当前位置: 移动技术网 > IT编程>开发语言>.net > asp.net简单实现单点登录(SSO)的方法

asp.net简单实现单点登录(SSO)的方法

2017年12月12日  | 移动技术网IT编程  | 我要评论

同安影视城攻略,墙面处理,石狮维多利亚

本文实例讲述了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程序设计有所帮助。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网