实现单点登录(附全码)_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.aspx.cc">
10![]()
<style>
H3 {
}{
11
FONT: 17px 宋体
12
}
13![]()
INPUT {
}{
14
FONT: 12px 宋体
15
}
16![]()
SPAN {
}{
17
FONT: 12px 宋体
18
}
19![]()
P {
}{
20
FONT: 12px 宋体
21
}
22![]()
H4 {
}{
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
后台:
![]()
![]()
1
using System;
2
using System.Collections;
3
using System.ComponentModel;
4
using System.Data;
5
using System.Drawing;
6
using System.Web;
7
using System.Web.SessionState;
8
using System.Web.UI;
9
using System.Web.UI.WebControls;
10
using System.Web.UI.HtmlControls;
11![]()
12
namespace 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.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![]()
/**//// <summary>
48
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
49
/// 此方法的内容。
50
/// </summary>
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="<h4 style='color:red'>嗨!欢迎您访问<a href='http://dotnet.aspx.cc/'>【孟宪会之精彩世界】";
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
单点登录就是同一时刻某一用户只能在一个地点登录系统.
②实现
通过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.aspx.cc">10

<style>
H3 {
}{11
FONT: 17px 宋体12
}13

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

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

P {
}{20
FONT: 12px 宋体21
}22

H4 {
}{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

后台:
1
using System;2
using System.Collections;3
using System.ComponentModel;4
using System.Data;5
using System.Drawing;6
using System.Web;7
using System.Web.SessionState;8
using System.Web.UI;9
using System.Web.UI.WebControls;10
using System.Web.UI.HtmlControls;11

12
namespace eMeng.Exam13


{14

/**//// <summary>15
/// SingleLogin 的摘要说明。16
/// 实现单点登录17
/// </summary>18
public class SingleLogin : System.Web.UI.Page19

{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.aspx.cc/Exam/SingleLogin.aspx38
}39

40

Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码41
override protected void OnInit(EventArgs e)42

{43
InitializeComponent();44
base.OnInit(e);45
}46

47

/**//// <summary>48
/// 设计器支持所需的方法 - 不要使用代码编辑器修改49
/// 此方法的内容。50
/// </summary>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
#endregion58

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
// else70
// {71
// Response.Write("已经登录!");72
// }73

74

75
// 作为唯一标识的Key,应该是唯一的,这可根据需要自己设定规则。76
// 做为测试,这里用用户名和密码的组合来做标识;也不进行其它的错误检查。77

78
// 生成Key79
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.aspx.cc/'>【孟宪会之精彩世界】";94
Msg.Text+="</a>,祝您浏览愉快!:)</h4>";95
Msg.Text+="<h4 style='color:red'>AX也祝您愉快!</h4>";96
}97
else98

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

少帮主的斧头好久不饮血了!
浙公网安备 33010602011771号