最近学习了如何实现无刷新登录,大体的效果如下(界面比较丑,请自行忽略....):
点击登录按钮时弹出登录窗口,输入正确的用户名密码后点击登录则登录窗口关闭,状态改为当前用户名.
第一步:
首先弹出窗口使用的是jquery-ui中的控件,第一步要学会如何使用.
打开解压后的jquery-UI下的development-bundle->demos,找到index.html,选择dialog下的model dialog,右键查看源码,观察如何使用该控件,找到一句关键代码:$("#dialog-modal").dialog({height: 140,modal: true});这是用于显示的,打开model message中的源码,找到关闭的关键代码:$(this).dialog('close');有了这两句代码,可以控制窗口的显示与关闭,可以进行下一步了.使用时需复制jquery-ui开发包的css文件夹,js文件夹到项目中.
第二步:
在这里先贴出处理AJAX请求的一般处理程序的代码,虽然正真写的时候都是用到再写,但这里不可能一步一步详细列出,为了便于理解,先将一般处理程序代码贴出来:
1.IsLogin.ashx,用于判断用户是否登录,登录则返回用户名.这里注意,在一般处理程序中要使用session,必须引入using System.Web.SessionState且要实现IRequiresSessionState接口
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.SessionState;
namespace AJAX无刷新登录.AJAX
{
/// <summary>
/// IsLogin 的摘要说明
/// </summary>
public class IsLogin : IHttpHandler,IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Session["userName"] != null)
{
string userName = context.Session["userName"].ToString();
context.Response.Write("yes|"+userName);
}
else
{
context.Response.Write("no");
}
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
2.CheckLogin.ashx,用于检测用户输入用户名密码是否匹配,正确则返回yes,错误返回no,这里为了简便没有连接数据库.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.SessionState;
namespace AJAX无刷新登录.AJAX
{
/// <summary>
/// CheckLogin 的摘要说明
/// </summary>
public class CheckLogin : IHttpHandler,IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string userName = context.Request["userName"];
string password=context.Request["password"];
if (userName=="admin"&&password=="admin")
{
context.Session["userName"] = "admin";
context.Response.Write("ok");
}
else
{
context.Response.Write("no");
}
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
3.LoginOut.ashx,用于控制用户登出,设置session为空.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.SessionState;
namespace AJAX无刷新登录.AJAX
{
/// <summary>
/// LoginOut 的摘要说明
/// </summary>
public class LoginOut : IHttpHandler,IRequiresSessionState
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
context.Session["userName"] = null;
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
一般处理程序就结束了,下面贴出主界面的代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Login.aspx.cs" Inherits="AJAX无刷新登录.Login" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<link href="JQueryUI/css/ui-lightness/jquery-ui-1.8.2.custom.css" rel="stylesheet" />
<script src="JQueryUI/jquery-1.4.2.min.js"></script>
<script src="JQueryUI/jquery-ui-1.8.2.custom.min.js"></script>
<script type="text/javascript">
//判断是否登录,登录则显示登录名,隐藏登录按钮,显示注销按钮
//否则相反
var isLogin = function () {
$.post("/AJAX/IsLogin.ashx", function (data) {
var strs = data.split('|');
if (strs[0] == "yes") {
$("#divShowLogin").hide();
$("#divShowLoginOut").show();
$("#spanName").text(strs[1]);
} else {
$("#divShowLogin").show();
$("#divShowLoginOut").hide();
$("#spanState").text("未登录");
}
});
}
$(function () {
isLogin();
//点击登录弹出登录窗口
$("#btnShowLogin").click(function () {
//模态窗口,设定长宽
$("#divLogin").dialog({
height: 160,
width: 300,
modal: true
});
});
//点击取消则关闭弹出框
$("#btnCancel").click(function () {
$("#divLogin").dialog('close');
});
//点击登录发送post请求在一般处理程序CheckLogin.ashx中验证登录,
//根据回调函数结果判断是否登录成功
$("#btnLogin").click(function () {
var userName = $("#txtUserName").val();
var password = $("#txtPwd").val();
$.post("/AJAX/CheckLogin.ashx", { "userName": userName, "password": password }, function (data) {
if (data == "ok") {
$("#divLogin").dialog('close');
isLogin();
}
else {
alert("用户名或密码错误");
}
});
});
//点击注销发送post请求,在一般处理程序中设置session为null,并调用isLogin函数刷新状态
$("#btnExit").click(function () {
$.post("/AJAX/LoginOut.ashx", function () {
isLogin();
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="divShowLogin" style="display: none">
<span id="spanState"></span>
<input type="button" value="登录" id="btnShowLogin" />
</div>
<div id="divShowLoginOut" style="display: none">
<span id="spanName"></span>
<input type="button" value="注销" id="btnExit" />
</div>
<div id="divLogin" title="登录窗口" style="display: none">
<table style="text-align: left" id="tbLoin">
<tr>
<td>用户名:</td>
<td>
<input type="text" id="txtUserName" /></td>
</tr>
<tr>
<td>密码:</td>
<td>
<input type="password" id="txtPwd" /></td>
</tr>
<tr>
<td>
<input type="button" value="登录" id="btnLogin" /></td>
<td style="text-align: left">
<input type="button" value="取消" id="btnCancel" /></td>
</tr>
</table>
</div>
</form>
</body>
</html>
以上所述是小编给大家介绍的AJAX如何实现无刷新登录功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# ajax实现无刷新
# ajax无刷新登录
# jQuery基于ajax实现页面加载后检查用户登录状态的方法
# jQuery Ajax 实现在html页面实时显示用户登录状态
# Ajax实现带有验证码的局部刷新登录界面
# jQuery+Ajax用户登录功能的实现
# 一款经典的ajax登录页面 后台asp.net
# jquery ajax 登录验证实现代码
# 基于jquery ajax 用户无刷新登录方法详解
# PHP+jQuery+Ajax实现用户登录与退出
# asp.net jQuery Ajax用户登录功能的实现
# ajax实现登录功能
# 弹出
# 在一
# 贴出
# 如何使用
# 小编
# 如何实现
# 的是
# 都是
# 判断是否
# 这是
# 在这里
# 不可能
# 一句
# 在此
# 右键
# 给大家
# 两句
# 输入用户名
# 先将
# 第二步
相关文章:
建站主机如何选?高性价比方案全解析
动图在线制作网站有哪些,滑动动图图集怎么做?
宝塔建站无法访问?如何排查配置与端口问题?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
为什么Go需要go mod文件_Go go mod文件作用说明
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
建站之星微信建站一键生成小程序+多端营销系统
建站主机系统SEO优化与智能配置核心关键词操作指南
php json中文编码为null的解决办法
如何快速搭建安全的FTP站点?
如何正确下载安装西数主机建站助手?
建站主机数据库如何配置才能提升网站性能?
如何用VPS主机快速搭建个人网站?
如何选购建站域名与空间?自助平台全解析
建站之星×万网:智能建站系统+自助建站平台一键生成
建站之星下载版如何获取与安装?
如何基于云服务器快速搭建网站及云盘系统?
无锡营销型网站制作公司,无锡网选车牌流程?
交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?
网站制作公司,橙子建站是合法的吗?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
建站之星安装提示数据库无法连接如何解决?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
零服务器AI建站解决方案:快速部署与云端平台低成本实践
建站10G流量真的够用吗?如何应对访问高峰?
教学网站制作软件,学习*后期制作的网站有哪些?
如何选择适配移动端的WAP自助建站平台?
建站之星各版本价格是多少?
安徽网站建设与外贸建站服务专业定制方案
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
高防服务器:AI智能防御DDoS攻击与数据安全保障
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何通过虚拟主机空间快速建站?
如何在Windows 2008云服务器安全搭建网站?
音响网站制作视频教程,隆霸音响官方网站?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
建站主机选购指南:核心配置优化与品牌推荐方案
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
小建面朝正北,A点实际方位是否存在偏差?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
淘宝制作网站有哪些,淘宝网官网主页?
建站之星代理如何优化在线客服效率?
如何快速查询域名建站关键信息?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
网站制作企业,网站的banner和导航栏是指什么?
*请认真填写需求信息,我们会在24小时内与您取得联系。