当前位置: 首页 > news >正文

PHP 用户登录与退出

PHP 用户登录与退出

登录页面

login.html 负责收集用户填写的登录信息。

<fieldset>

<legend>用户登录</legend>

<form name="LoginForm" method="post" action="login.php" onSubmit="return InputCheck(this)">

<p>

<label for="username" class="label">用户名:</label>

<input id="username" name="username" type="text" class="input" />

<p/>

<p>

<label for="password" class="label">密 码:</label>

<input id="password" name="password" type="password" class="input" />

<p/>

<p>

<input type="submit" name="submit" value=" 确 定 " class="left" />

</p>

</form>

</fieldset>

javascript 检测及 CSS 样式可参考 reg.html,本部分略去,可直接查看最后附录的完整代码。

登录处理

login.php 负责处理用户登录与退出动作。

//登录

if(!isset($_POST['submit'])){

exit('非法访问!');

}

$username = htmlspecialchars($_POST['username']);

$password = MD5($_POST['password']);

 

//包含数据库连接文件

include('conn.php');

//检测用户名及密码是否正确

$check_query = mysql_query("select uid from user where username='$username' and password='$password' limit 1");

if($result = mysql_fetch_array($check_query)){

//登录成功

$_SESSION['username'] = $username;

$_SESSION['userid'] = $result['uid'];

echo $username,' 欢迎你!进入 <a href="my.php">用户中心</a><br />';

echo '点击此处 <a href="login.php?action=logout">注销</a> 登录!<br />';

exit;

} else {

exit('登录失败!点击此处 <a href="javascript:history.back(-1);">返回</a> 重试');

}

该段代码首先确认如果是用户登录的话,必须是 POST 动作提交。然后根据用户输入的信息去数据库核对是否正确,如果正确,注册 session 信息,否则提示登录失败,用户可以重试。

该段代码需要在页面开头启用 session_start() 函数,参见下面 退出处理 代码部分。

退出处理

处理用户退出的代码跟处理登录的代码都在 login.php 里。

session_start();

 

//注销登录

if($_GET['action'] == "logout"){

unset($_SESSION['userid']);

unset($_SESSION['username']);

echo '注销登录成功!点击此处 <a href="login.html">登录</a>';

exit;

}

该段代码在处理用户登录的代码之前,只允许以 login.php?action=logout 的方式访问,其他方式都认为是检测用户登录。具体逻辑参看附录完整代码。

用户中心

my.php 是用户中心,列在教程里作为用户登录检测参考。

<?php

session_start();

 

//检测是否登录,若没登录则转向登录界面

if(!isset($_SESSION['userid'])){

header("Location:login.html");

exit();

}

//包含数据库连接文件

include('conn.php');

$userid = $_SESSION['userid'];

$username = $_SESSION['username'];

$user_query = mysql_query("select * from user where uid=$userid limit 1");

$row = mysql_fetch_array($user_query);

echo '用户信息:<br />';

echo '用户ID:',$userid,'<br />';

echo '用户名:',$username,'<br />';

echo '邮箱:',$row<'email'>,'<br />';

echo '注册日期:',date("Y-m-d", $row['regdate']),'<br />';

echo '<a href="login.php?action=logout">注销</a> 登录<br />';

?>

提示

  1. 用户注册登录涉及到用户信息与数据库的交互,因此要特别注意用户提交的信息不能为非法信息,本例中注册部分已经使用正则表达式做了限制,对登录部分只简单使用了 htmlspecialchars() 处理,实际应用时可更严格一些。
  2. 本教程只是简单演示用户注册与登录的过程,其代码仅供学习参考,不可直接用于项目生产。
  3. 本教程中对于用户登录成功后采用 session 来管理,也可以采用 cookie 来管理,尤其对于有时限要求的情况。
  4. 为了提高用户体验,用户注册部分可以结合 AJAX 来检测用户输入的信息而不必等点击提交后再检测。

     

     

    摘抄自:http://www.5idev.com/p-php_user_login.shtml

转载于:https://www.cnblogs.com/BruceLone/p/4264909.html

相关文章:

  • Java之线程池深度剖析
  • POCO浅探
  • Dataset+TableAdapter _.net最终数据访问类出现? 我的心血显然被藐视了
  • Scrum实施日记 - 我可以问问题吗?
  • Design Patterns
  • 手机端雅安地震寻人整合项目
  • 香港身份证
  • UDDI(一)
  • 浅谈 XSS CSRF(转)
  • ansible笔记(2):管理清单配置详解
  • VS2015 Web应用程序发布
  • 《Java核心技术卷一》之 泛型
  • emacs 窗口控制
  • 如何在同一任务列表中显示我的任务及我所属组的任务
  • POJ2017-Speed Limit
  • 【知识碎片】第三方登录弹窗效果
  • Brief introduction of how to 'Call, Apply and Bind'
  • docker-consul
  • Flannel解读
  • javascript数组去重/查找/插入/删除
  • Java深入 - 深入理解Java集合
  • k个最大的数及变种小结
  • laravel5.5 视图共享数据
  • MySQL的数据类型
  • mysql中InnoDB引擎中页的概念
  • python学习笔记-类对象的信息
  • SSH 免密登录
  • vue2.0项目引入element-ui
  • 百度小程序遇到的问题
  • 码农张的Bug人生 - 初来乍到
  • 设计模式(12)迭代器模式(讲解+应用)
  • 使用Swoole加速Laravel(正式环境中)
  • mysql面试题分组并合并列
  • 交换综合实验一
  • 京东物流联手山西图灵打造智能供应链,让阅读更有趣 ...
  • ​​​​​​​Installing ROS on the Raspberry Pi
  • ​LeetCode解法汇总518. 零钱兑换 II
  • $分析了六十多年间100万字的政府工作报告,我看到了这样的变迁
  • (1)STL算法之遍历容器
  • (java版)排序算法----【冒泡,选择,插入,希尔,快速排序,归并排序,基数排序】超详细~~
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (pytorch进阶之路)扩散概率模型
  • (八)Flask之app.route装饰器函数的参数
  • (八十八)VFL语言初步 - 实现布局
  • (动手学习深度学习)第13章 计算机视觉---微调
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (算法二)滑动窗口
  • (原創) 如何讓IE7按第二次Ctrl + Tab時,回到原來的索引標籤? (Web) (IE) (OS) (Windows)...
  • (转载)跟我一起学习VIM - The Life Changing Editor
  • .bat文件调用java类的main方法
  • .h头文件 .lib动态链接库文件 .dll 动态链接库
  • .NET / MSBuild 扩展编译时什么时候用 BeforeTargets / AfterTargets 什么时候用 DependsOnTargets?
  • .net下的富文本编辑器FCKeditor的配置方法
  • @RequestParam @RequestBody @PathVariable 等参数绑定注解详解