内容简介: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 了。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Charlotte's Web
E. B. White / Puffin Classics / 2010-6-3 / GBP 6.99
This is the story of a little girl named Fern who loved a little pig named Wilbur and of Wilbur's dear friend, Charlotte A. Cavatica, a beautiful large grey spider. With the unlikely help of Templeton......一起来看看 《Charlotte's Web》 这本书的介绍吧!