分享如何写ThinkPHP的注册和登录代码
作者:bea
thinkphp的登录代码,看起来很简单,正因为简单,也就没有人去写这方面的文章。但对于初学者来说,它确是一个拦路虎,得花时间去摸索。我写一个,抛砖引玉。 目的:注册成功后就进入首页,并“***欢迎你回来”。 第一步:在config.php文件中加上 'USER_AUTH_KEY'=>'authId' 这一句,示例如下: 'mysql',// 指定数据库是mysql 'DB_HOST'=> 'localhost', 'DB_NAME'=>'myuser', // 数据库
thinkphp的登录代码,看起来很简单,正因为简单,也就没有人去写这方面的文章。但对于初学者来说,它确是一个拦路虎,得花时间去摸索。我写一个,抛砖引玉。
目的:注册成功后就进入首页,并“***欢迎你回来”。
第一步:在config.php文件中加上
'USER_AUTH_KEY'=>'authId'
这一句,示例如下:
'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);//将用户名写入Session
echo "alert('数据库添加成功');location.href='http://127.0.0.1:3000/zhuce/index.php/index';";
}
else throw_exception("alert('数据库添加失败');history.back();");
}
第三步:在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();
}
第四步:首页显示模板,部分代码如下:
{$msg}
这是我的首页
小结:登录代码都是围绕写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'
这一句,示例如下:
'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);//将用户名写入Session
echo "alert('数据库添加成功');location.href='http://127.0.0.1:3000/zhuce/index.php/index';";
}
else throw_exception("alert('数据库添加失败');history.back();");
}
第三步:在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();
}
第四步:首页显示模板,部分代码如下:
{$msg}
这是我的首页
小结:登录代码都是围绕写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')) 有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 电脑使用技巧大全
- 如何快速提高电脑运行速度
- 教你怎样换电脑鼠标图标
- 教你怎么优化和美化电脑桌面
- ThinkPHP模板 用ThinkPHP写的模板应用
- thinkphp常使用的系统常量整理发布
- thinkphp视频教程下载地址兄弟连thinkphp视频
- Thinkphp向数据库插入数据失败原因
- 分享一个thinkphp错误提示页面代码
- 解决ThinkPHP错误页无法正常跳转
- ThinkPHP实例 用户注册登录留言
- ThinkPHP中文乱码解决方案
- ThinkPHP分页中的条件查询问题
- soap在ThinkPHP中的使用实例
- 什么是ThinkPHP框架新手了解下
- M方法和D方法在ThinkPHP中的区别
- 总结ThinkPHP使用技巧经验分享
- 比较ThinkPHP和FleaPHP二款PHP框架
- ThinkPHP教程详解CURD的使用