thinkphp 5框架实现登陆,登出及session登陆状态检测功能示例
时间:2021-01-22
来源:互联网
这篇文章主要介绍了thinkphp 5框架实现登陆,登出及session登陆状态检测功能,结合实例形式分析了thinkPHP5登陆判断、跳转及session的相关使用技巧,需要的朋友可以参考下
本文实例讲述了thinkphp 5框架实现登陆,登出及session登陆状态检测功能。分享给大家供大家参考,具体如下:
1,访问http://localhost/tp5/admin.php时,判断有没有登陆:
想法:写一个父类,继承controller,然后定义一个初始化方法,在控制器调用时就判断是否登陆
<?php
namespace app\Admin\controller;
use think\Controller;
use think\Session;
class Basic extends Controller
{
//如果你的控制器类继承了\think\Controller类的话,可以定义控制器初始化方法_initialize,在该控制器的方法调用之前首先执行。
public function _initialize()
{
//判断有无admin_username这个session,如果没有,跳转到登陆界面
if(!session('admin_username')){
return $this->error('您没有登陆',url('Login/login'));
}
}
}
登陆界面:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<h1>登陆</h1>
<div>
<form role="form" action="{url('Login/login')}" method="post">
<div>
<input id="admin_username" type="text" name="admin_username" class=" validate" placeholder="请输入用户名" required>
<label for="admin_username">用户名</label>
</div>
<div>
<input id="admin_password" type="password" name="admin_password" placeholder="请输入密码" required>
<label for="admin_password">密码</label>
</div>
<button type="submit" class="waves-effect red lighten-1 waves-light btn full-width " style="margin-top:10px; height:40px;">登 录</button>
</form>
</div>
</body>
</html>
登陆控制器:
<?php
namespace app\Admin\controller;
use think\Controller;
use think\Session;
use think\Request;
use think\Db;
class Login extends Controller{
public function login(){
//判断是否是post方法发送的数据:如果是则开始登陆
if (Request::instance()->isPost()){
$admin_username = input('post.admin_username');//接收前台用户名
$admin_password = input('post.admin_password');//接收前台密码
if(empty($admin_username) || empty($admin_password)){
$this->error("用户名或者密码不能为空!");
}
//从数据库读取数据
$admin_info = DB::name('admin')
->where('admin_username',$admin_username)
->find();
if(empty($admin_info)){
$this->error('用户不存在,请重新登陆',url('Login/login'));
}else{
if(md5($admin_password)!=$admin_info['admin_password']){
$this->error('密码不正确,请重新登陆',url('Login/login'));
}else{
Session::set('admin_username',$admin_username);
$this->success("登录成功!",url('Index/index'));
}
}
}else{//如果不是post,则返回登陆界面
return view('login');
}
}
public function logout(){
session(null);//退出清空session
return $this->success('退出成功',url('Login/login'));//跳转到登录页面
}
}
如果失败,回到登陆页面;如果登陆成功,跳转到后台首页:
<?php
namespace app\Admin\controller;
use think\Controller;
use think\Session;
use think\View;
//后台首页继承自登陆判断页面,每次加载都会先执行判断页面的代码
class Index extends Basic
{
public function index()
{
$view = new View();
$data = session('admin_username');
$view->assign('data',$data);
//return view('index');
return $view->fetch('index');
}
}
后台首页面:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<!-- <h1>hello,{$Think.session.admin_username}</h1> -->
<h1>hello,{$data}</h1>
<a href="{:url('Login/logout')}" rel="external nofollow" >退出登陆</a>
</body>
</html>
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
-
冷钱包是什么?跟热钱包有什么差别?如何选择最安全的存币方式? 时间:2025-04-30
-
什么是欧易Web3钱包?如何创建或导入/管理欧易Web3钱包? 时间:2025-04-30
-
如何通过Gate Web3钱包购买加密货币? 时间:2025-04-30
-
如何从Gate.io转账至Gate Web3钱包?如何将钱包资产转回Gate.io账户? 时间:2025-04-30
-
Gate Web3钱包常见问题汇总 时间:2025-04-30
-
如何使用Gate.io web3钱包进行转账/充值?(App端) 时间:2025-04-30
今日更新
-
当手上出现肉眼可见的脏污时最好用什么清洗
阅读:26
-
CF2021年1月新刮刮卡活动地址
阅读:121
-
PHP SESSION跨页面传递失败解决方案
阅读:27
-
PHP使用Session实现上传进度功能详解
阅读:21
-
PHP实现cookie跨域session共享的方法分析
阅读:24
-
PHPcookie与session会话基本用法实例分析
阅读:21
-
PHP实现超简单的SESSION与COOKIE登录验证功能示例
阅读:20
-
PHP图像处理与SESSION制作超简单验证码的方法示例
阅读:26
-
php7 list()、session及其他模块的修改实例分析
阅读:21
-
DNF2021春节永恒副本怎么打?DNF副本攻略!
阅读:22