分享

实现单点登录(附全码)_AX - AXzhz - 博客园

 xnet 2007-01-17

实现单点登录(附全码)_AX

①概念:
单点登录就是同一时刻某一用户只能在一个地点登录系统.
②实现
通过Cache来保证用户只能登录一次.因为Cache是Application level的.
不过猜想当用户同时在线量很大时会出现问题,10万的用户Cache可不是说着玩的,不过一般除了网游好像很难达到这个数量级.
③本文源自【孟宪会之精彩世界】,略做修改,特此感谢!

附:源码
前台:

 1<%@ Page language="c#" Codebehind="SingleLogin.aspx.cs" AutoEventWireup="false"
 2    Inherits="eMeng.Exam.SingleLogin" 
%>
 3<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
 4<HTML>
 5    <HEAD>
 6        <title>单点登录测试</title>
 7        <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 8        <meta http-equiv="Author" content="孟子E章">
 9        <meta http-equiv="WebSite" content="http://dotnet.">
10        <style>H3 {
11    FONT: 17px 宋体
12}

13INPUT {
14    FONT: 12px 宋体
15}

16SPAN {
17    FONT: 12px 宋体
18}

19{
20    FONT: 12px 宋体
21}

22H4 {
23    FONT: 12px 宋体
24}

25
</style>
26    </HEAD>
27    <body ms_positioning="GridLayout">
28        <form id="Form1" method="post" runat="server">
29            <div align="center">
30                <h3>单点登录测试</h3>
31                <p>用户名称:<asp:TextBox id="UserName" runat="server"></asp:TextBox></p>
32                <p>用户密码:<asp:TextBox id="PassWord" runat="server" TextMode="Password"></asp:TextBox></p>
33                <p><asp:Button id="Login" runat="server" Text=" 登  录 "></asp:Button></p>
34                <p><asp:Label id="Msg" runat="server"></asp:Label></p>
35            </div>
36        </form>
37    </body>
38</HTML>
39

后台:

  1using System;
  2using System.Collections;
  3using System.ComponentModel;
  4using System.Data;
  5using System.Drawing;
  6using System.Web;
  7using System.Web.SessionState;
  8using System.Web.UI;
  9using System.Web.UI.WebControls;
 10using System.Web.UI.HtmlControls;
 11
 12namespace eMeng.Exam
 13{
 14    /// <summary>
 15    /// SingleLogin 的摘要说明。
 16    /// 实现单点登录
 17    /// </summary>

 18    public class SingleLogin : System.Web.UI.Page
 19    {
 20        protected System.Web.UI.WebControls.TextBox UserName;
 21        protected System.Web.UI.WebControls.TextBox PassWord;
 22        protected System.Web.UI.WebControls.Label Msg;
 23        protected System.Web.UI.WebControls.Button Login;
 24
 25        private void Page_Load(object sender, System.EventArgs e)
 26        {
 27            //字符串倒置
 28            string s="hello_XA";
 29            string ss="";
 30            for(int i=s.Length-1;i>=0;i--)
 31            {
 32                ss+=s[i];
 33            }

 34            Response.Write(ss);
 35            Response.Write("<br>"+DateTime.MaxValue+"||"+System.Web.HttpContext.Current.Session.Timeout);
 36            // 实际例子可访问:
 37            // http://dotnet./Exam/SingleLogin.aspx
 38        }

 39
 40        Web 窗体设计器生成的代码
 58
 59        private void Login_Click(object sender, System.EventArgs e)
 60        {
 61//            //Session不能实现单点登录
 62//            string key=UserName.Text + "_" + PassWord.Text;
 63//            string k=Convert.ToString(Session["user"]);
 64//            if(k==""||k==null)
 65//            {
 66//                Session["user"]=key;
 67//                Response.Write("首次登录!");
 68//            }
 69//            else
 70//            {
 71//                Response.Write("已经登录!");
 72//            }
 73
 74
 75            // 作为唯一标识的Key,应该是唯一的,这可根据需要自己设定规则。
 76            // 做为测试,这里用用户名和密码的组合来做标识;也不进行其它的错误检查。
 77
 78            // 生成Key
 79            string sKey = UserName.Text + "_" + PassWord.Text;
 80            // 得到Cache中的给定Key的值
 81            string sUser = Convert.ToString(Cache[sKey]);
 82            // 检查是否存在
 83            if (sUser == null || sUser == String.Empty)
 84            {
 85                // Cache中没有该Key的项目,表名用户没有登录,或者已经登录超时
 86                // 注意下面使用的TimeSpan构造函数重载版本的方法,是进行是否登录判断的关键。???好象不是哦!
 87                //SessTimeOut是设定的一个TimeSpan,该处设定为Session登录超时的时间,我本机为20分钟,
 88                //见Page_Load的最后一行输出
 89                TimeSpan SessTimeOut = new TimeSpan(0,0,System.Web.HttpContext.Current.Session.Timeout,0,0);
 90                HttpContext.Current.Cache.Insert(sKey,sKey,null,DateTime.MaxValue,SessTimeOut,
 91                    System.Web.Caching.CacheItemPriority.NotRemovable,null);
 92                // 首次登录,您可以做您想做的工作了。
 93                Msg.Text="<h4 style=‘color:red‘>嗨!欢迎您访问<a href=‘http://dotnet./‘>【孟宪会之精彩世界】";
 94                Msg.Text+="</a>,祝您浏览愉快!:)</h4>";
 95                Msg.Text+="<h4 style=‘color:red‘>AX也祝您愉快!</h4>";
 96            }

 97            else
 98            {
 99                // 在 Cache 中发现该用户的记录,表名已经登录过,禁止再次登录
100                Msg.Text="<h4 style=‘color:red‘>抱歉,您好像已经登录了呀:-(</h4>";
101            }

102        }

103    }

104}

105

posted on 2007-01-11 11:03 斧头帮少帮主 阅读(161) 评论(5)  编辑 收藏 引用 网摘 所属分类: 经验总结

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多