内容简介: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 了。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
技术领导之路(中英文对照)
Gerald M.Weinberg / 余晟 / 电子工业出版社 / 2009-12 / 69.00元
《技术领导之路:全面解决问题的途径(中英文对照)》内容简介:搞定技术问题并不简单,但与人打交到也并非易事。作为一个技术专家,你是否在走上管理岗位时遇到了各种不适“症状”?《技术领导之路:解决问题的有机方法》一书将帮助你成为一个成功的解决问题的领导者。书中温伯格从一个反思者的角度阐述了要成为一个成功的解决问题的领导者必备的3个技能——MOI,即激励(Motivation)、组织(Organizati......一起来看看 《技术领导之路(中英文对照)》 这本书的介绍吧!