laravel 小程序登录 session问题

问题描述

当微信小程序开发中用laravel做后台的时候一定会遇到登录session的问题

因为小程序没有cookie,所以每一次请求的时候,相当于关闭浏览器,重新打开浏览器请求,服务器会重新生成一条session。php的有自己的session回收机制,但是laravel并没有用PHP的session那套,而是有一套自己的session机制。本人是用的redis存储session,这相当于每次请求的时候都在redis中新生成一条记录,当访问量特别大的时候,请求比较多,而设置的session时间又很长的时候这个时候可能导致redis撑爆,要保证session不重新生成,网上有介绍很多办法,可以直接用别人针对微信登录的vendor包,也可以自己动手。

解决办法

  1. 小程序重新封装一个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()));
        });
    }

你可能感兴趣的:(laravel 小程序登录 session问题)