php - laravel5.2 如何删除session。
大家讲道理
大家讲道理 2017-04-10 17:32:03
[PHP讨论组]

做用户退出登录,ajax调用删除session登录时设置的$request->session()->put('user','value');
使用了$request->session()->forget('user');然后跳转到login页
但是发现跳转后获取的session数据仍然是删除前的session状态,所以还是保持了登录状态。求教是我用法错误吗?

下面是ajax调用的方法:

    public function logout(Request $request)
    {
        if ($request->session()->has('user')) {
            $is_forgotten = $request->session()->forget('user');
            if ($is_forgotten === null)
                echo json_encode(['result' => 1]);
            exit;
        }
        echo json_encode(['result'=>0,'msg'=>'退出失败']);
        exit;
    }

下面是登录时给session的user赋值的代码

    public function valid(Request $request)
    {
        $r = $request->all();
        $validator = Validator::make($r,[
            'username'=>'bail|required',
            'password'=>'bail|required|integer',
        ]);

        if ($validator->fails()) {
            return redirect('admin/login')->withErrors($validator)->withInput();
        }

        $where = [
            'name'=>$r['username'],
            'pwd'=>md5($r['password']),
        ];

        $hasExists = AdminModel::hasExists($where);

        if (null !== $hasExists) {
            $request->session()->put('user',json_encode(['name'=>$r['username']]));
            return redirect('admin');
        } else {
            return redirect('admin/login')->with('hasExists','用户名或密码错误');
        }
    }
大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回复(1)
阿神

建议楼主在了解一下Larave的Session机制,如果你的代码中途有exit,最好在它之前Session::save()一下

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号