哪里能复制biangbiang:实现单点登录(附全码)_AX - AXzhz - 博客园

来源:百度文库 编辑:偶看新闻 时间:2024/05/06 01:04:26

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

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

附:源码
前台:

 1<%@ Page language="c#" Codebehind="SingleLogin.aspx.cs" AutoEventWireup="false"
 2    Inherits="eMeng.Exam.SingleLogin" %>
 3
 4
 5    
 6        单点登录测试
 7        
 8        
 9        
10        
26    
27    
28        
29            
30                

单点登录测试


31                

用户名称:


32                

用户密码:


33                


34                


35            

36        
37    
38
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    /**//// 
 15    /// SingleLogin 的摘要说明。
 16    /// 实现单点登录
 17    /// 

 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("
"+DateTime.MaxValue+"||"+System.Web.HttpContext.Current.Session.Timeout);
 36            // 实际例子可访问:
 37            // http://dotnet.aspx.cc/Exam/SingleLogin.aspx
 38        }
 39
 40        Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码
 41        override protected void OnInit(EventArgs e)
 42        {
 43            InitializeComponent();
 44            base.OnInit(e);
 45        }
 46
 47        /**//// 
 48        /// 设计器支持所需的方法 - 不要使用代码编辑器修改
 49        /// 此方法的内容。
 50        /// 

 51        private void InitializeComponent()
 52        {
 53            this.Login.Click += new System.EventHandler(this.Login_Click);
 54            this.Load += new System.EventHandler(this.Page_Load);
 55
 56        }
 57        #endregion
 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="嗨!欢迎您访问【孟宪会之精彩世界】";
 94                Msg.Text+=",祝您浏览愉快!:)";
 95                Msg.Text+="AX也祝您愉快!";
 96            }
 97            else
 98            {
 99                // 在 Cache 中发现该用户的记录,表名已经登录过,禁止再次登录
100                Msg.Text="抱歉,您好像已经登录了呀:-(";
101            }
102        }
103    }
104}
105

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