结合Memcache实现登录信息保存

场景:一个pos机需要多个账号信息登录;同时不能挤掉别人.

1.购买阿里云Memcache;

2.引入对应的sdk类文件;实例化调用

function login_form_password()
{
    if (empty($this->data['admin'])) {
        return ['code' => 1, 'msg' => '请输入正确的用户登陆名'];
    }
    if (empty($this->data['password'])) {
        return array("code" => 1, "msg" => "参数错误或者缺少");
    }
    if (empty($this->data['platform']) || !in_array($this->data['platform'], ["android", "ios", "pc", "wx", 'wxxcx'])) {
        return array("code" => 1, "msg" => 'platform ' . "参数错误或者缺少");
    }
    $admin = $this->DB('slave1')->get(TABLE_MERCHANT_USER, ['admin_id', "admin_pwd", 'store_id'], ["admin_account" => $this->data['admin']]);
    if (MD5($this->data['password'] . APISECRET) == $admin['admin_pwd']) {
        $oMucache = new mucache(false);
        //修改数据库 商家登录的最新时间
        $this->DB('master')->update(TABLE_MERCHANT_USER, [
            'pos_last_login' => date('Y-m-d H:i:s')
        ], [
            'admin_id' => $admin['admin_id']
        ]);
        $token = $this->generateNum();
        $ok = $oMucache->set($admin['admin_id'] . '|' . $this->data['platform'], $token, 7200);
        if ($ok === true) {
            //前端获取到token进行解析,然后想访问后台接口必须携带
            return array("code" => 0, "token" => base64_encode(($admin['admin_id'] + 139188800) . "|" . $token . "|" . $admin['store_id']));
        }
    }
    return array("code" => 1, "msg" => "身份识别失败");
}

3.memcache类中要传入相应的配置

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值