详解ThinkPHP登录功能实例代码
用户登陆功能是PHP程序设计中常见的需求,本文ThinkPHP实例主要完成注册成功后进入首页的代码编写,并告诉你是如何实现登录用户的功能。 详解ThinkPHP登录功能实例代码 具体步骤: 第一步:在config.php文件中加上: 'USER_AUTH_KEY'=>'authId'
示例如下: (推荐教程: 女神老师讲解thinkphp6支付大通关_ ? 还搁这学tp5?thinkphp6都出来了 ) ? <?php if(!defined('THINK_PATH')) exit(); return array( // 定义数据库连接信息 'DB_TYPE'=> 'mysql',// 指定数据库是mysql 'DB_HOST'=> 'localhost','DB_NAME'=>'myuser',// 数据库名 'DB_USER'=>'root','DB_PWD'=>'',//您的数据库连接密码 'DB_PORT'=>'3306','DB_PREFIX'=>'think_',//数据表前缀 'USER_AUTH_KEY'=>'authId' ); ?>
第二步:在AdminAction.class.php中的insert()代码中用: Session::set(C('USER_AUTH_KEY'),$user);
保存登录用户名到session。 完整实现代码如下: public function insert() { header('Content-Type:text/html; charset=utf-8');//防止出现乱码 $user=$_POST['user']; $this->verifyCheck(); $Pagemodel = D("user"); $vo = $Pagemodel->create(); if(false === $vo) die($Pagemodel->getError()); $topicid = $Pagemodel->add(); //add方法会返回新添加的记录的主键值 if($topicid) { // www.jbxue.com //$_SESSION[C('USER_AUTH_KEY')]=$user;//不能用此句 Session::set(C('USER_AUTH_KEY'),$user); //dump(Session::get('authId')); echo "<script>alert('数据库添加成功');location.href='http://127.0.0.1/zhuce/index.php/index';</script>"; } else throw_exception("<script>alert('数据库添加失败');history.back();</script>"); }
第三步:在IndexAction.class.php文件中用if(!Session::is_set(C('USER_AUTH_KEY')))判断用户登录了没有。 Session::get(C('USER_AUTH_KEY'))是获取登录用户的名。
具体代码如下: public function index() { //www.jbxue.com if(!Session::is_set(C('USER_AUTH_KEY'))) //if(!isset($_SESSION['USER_AUTH_KEY'])||($_SESSION['USER_AUTH_KEY']==0))//不能用此句 { $msg="用户没有登录"; } else { $msg=Session::get(C('USER_AUTH_KEY')).'欢迎你回来'; } $this->assign('msg',$msg); $this->display(); }
第四步:首页显示模板,代码如下: <body> {$msg}<br /> 这是我的首页 </body>
总结: 登录代码都是围绕写session,判断session,读session展开。 写session用:Session::set(C('USER_AUTH_KEY'),$user); 判断session用:if(!Session::is_set(C('USER_AUTH_KEY'))); 读session用:Session::get(C('USER_AUTH_KEY')) 更多内容请访问 怎么从一名码农成为架构师的必看知识点:目录大全(持续更新)50W年薪挑战! ? (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |