php ajax操作成功刷新页面,PHP ajax制作局部刷新用户登录和退出功能_PHP实例教程...

php用户登录做很简单,但是要做到符合用户体验有点小不简单,比如登录局部无刷新验证就利用到ajax,这篇文章是利用ajax+jquery+php实现局部刷新的用户登录和退出!教程比较详细,需要这个功能的朋友请认真看.

演示登录前界面(用户名和密码demo)

a4c26d1e5885305701be709a3d33442f.png

成功登录后界面

a4c26d1e5885305701be709a3d33442f.png

创建数据库表

本例我们使用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 = "

id='result'>

"+json.user+",恭喜您登录成功!

您这是第"+json.login_counts+"次登录本站。

上次登录本站的时间是:"+json.login_time+"

id='logout'>【退出】

";

$("#login").append(div);

}else{

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值