PHP 附录 : 用户注册与登录完整代码
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
- <title>用户登录</title>
- <style type="text/css">
- html{font-size:12px;}
- fieldset{width:520px; margin: 0 auto;}
- legend{font-weight:bold; font-size:14px;}
- label{float:left; width:70px; margin-left:10px;}
- .left{margin-left:80px;}
- .input{width:150px;}
- span{color: #666666;}
- </style>
- <script language=JavaScript>
- <!--
- function InputCheck(LoginForm)
- {
- if (LoginForm.username.value == "")
- {
- alert("请输入用户名!");
- LoginForm.username.focus();
- return (false);
- }
- if (LoginForm.password.value == "")
- {
- alert("请输入密码!");
- LoginForm.password.focus();
- return (false);
- }
- }
- //-->
- </script>
- </head>
- <body>
- <div>
- <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>
- </div>
- </body>
- </html>
conn.php
- <?php
- /*****************************
- *数据库连接
- *****************************/
- $conn = @mysql_connect("localhost","root","root123");
- if (!$conn){
- die("连接数据库失败:" . mysql_error());
- }
- mysql_select_db("test", $conn);
- //字符转换,读库
- mysql_query("set character set 'gbk'");
- //写库
- mysql_query("set names 'gbk'");
- ?>
reg.php
- <?php
- if(!isset($_POST['submit'])){
- exit('非法访问!');
- }
- $username = $_POST['username'];
- $password = $_POST['password'];
- $email = $_POST['email'];
- //注册信息判断
- if(!preg_match('/^[\w\x80-\xff]{3,15}$/', $username)){
- exit('错误:用户名不符合规定。<a href="javascript:history.back(-1);">返回</a>');
- }
- if(strlen($password) < 6){
- exit('错误:密码长度不符合规定。<a href="javascript:history.back(-1);">返回</a>');
- }
- if(!preg_match('/^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$/', $email)){
- exit('错误:电子邮箱格式错误。<a href="javascript:history.back(-1);">返回</a>');
- }
- //包含数据库连接文件
- include('conn.php');
- //检测用户名是否已经存在
- $check_query = mysql_query("select uid from user where username='$username' limit 1");
- if(mysql_fetch_array($check_query)){
- echo '错误:用户名 ',$username,' 已存在。<a href="javascript:history.back(-1);">返回</a>';
- exit;
- }
- //写入数据
- $password = MD5($password);
- $regdate = time();
- $sql = "INSERT INTO user(username,password,email,regdate)VALUES('$username','$password','$email',
- $regdate)";
- if(mysql_query($sql,$conn)){
- exit('用户注册成功!点击此处 <a href="login.html">登录</a>');
- } else {
- echo '抱歉!添加数据失败:',mysql_error(),'<br />';
- echo '点击此处 <a href="javascript:history.back(-1);">返回</a> 重试';
- }
- ?>
login.html
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=gbk" />
- <title>用户登录</title>
- <style type="text/css">
- html{font-size:12px;}
- fieldset{width:300px; margin: 0 auto;}
- legend{font-weight:bold; font-size:14px;}
- .label{float:left; width:70px; margin-left:10px;}
- .left{margin-left:80px;}
- .input{width:150px;}
- span{color: #666666;}
- </style>
- <script language=JavaScript>
- <!--
- function InputCheck(LoginForm)
- {
- if (LoginForm.username.value == "")
- {
- alert("请输入用户名!");
- LoginForm.username.focus();
- return (false);
- }
- if (LoginForm.password.value == "")
- {
- alert("请输入密码!");
- LoginForm.password.focus();
- return (false);
- }
- }
- //-->
- </script>
- </head>
- <body>
- <div>
- <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>
- </div>
- </body>
- </html>
login.php
- <?php
- session_start();
- //注销登录
- if($_GET['action'] == "logout"){
- unset($_SESSION['userid']);
- unset($_SESSION['username']);
- echo '注销登录成功!点击此处 <a href="login.html">登录</a>';
- exit;
- }
- //登录
- 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> 重试');
- }
- ?>
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 />';
- ?>
社交
PHP 附录 : 用户注册与登录完整代码的更多相关文章
- PHP用户注册与登录完整代码【4】
login.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:// ...
- 单点登录SSO:可一键运行的完整代码
单点登录方案不同于一个普通站点,它的部署比较繁琐:涉及到好几个站点,要改host.安装证书.配置HTTPS. 看到的不少这方面示例都是基于HTTP的,不认同这种简化: 1. 它体现不出混合HTTP/H ...
- 吴裕雄 python 人工智能——智能医疗系统后台用户注册、登录和初诊简约版代码展示
#用户注册.登录模块 #数据库脚本 CREATE TABLE usertable( userid number(8) primary key not null , username varchar(5 ...
- Django学习笔记(16)——扩展Django自带User模型,实现用户注册与登录
一,项目题目:扩展Django自带User模型,实现用户注册与登录 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册,登录,用户认证,注销,修改密码等功能. ...
- java mail实现Email的发送,完整代码
java mail实现Email的发送,完整代码 1.对应用程序配置邮件会话 首先, 导入jar <dependencies> <dependency> <groupId ...
- jQuery弹出窗口完整代码
jQuery弹出窗口完整代码 效果体验:http://keleyi.com/keleyi/phtml/jqtexiao/1.htm 1 <!DOCTYPE html PUBLIC "- ...
- day19面向对象 , 用户注册和登录
#!/usr/bin/env python# -*- coding:utf-8 -*- # 1.简述编写类和执行类中方法的流程."""编写:class Person: d ...
- Django学习笔记(9)—— 开发用户注册与登录系统
一,项目题目: 开发用户注册与登录系统 该项目主要练习使用Django开发一个用户注册与登录的系统,通过这个项目然后巩固自己这段时间所学习的Django知识. 二,项目需求: 开发一个简单的用户登录与 ...
- Android基于XMPP Smack Openfire下学习开发IM(一)实现用户注册、登录、修改密码和注销等
http://blog.csdn.net/h7870181/article/details/8653865 以前学习过用Scoket 建立聊天,简单的建立聊天是没问题的,但如果要实现多人复杂的聊天,后 ...
随机推荐
- !important面试汇总啊
https://www.jianshu.com/p/feab89b88d6b https://juejin.im/post/5c64d15d6fb9a049d37f9c20#heading-57
- 洛谷 P1241 括号序列(栈)
嗯... 题目链接:https://www.luogu.org/problem/P1241 首先这道题是栈的入门题的加强版, 不仅要你判断这个括号序列是否合法,还要你将这个序列补充完整... 一开始是 ...
- linux文件或目录属性
wc(word count)命令的功能:统计指定文件的字节数.字数.行数.,并将统计结果显示输出 命令参数: -c 只显示字节数 -l 只显示行数 -w 只显示字数 od命令:查看二进制文件信息 ...
- Redis 作为windows服务运行
如果服务器上以控制台方式运行Redis服务,非常不方便,不小心会被人点击关闭,到时服务就挂了. 使用 命令的方式,将配置加载到windows服务,执行后无法启动,提示配置问题. redis-serve ...
- leetCode练题——21. Merge Two Sorted Lists(照搬大神做法)
1.题目 21. Merge Two Sorted Lists Merge two sorted linked lists and return it as a new list. The new l ...
- python合并大量ts文件成mp4格式(ps:上限是450,亲测)
import os #exec_str = r'copy /b ts/c9645620628078.ts+ts/c9645620628079.ts ts/1.ts' #os.system(exec_s ...
- 服务器settings
1,如果增加了一个新的APP, 那么需要在服务器上 vim settings文件进行修改, 修改方法 i, :wq 2,正式服务器需要一样的操作
- lua叠代器
注意:叠待值遇到nil就退出 叠代器,是符合for遍历框架,需要满足条件 1-叠代函数,常量,控制变量 2-叠代函数可以接受二个参数,当然也可以忽略处理(利用闭包封装参数作为控制变量和状态变量) 无状 ...
- 二十 Struts2的标签库,数据回显(基于值栈)
通用标签库 判断标签:<s:if>.<s:elseif>.<s:else> 循环标签:<s:iterator> 其他常用标签: <s:proper ...
- Spring boot 中发送邮件
参考:https://blog.csdn.net/qq_39241443/article/details/81293939 添加依赖: <dependency> <groupId&g ...