thinkphp如何写登录代码
来源:互联网 发布:奥巴马医改利弊 知乎 编辑:程序博客网 时间:2024/06/09 19:17
目的:注册成功后就进入首页,并告诉你是登录用户。
第一步:在config.php文件中加上
'USER_AUTH_KEY'=>'authId'
这一句,示例如下:
<?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)
{
//$_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:3000/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()
{
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'))
第一步:在config.php文件中加上
'USER_AUTH_KEY'=>'authId'
这一句,示例如下:
<?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)
{
//$_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:3000/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()
{
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'))
0 0
- thinkphp如何写登录代码
- thinkphp如何写登录代码
- 如何写thinkphp的注册与登录代码-thinkphp的session设置
- thinkphp登录代码
- ThinkPHP如何使用QQ登录?
- ThinkPHP登录
- thinkPHP 登录
- 如何精准写代码
- 如何写好代码
- 如何写伪代码?
- 程序员如何写代码
- 如何写好代码
- 如何写伪代码
- 如何写好代码
- 如何写好代码
- 如何写好代码
- 如何写好代码
- 如何写好代码
- MongoDB 学习(-) 安装
- 健康卧室床头别放5样东西
- 健康卧室床头别放5样东西
- sqlite3中的数据类型
- 瓦让他十分的人员和人员和
- thinkphp如何写登录代码
- 额外热特色是一个人同意
- 恶趣味大大大大的
- android 20个常用的系统调用代码片段
- 是的风格是大法官史蒂夫
- 大卫的我的大大的
- sqlite3函数使用说明1
- 啊是打工撒旦稍等
- 基于Android的移动终端应用程序开发与研究