内容简介:CLI 模式不支持 move_uploaded_file() 函数,因此 $_FILE 内容会和默认的不一样,需要手动处理。参考由于 CLI 模式不支持 header() 函数,需要使用 WorkerMan 自带的 Http::header() 代替。我的做法是在render() 函数加上 Http::header()
CLI 模式不支持 move_uploaded_file() 函数,因此 $_FILE 内容会和默认的不一样,需要手动处理。参考 http://doc.workerman.net/web-server.html
报错
由于 CLI 模式不支持 header() 函数,需要使用 WorkerMan 自带的 Http::header() 代替。我的做法是在
app/Exceptions/Handler.php
render() 函数加上 Http::header()
Auth Guard 保留登录信息
如果使用了 Auth 中间件,程序会一直保留登录信息,不管谁登录都返回第一个用户。我的做法是复制默认的 RequestGuard.php 到
app/Services/Auth/RequestGuard.php
并增加函数
public function logout()
{
$this->user = null;
}
然后在
app/Providers/AuthServiceProvider.php
里增加这个 guard
public function boot()
{
$this->app['auth']->extend('api', function($app, $name, array $config) {
return new RequestGuard(function ($request) {
if ($request->input('apiToken')) {
$user = new User;
return $user->getByApiToken($request->input('apiToken'));
}
},
$app['request'],
$app['auth']->createUserProvider());
});
}
然后修改
app/Http/Middleware/Authenticate.php
public function handle($request, Closure $next, $guard = null)
{
$guard = $this->auth->guard($guard);
$guard->setRequest($request); // 这里是为了每次请求都重新设置一遍参数
if ($guard->guest()) {
return response('Unauthorized.', 401);
}
return $next($request);
}
最后在每次请求完后执行一次
app('auth')->logout();
清理登录信息
lumen和event扩展冲突
如果系统里安装了 event 扩展,Lumen 在使用 artisan 或者 bootstrap/app.php 里打开了 $app->withFacades(),那么系统会报
Cannot declare class Event, because the name is already in use
Laravel 不知道会不会报错,估计也会。
这时候在 Console/Kernel.php 里加入
protected $aliases = false;
就可以了。代价是不能使用 Facades 了。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
PHP高级程序设计
Kevin McArthur / 汪泳 等 / 人民邮电出版社出版 / 2009.7 / 45.00元
今天,PHP已经是无可争议的Web开发主流语言。PHP 5以后,它的面向对象特性也足以与Java和C#相抗衡。然而,讲述PHP高级特性的资料一直缺乏,大大影响了PHP语言的深入应用。 本书填补了这一空白。它专门针对有一定经验的PHP程序员,详细讲解了对他们最为重要的主题:高级面向对象、设计模式、文档、测试和标准PHP库等内容。同时,为适应目前Web开发的新趋势,作者还全面探讨了MVC架构和Z......一起来看看 《PHP高级程序设计》 这本书的介绍吧!