通过以下命令刚安装的Lumen:
<code>composer create-project laravel/lumen --prefer-dist </code>
做了以下修改:
1、修改 .env 文件
<code>APP_KEY=iMXwF1A6Vdbg5V8bYzuNbqv0HX6nH9Cd SESSION_DRIVER=file </code>
2、修改 bootstrap/app.php 文件,取消以下代码的注释屏蔽:
<code>Dotenv::load(__DIR__.'/../'); $app->withFacades(); $app->withEloquent(); $app->middleware([ // Illuminate\Cookie\Middleware\EncryptCookies::class, // Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, Illuminate\Session\Middleware\StartSession::class, // Illuminate\View\Middleware\ShareErrorsFromSession::class, // Laravel\Lumen\Http\Middleware\VerifyCsrfToken::class, ]); </code>
出现以下错误提示:
<code>Whoops, looks like something went wrong. 1/1 ErrorException in StartSession.php line 171: Argument 1 passed to Illuminate\Session\Middleware\StartSession::addCookieToResponse() must be an instance of Symfony\Component\HttpFoundation\Response, string given, called in F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php on line 71 and defined in StartSession.php line 171 at Application->Laravel\Lumen\{closure}('4096', 'Argument 1 passed to Illuminate\Session\Middleware\StartSession::addCookieToResponse() must be an instance of Symfony\Component\HttpFoundation\Response, string given, called in F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php on line 71 and defined', 'F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php', '171', array()) in StartSession.php line 171 at StartSession->addCookieToResponse(' <title>Lumen</title> <link href="//fonts.googleapis.com/css?family=Lato:100" rel="stylesheet" type="text/css"> <style> body { margin: 0; padding: 0; width: 100%; height: 100%; color: #B0BEC5; display: table; font-weight: 100; font-family: 'Lato'; } .container { text-align: center; display: table-cell; vertical-align: middle; } .content { text-align: center; display: inline-block; } .title { font-size: 96px; margin-bottom: 40px; } .quote { font-size: 24px; } </style> <div class="container"> <div class="content"> <div class="title">Lumen.</div> </div> </div> ', object(Store)) in StartSession.php line 71 at StartSession->handle(object(Request), object(Closure)) at call_user_func_array(array(object(StartSession), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) at call_user_func(object(Closure), object(Request)) in Pipeline.php line 103 at Pipeline->then(object(Closure)) in Application.php line 1354 at Application->sendThroughPipeline(array('Illuminate\Session\Middleware\StartSession'), object(Closure)) in Application.php line 1135 at Application->dispatch(null) in Application.php line 1073 at Application->run() in index.php line 28 </code>
然后找到vendor/illuminate/session/Middleware/StartSession.php文件,添加了调试信息:
修改 handle() 方法如下:
<code> public function handle(Request $request, Closure $next) { $this->sessionHandled = true; // If a session driver has been configured, we will need to start the session here // so that the data is ready for an application. Note that the Laravel sessions // do not make use of PHP "native" sessions in any way since they are crappy. if ($this->sessionConfigured()) { $session = $this->startSession($request); $request->setSession($session); } $response = $next($request); echo gettype($response) . '<br>'; // Again, if the session has been configured we will need to close out the session // so that the attributes may be persisted to some storage medium. We will also // add the session identifier cookie to the application response headers now. if ($this->sessionConfigured()) { $this->storeCurrentUrl($request, $session); $this->collectGarbage($session); echo gettype($response) . '<br>'; $this->addCookieToResponse($response, $session); } return $response; } </code>
输出显示:
<code>string string </code>
错误信息说 addCookieToResponse 方法第一个参数 需要 Response实例,而的到是却是String,不知如何解决@@
回复内容:
通过以下命令刚安装的Lumen:
<code>composer create-project laravel/lumen --prefer-dist </code>
做了以下修改:
1、修改 .env 文件
<code>APP_KEY=iMXwF1A6Vdbg5V8bYzuNbqv0HX6nH9Cd SESSION_DRIVER=file </code>
2、修改 bootstrap/app.php 文件,取消以下代码的注释屏蔽:
<code>Dotenv::load(__DIR__.'/../'); $app->withFacades(); $app->withEloquent(); $app->middleware([ // Illuminate\Cookie\Middleware\EncryptCookies::class, // Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, Illuminate\Session\Middleware\StartSession::class, // Illuminate\View\Middleware\ShareErrorsFromSession::class, // Laravel\Lumen\Http\Middleware\VerifyCsrfToken::class, ]); </code>
出现以下错误提示:
<code>Whoops, looks like something went wrong. 1/1 ErrorException in StartSession.php line 171: Argument 1 passed to Illuminate\Session\Middleware\StartSession::addCookieToResponse() must be an instance of Symfony\Component\HttpFoundation\Response, string given, called in F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php on line 71 and defined in StartSession.php line 171 at Application->Laravel\Lumen\{closure}('4096', 'Argument 1 passed to Illuminate\Session\Middleware\StartSession::addCookieToResponse() must be an instance of Symfony\Component\HttpFoundation\Response, string given, called in F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php on line 71 and defined', 'F:\upupw\vhosts\lumen\vendor\illuminate\session\Middleware\StartSession.php', '171', array()) in StartSession.php line 171 at StartSession->addCookieToResponse(' <title>Lumen</title> <link href="//fonts.googleapis.com/css?family=Lato:100" rel="stylesheet" type="text/css"> <style> body { margin: 0; padding: 0; width: 100%; height: 100%; color: #B0BEC5; display: table; font-weight: 100; font-family: 'Lato'; } .container { text-align: center; display: table-cell; vertical-align: middle; } .content { text-align: center; display: inline-block; } .title { font-size: 96px; margin-bottom: 40px; } .quote { font-size: 24px; } </style> <div class="container"> <div class="content"> <div class="title">Lumen.</div> </div> </div> ', object(Store)) in StartSession.php line 71 at StartSession->handle(object(Request), object(Closure)) at call_user_func_array(array(object(StartSession), 'handle'), array(object(Request), object(Closure))) in Pipeline.php line 124 at Pipeline->Illuminate\Pipeline\{closure}(object(Request)) at call_user_func(object(Closure), object(Request)) in Pipeline.php line 103 at Pipeline->then(object(Closure)) in Application.php line 1354 at Application->sendThroughPipeline(array('Illuminate\Session\Middleware\StartSession'), object(Closure)) in Application.php line 1135 at Application->dispatch(null) in Application.php line 1073 at Application->run() in index.php line 28 </code>
然后找到vendor/illuminate/session/Middleware/StartSession.php文件,添加了调试信息:
修改 handle() 方法如下:
<code> public function handle(Request $request, Closure $next) { $this->sessionHandled = true; // If a session driver has been configured, we will need to start the session here // so that the data is ready for an application. Note that the Laravel sessions // do not make use of PHP "native" sessions in any way since they are crappy. if ($this->sessionConfigured()) { $session = $this->startSession($request); $request->setSession($session); } $response = $next($request); echo gettype($response) . '<br>'; // Again, if the session has been configured we will need to close out the session // so that the attributes may be persisted to some storage medium. We will also // add the session identifier cookie to the application response headers now. if ($this->sessionConfigured()) { $this->storeCurrentUrl($request, $session); $this->collectGarbage($session); echo gettype($response) . '<br>'; $this->addCookieToResponse($response, $session); } return $response; } </code>
输出显示:
<code>string string </code>
错误信息说 addCookieToResponse 方法第一个参数 需要 Response实例,而的到是却是String,不知如何解决@@
抱歉,刚刚下班回来才看到。
如果直接在路由的回调中返回的确实是 String
,如果是在控制器中调用,框架会帮忙把 String
转为 Response
对象。
当然,在路由回调中我们直接也可以转一下。prepareResponse
方法参见类 Laravel\Lumen\Application
:
<code>php</code><code>$app->get('/', function() use ($app) { return $app->prepareResponse($app->welcome()); }); </code>
@Mr_Jing(Lumen 初体验 文章作者)可以麻烦解答下吗?

TheSecretTokeEpingAphp-PowerEdwebSiterUnningSmoothlyShyunderHeavyLoadInVolvOLVOLVOLDEVERSALKEYSTRATICES:1)emplactopCodeCachingWithOpcachingWithOpCacheToreCescriptexecution Time,2)使用atabasequercachingCachingCachingWithRedataBasEndataBaseLeSendataBaseLoad,3)

你应该关心DependencyInjection(DI),因为它能让你的代码更清晰、更易维护。1)DI通过解耦类,使其更模块化,2)提高了测试的便捷性和代码的灵活性,3)使用DI容器可以管理复杂的依赖关系,但要注意性能影响和循环依赖问题,4)最佳实践是依赖于抽象接口,实现松散耦合。

是的,优化papplicationispossibleandessential.1)empartcachingingcachingusedapcutorediucedsatabaseload.2)优化的atabaseswithexing,高效Quereteries,and ConconnectionPooling.3)EnhanceCodeWithBuilt-unctions,避免使用,避免使用ingglobalalairaiables,并避免使用

theKeyStrategiestosiminificallyBoostphpapplicationPermenCeare:1)useOpCodeCachingLikeLikeLikeLikeLikeCacheToreDuceExecutiontime,2)优化AtabaseInteractionswithPreparedStateTemtStatementStatementSandProperIndexing,3)配置

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。