m_Orchestrate learning system---三、session使用完整流程是什么
一、总结
一句话总结:
1、在登录成功之后设置session和cookie
2、在公共控制器里面使用session和cookie判断是否已经登录(做基本的权限控制)
3、在视图页面调用session来显示登录
4、退出登录之后,把cookie和session都清空
1、thinkphp中session和cookie的使用的完整流程是怎样?
1、在登录成功之后设置session和cookie
1 <?php
2 namespace app\index\controller;
3 use think\Loader; 4 use think\Validate; 5 6 use app\index\controller\Base; 7 8 class Login extends Base 9 { 10 //登录 11 public function login() 12 { 13 if(request()->isPost()){ 14 //1、获取用户从页面上传过来的账号和密码 15 $data=input('post.'); 16 // dump($data);die; 17 //2、对获取的数据进行验证 18 $captcha = new \think\captcha\Captcha(); 19 if (!$captcha->check($data['code'])) { 20 $this->error('验证码错误'); 21 } 22 $validate = Loader::validate('Login'); 23 if(!$validate->scene('login')->check($data)){ 24 $this->error($validate->getError()); die; 25 } 26 27 //3、在数据库中查找此用户和密码,找到则登录成功,没找到则登录失败 28 $res=db('user')->where('username',$data['username'])->where('password',md5($data['password']))->where('status',$data['status'])->find(); 29 //4、如果在数据库中查找到数据,则判断是老师还是学生,跳转到相应的页面去,没有就直接返回错误界面 30 if($res){ 31 //5、登录成功,将数据存入cookie和session 32 //5.1、将登录信息写入session 33 session('id', $res['id']); 34 session('username', $res['username']); 35 session('password', $res['password']); 36 //5.2、设置cookie 37 cookie('id', $res['id'], 3600); 38 cookie('username', $res['username'], 3600); 39 cookie('password', $res['password'], 3600); 40 if($data['status']) $this->success("即将跳转到老师界面!!",url('teacher/index/index')); 41 else $this->success("即将跳转到学生界面!!",url('student/index/index')); 42 }else{ 43 $this->error('用户名或者密码错误或者未注册!!'); 44 } 45 46 } 47 48 return view(); 49 } 50 51 }
2、在公共控制器里面使用session和cookie判断是否已经登录(做基本的权限控制)
1 <?php
2 namespace app\teacher\controller;
3
4 use think\Controller; 5 6 class Base extends Controller 7 { 8 /** 9 * 登录之后显示正确登录的用户 10 * 0、将登录的用户信息写入session 11 * 1、获取登录的用户的数据 12 * 2、将获取的数据传递到top.htm页面 13 * @return [type] [description] 14 */ 15 public function _initialize() 16 { 17 if(!session('username')){ 18 //如果cookie存在的话 19 if(cookie('username')){ 20 //设置session 21 session('id', cookie('id')); 22 session('username',cookie('username')); 23 session('password', cookie('password')); 24 // dump(cookie('username'));die; 25 return; 26 } 27 $this->error('您尚未登录系统',url('index/login/login')); 28 } 29 } 30 }
3、在视图页面调用session来显示登录
<span class="tpl-header-list-user-nick">{$Request.session.username}</span> <span class="tpl-header-list-user-ico"> <img src="__TEACHER__/assets/img/user01.png"></span>
4、退出登录之后,把cookie和session都清空
1 <?php
2 namespace app\teacher\controller;
3
4 use think\Controller; 5 6 class Base extends Controller 7 { 8 //退出登录操作 9 public function logout(){ 10 session(null); 11 cookie('id', null); 12 cookie('username', null); 13 cookie('password', null); 14 //退出登录清空session之后要成功跳转 15 $this->success('退出系统成功',url('index/index/index')); 16 } 17 }
二、内容在总结中
项目地址
fry404006308/m_Orchestrate: m_Orchestrate
https://github.com/fry404006308/m_Orchestrate