全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

AJAX如何实现无刷新登录功能

最近学习了如何实现无刷新登录,大体的效果如下(界面比较丑,请自行忽略....):

点击登录按钮时弹出登录窗口,输入正确的用户名密码后点击登录则登录窗口关闭,状态改为当前用户名.

第一步:

首先弹出窗口使用的是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小时内与您取得联系。