我们先来看个最简单的实例
以下附简单的login.htm内容
代码如下 | 复制代码 |
<html> <body> <form name="login" action="login.php" method=post> 用户名<input type=text name="name"> <p>密码<input type=password name="password"> <p> <input name="log" type=submit value="登录"> </form> </body> </html> |
login.php内容如下:
代码如下 | 复制代码 |
<? error_reporting(0); $mysql_servername = "localhost"; //主机地址 $mysql_username = "root"; //数据库用户名 $mysql_password =""; //数据库密码 $mysql_database ="peng"; //数据库 mysql_connect($mysql_servername , $mysql_username , $mysql_password); mysql_select_db($mysql_database); $name=$_POST['name']; $passowrd=$_POST['password']; if ($name && $passowrd){ ?> |
下面还有一个我刚学php 是写的
这是一个登录页面的效果图,其它登陆别名与密码
代码如下 | 复制代码 |
<input name="myname" type="text" id="myname" style="border:solid 0px;" /> <input name="mypass" type="password" id="mypass" style="border:solid 0px;" /> |
php代码
代码如下 | 复制代码 |
<? session_start();//这个一定要申明喽,给个小提示:在session之前不能有任何输出哦,在php.5以下的版本会有问题. ?> |
上面的实例我都只保存信息到了session下面来看个同时应用session和cookie来保存用户登录信息
1、数据库连接设备页面:connectvars.php
代码如下 | 复制代码 |
<?php //数据库的地位 define(""DB_HOST"", ""127.0.0.1""); //用户名 define(""DB_USER"", ""root""); //口令 define(""DB_PASSWORD"", ""19900101""); //数据库名 define(""DB_NAME"",""test"") ; ?> |
2、登录页面:logIn.php
代码如下 | 复制代码 |
<?php //插入连接数据库的相干信息 require_once ""connectvars.php""; //开启一个会话 $error_msg = ""; if(!empty($user_username)&&!empty($user_password)){ <label for="username">Username:</label> <br/> <label for="password">Password:</label> </fieldset> |
3、登入页面:loged.php
代码如下 | 复制代码 |
<?php //应用会话内存储的变量值之前必须先开启会话 session_start(); //若是会话没有被设置,查看是否设置了cookie if(!isset($_SESSION[""user_id""])){ if(isset($_COOKIE[""user_id""])&&isset($_COOKIE[""username""])){ //用cookie给session赋值 $_SESSION[""user_id""]=$_COOKIE[""user_id""]; $_SESSION[""username""]=$_COOKIE[""username""]; } } //应用一个会话变量搜检登录状况 if(isset($_SESSION[""username""])){ echo ""You are Logged as "".$_SESSION[""username""].""<br/>""; echo ""<a href="logOut.php"> Log Out("".$_SESSION[""username""]."")</a>""; } /**在已登录页面中,可以哄骗用户的session如$_SESSION[""username""]、 * $_SESSION[""user_id""]对数据库进行查询,可以做很多多少很多多少工作*/ ?> |
4、刊出session与cookie页面:logOut.php(刊出后重定向到lonIn.php)
代码如下 | 复制代码 |
<?php /**同时刊出session和cookie的页面*/ //即使是刊出时,也必须起首开端会话才干接见会话变量 session_start(); //应用一个会话变量搜检登录状况 if(isset($_SESSION[""user_id""])){ //要清除会话变量,将$_SESSION超等全局变量设置为一个空数组 $_SESSION = array(); //若是存在一个会话cookie,经由过程将到期时候设置为之前1个小时从而将其删除 if(isset($_COOKIE[session_name()])){ setcookie(session_name(),"""",time()-3600); } //应用内置session_destroy()函数调用撤销会话 session_destroy(); } //同时将各个cookie的到期时候设为畴昔的某个时候,使它们由体系删除,时候以秒为单位 setcookie(""user_id"","""",time()-3600); setcookie(""username"","""",time()-3600); //location首部使浏览看重定向到另一个页面 $home_url = ""logIn.php""; header(""Location:"".$home_url); ?> |
用户注册登录涉及到用户信息与数据库的交互,因此要特别注意用户提交的信息不能为非法信息,本例中注册部分已经使用正则表达式做了限制,对登录部分只简单使用了 htmlspecialchars() 处理,实际应用时可更严格一些。
本教程只是简单演示用户注册与登录的过程,其代码仅供学习参考,不可直接用于项目生产。
本教程中对于用户登录成功后采用 session 来管理,也可以采用 cookie 来管理,尤其对于有时限要求的情况。
为了提高用户体验,用户注册部分可以结合 AJAX 来检测用户输入的信息而不必等点击提交后再检测。