php框架实现登录,thinkphp框架下实现登录、注册、找回密码功能

本文介绍了如何在ThinkPHP框架下利用AJAX处理登录、注册和找回密码的流程。包括用户输入验证、数据加密、状态判断(如未审核和禁用状态)以及会话管理。注册后的用户需要经过后台审核才能使用。同时,提供了登录成功和失败的反馈,以及登出功能。
摘要由CSDN通过智能技术生成

本文实例为大家分享了thinkphp框架下使用ajax表单提交的登录、注册、找密码的实现方法,以及注册后的用户需后台审核。

user表的字段为id、num、password、name、email、addtime、status

具体代码如下

namespace Home\Controller;

use Think\Controller;

class LoginController extends Controller {

//处理登录

public function signin(){

if(IS_GET){

$this->display();

}

if(IS_POST){

/* 调用登录接口登录 */

$User = M('user') ;

//I方法接收页面传递来的值

$num = I('num') ;

$password = I('password') ;

//查找user表中num等于$num的值

$datanum = $User->where(array('num'=>$num))->find();

//判断$datanum的值

if ($datanum){

if (md5($password) === $datanum['password']) {

if ($datanum['status'] == 0) {

$this->error('用户处于未审核状态,请联系管理员');

}elseif($datanum['status'] == 2){

$this->error('用户处于禁用状态,请联系管理员');

}else{

$this->autoLogin($datanum) ; //调用私有方法自动登录.

$uid = $datanum['id'];

if($_SESSION['user_auth']['uid'] && $_SESSION['user_auth']['role'] == 'user'){

$this->success('登录成功!', U('Index/index'));

}else{

$this->error('存储错误.');

}

}

}else{

$this->error('密码填写不正确,请重新填写');

exit();

}

}else{

$this->error('用户不存在,请注册',U('signup'));

}

}

}

public function autoLogin($user){

/* 记录登录SESSION */

$auth = array(

'uid' => $user['id'],

'num' => $user['num'],

'role' => 'user' , //记录用户类型

);

session('user_auth', $auth);

session('user_auth_sign', data_auth_sign($auth));

}

/*

* 用户注册

*/

public function signup(){

if(is_user_login()){

$this->redirect('Index/index');

}

if(IS_GET){

//注册页面

$this->display();

}

if(IS_POST){

//判断用户

$data['num'] = I('num') ;

$User = M('user') ;

$datanum = $User->where($data)->find();

if ($datanum){

$this->success('您已经注册过,请直接登录',U('signin'));

}else{

$data['password'] = md5(I('password'));

$data['name'] = I('name');

$data['email'] = I('email');

$data['addtime'] = time();

$uid = $User->add($data);

if($uid)

$this->success('注册成功',U('signin')) ;

else

$this->error('注册失败') ;

}

}

}

public function logout(){

if(is_user_login()){

$User = M('user') ;

session('user_auth', null);

session('user_auth_sign', null);

session('[destroy]');

$this->success('登出成功!', U('signin'));

} else {

$this->redirect('signin');

}

}

//忘记密码

public function wjpas(){

if(IS_GET){

$this->display();

}

if(IS_POST){

$User = M('user') ;

$num = I('num') ;

$data['password'] = md5(I('password')) ;

$email = I('email') ;

$datanum = $User->where(array('num'=>$num))->find();

if ($datanum){

if ($email === $datanum['email']) {

$User->where(array('num'=>$num))->save($data); // 根据条件更新记录

$this->success('密码修改成功',U('signin')) ;

}else{

$this->error('邮箱填写不正确,请重新填写');

exit();

}

}else{

$this->error('用户不存在,请注册',U('signup'));

}

}

}

}

?>

以上就是本文的全部内容,希望对大家学习php程序设计有所帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值