asp.net如何实现单点登录SSO
这篇文章主要介绍了asp.net如何实现单点登录SSO,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
单点登录(Single Sign On , 简称 SSO )是目前比较流行的服务于企业业务整合的解决方案之一, SSO 使得在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统
CAS(Central Authentication Service)是一款不错的针对 Web 应用的单点登录框架(耶鲁大学开发)主要用于Java Php 有兴趣大家可以研究下..
下面是一个简单实现单点登录的方法:
public void SingleUserLogin(string userName){ //定义键值 string key=userName; string value=Convert.ToString(Cache[key]); if(value==null||value==string.Empty){ //定义Cache过期时间 TimeSpan span=new TimeSpan(0,0,HttpContext.Current.Session.Timeout,0,0); //第一次登陆的时候插入一个用户相关的cache值, HttpContext.Current.Cache.Insert(key,key,null,DateTime.MaxValue,span,System.Web.Caching.CacheItemPriority.NotRemovable,null); Session["userName"]=userName; Response.Redirect("Main.aspx"); } else if(Cache[key].ToString()==key){ //重复登陆 Response.Write("<mce:script type="text/javascript"><!-- alert('您的账号已经登陆!');window.location='login.aspx'; // --></mce:script>"); } else{ //取消当前的session会话 Session.Abandon(); } }
在Web Config 配置 窗体模式
<authentication mode="Forms">//mode值是Forms为定义成窗体验证 <forms loginUrl="Mananger/Login.aspx" name=".ASPXAUTH">//用户未登陆就先访问Mananger/Login.aspx页面 </forms> </authentication> <authorization> <deny users="?"/> </authorization>
感谢你能够认真阅读完这篇文章,希望小编分享的“asp.net如何实现单点登录SSO”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注行业资讯频道,更多相关知识等着你来学习!