一个单点登录的问题
需求,有若干网站,在这若干的网站上面我拥有相同的用户名和密码如何制作一个通用登录程序,使用一次用户名和密码一次性登录这些网站。
注,这些网站中,有用flash做的登录界面。
是否可行 --------------------编程问答-------------------- 做一个公共的服务端,比如webservice,
每个系统登录时都向这个服务端发送请求,服务端保存登录状态,系统标识以及超时等信息,系统登录时先查阅服务端,在进行系统内部逻辑。
单点登录不好做,做好了极复杂,其中有bs系统的局限性、异构系统通讯、用户信息维护和同步、服务协议的制定、令牌环等等复杂操作。
。。。。。。 --------------------编程问答-------------------- 学习~~~ --------------------编程问答-------------------- 看下面这段代码 绝对对你有用 我已经做过了
int i = this.checkLogin(txtName.Text,txtPwd.Text);
if (i> 0)
{
// 作为唯一标识的str_Key,应该是唯一的,这可根据需要自己设定规则。
// 做为测试,这里用用户名和密码的组合来做标识;也不进行其它的错误检查。
// 生成str_Key
string str_Key = txtName.Text + "_" + txtPwd.Text;
// 得到Cache中的给定str_Key的值
string str_User = Convert.ToString(Cache[str_Key]);
// Cache中没有该str_Key的项目,表名用户没有登录,或者已经登录超时
if (str_User == String.Empty)
{
// TimeSpan构造函数,用来重载版本的方法,进行判断是否登录。
TimeSpan SessTimeOut = new TimeSpan(0,0,HttpContext.Current.Session.Timeout,0,0);
HttpContext.Current.Cache.Insert(str_Key,str_Key,null,DateTime.MaxValue,SessTimeOut, CacheItemPriority.NotRemovable,null);
Session["User"] = str_Key;
// 首次登录成功
Response.Write("<h2 style='color:red'>你好,登录成功!");
}
else
{
// 在 Cache 中存在该用户的记录,表名已经登录过,禁止再次登录
Response.Write("<h2 style='color:red'>抱歉,您好像已经登录了!");
return;
}
}
else
{
Response.Write("用户名称或密码错误!!!");
} --------------------编程问答-------------------- 用Session对象保存登录数据就可以实现一次登录 --------------------编程问答-------------------- cookie保存登录信息 --------------------编程问答-------------------- 不懂,帮顶下 --------------------编程问答-------------------- 服务器中或者数据库中存储一个令牌记录该用户是否登录以及登录信息,每个程序每次都是判断是否已登录都是判断这个令牌,而不是对自己的表进行判断 --------------------编程问答-------------------- 4天前的帖子了 --------------------编程问答-------------------- 期待高手回答 学习下呢 --------------------编程问答-------------------- mark 学习
补充:.NET技术 , ASP.NET