php用户登录做很简单,但是要做到符合用户体验有点小不简单,比如登录局部无刷新验证就利用到ajax,这篇文章是利用ajax+jquery+php实现局部刷新的用户登录和退出!教程比较详细,需要这个功能的朋友请认真看.
演示登录前界面(用户名和密码demo)
成功登录后界面
创建数据库表
本例我们使用Mysql数据库,创建一张user表,表结构如下:
CREATE TABLE `user` (
`id` int(11) NOT NULL auto_increment,
`username` varchar(30) NOT NULL COMMENT
'用户名',
`password` varchar(32) NOT NULL COMMENT
'密码',
`login_time` int(10) default NULL COMMENT
'登录时间',
`login_ip` varchar(32) default NULL COMMENT
'登录IP',
`login_counts` int(10) NOT NULL default '0'
COMMENT '登录次数',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
然后往user表中插入一条用户信息数据:
INSERT INTO `user` (`id`, `username`, `password`, `login_time`,
`login_ip`, `login_counts`)
VALUES(1, 'demo',
'fe01ce2a7fbac8fafaed7c982a04e229', '', '', 0);
index.php
用户在输入用户名和密码后,提示用户登录成功,并显示相关登录信息,如果点击“退出”,则退出到用户登录界面。
进入index.php,如果用户已登录则显示登录信息,如果未登录则显示登录框要求用户登录。
用户登录
if(isset($_SESSION['user'])){
?>
<?php
echo
$_SESSION['user'];?>
,恭喜您登录成功!您这是第<?php
echo
$_SESSION['login_counts'];?>
次登录本站。上次登陆本站的时间是:<?php
echo date('Y-m-d
H:i:s',$_SESSION['login_time']);?>
href='#'
id='logout'>【退出】
用户名:
id="user" />
密
码:
type="password" class="input" name="pass" id="pass"
/>
/>
注意在index.php文件头应该加上语句:session_start;
同时在head部分引入jquery库,以及包含global.js,您还可以为登录框写个漂亮的CSS样式,当然本例已经略微写了个简单的样式,请查看源码。
global.js文件包括了将要实现的jquery代码。首先要做的就是让输入框获得焦点,像百度和google那样一打开,鼠标光标就在输入框内。使用代码如下:
$(function(){
$("#user").focus();
});
接着要做的就是,当输入框获得和失去焦点时,分别呈现不同的样式,比如本例中使用不同的边框颜色,代码如下:
$("input:text,textarea,input:password").focus(function() {
$(this).addClass("cur_select");
});
$("input:text,textarea,input:password").blur(function() {
$(this).removeClass("cur_select");
});
用户登录:用户点击登录按钮后,首先要验证用户的输入不能为空,然后向后台login.php发送一个Ajax请求。当后台验证登录成功后,返回登录用户信息:如用户登录次数和上次登录时间等;如果登录失败,则返回登录失败信息。
$(".btn").live('click',function(){
var user =
$("#user").val();
var pass =
$("#pass").val();
if(user==""){
$('
/>').html("用户名不能为空!").appendTo('.sub').fadeOut(2000);
$("#user").focus();
return false;
}
if(pass==""){
$('
/>').html("密码不能为空!").appendTo('.sub').fadeOut(2000);
$("#pass").focus();
return false;
}
$.ajax({
type: "POST",
url: "login.php?action=login",
dataType: "json",
data: {"user":user,"pass":pass},
beforeSend: function(){
$('
/>').addClass("loading").html("正在登录...").css("color","#999")
.appendTo('.sub');
},
success: function(json){
if(json.success==1){
$("#login_form").remove();
var div = "
";$("#login").append(div);
}else{