详解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年薪挑战!​zhuanlan.zhihu.com图标

 

posted @ 2020-03-19 14:11  八重樱  阅读(288)  评论(0编辑  收藏