问题描述
当微信小程序开发中用laravel做后台的时候一定会遇到登录session的问题
因为小程序没有cookie,所以每一次请求的时候,相当于关闭浏览器,重新打开浏览器请求,服务器会重新生成一条session。php的有自己的session回收机制,但是laravel并没有用PHP的session那套,而是有一套自己的session机制。本人是用的redis存储session,这相当于每次请求的时候都在redis中新生成一条记录,当访问量特别大的时候,请求比较多,而设置的session时间又很长的时候这个时候可能导致redis撑爆,要保证session不重新生成,网上有介绍很多办法,可以直接用别人针对微信登录的vendor包,也可以自己动手。
解决办法
- 小程序重新封装一个http请求,将cookie放在header头中,每次请求带上cookie
function Http({
url,
data,
success,
fail,
complete,
method = "POST"
}) {
var session_id = wx.getStorageSync('PHPSESSID'); //本地取存储的sessionID
if (session_id != "" && session_id != null) {
var header = {
'content-type': 'application/x-www-form-urlencoded',
'Cookie': 'skey=' + session_id
}
} else {
var header = {
'content-type': 'application/x-www-form-urlencoded'
}
}
wx.request({
url: url,
method: method,
data: data,
header: header,
success: res => {
console.log(res);
if (session_id == "" || session_id == null) {
wx.setStorageSync('PHPSESSID', res.data.session_id) //如果本地没有就说明第一次请求 把返回的session id 存入本地
}
let data = res.data
res['statusCode'] === 200 ? success(data) : fail(res)
},
fail: fail,
complete: complete
})
}
2.修改laravel的env配置加上
SESSION_COOKIE=skey
3.关键的一点就是在Illuminate\Session\Middleware\StartSession中getSession中通过cookie获取cookie值的时候,居然没有获取到,而普通浏览器请求可以获取到,这里面的laravel机制没有追到,所以之后修改vendor代码如下,直接使用php的$_COOKIE获取
public function getSession(Request $request)
{
return tap($this->manager->driver(), function ($session) use ($request) {
$cookie_name = $session->getName();
$sesssion_id = isset($_COOKIE[$cookie_name]) ? $_COOKIE[$cookie_name] : '';
$session->setId($sesssion_id);
// $session->setId($request->cookies->get($session->getName()));
});
}