.NET基于Redis缓存实现单点登录SSO的解决方案
一、基本概念
最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单点登录,现在就NET基于Redis缓存实现单点登录做一个简单的分享。
单点登录(Single Sign On),简称为 SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。
普通的登录是写入session,每次获取session看看是否有登录就可记录用户的登录状态。
同理多个站点用一个凭证,可以用分布式session,我们可以用redis实现分布式session,来实现一个简单的统一登录demo
我们在本地IIS建立三个站点
http://www.a.com 登录验证的站点
http://test1.a.com 站点1
http://test2.a.com 站点2
修改host文件C:\Windows\System32\drivers\etc下
127.0.0.1 www.a.com
127.0.0.1 test1.a.com
127.0.0.1 test2.a.com
127.0.0.1 sso.a.com
具体实现原理,当用户第一次访问应用系统test1的时候,因为还没有登录,会被引导到认证系统中进行登录;根据用户提供的登录信息,认证系统进行身份校验,如果通过校验,应该返回给用户一个认证的凭据--ticket;用户再访问别的应用的时候就会将这个ticket带上,作为自己认证的凭据,应用系统接受到请求之后会把ticket送到认证系统进行校验,检查ticket的合法性。如果通过校验,用户就可以在不用再次登录的情况下访问应用系统test2和应用系统test3了。
项目结构

二、代码实现
sso.a.com登录验证站点
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Index.aspx.cs" Inherits="ADJ.SSO.Web.Index" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>SSO demo</title>
</head>
<body>
<form id="form1" runat="server">
用 户:<input id="txtUserName" type="text" name="userName" /><br /><br />
密 码:<input type="password" name="passWord" /><br /><br />
<input type="submit" value="登录" /><br /><br /> <span style="color: red; margin-top: 20px;"><%=StrTip %></span>
</form> </body>
</html>
代码:
public partial class Index : System.Web.UI.Page
{
//定义属性
public string StrTip { get; set; }
public string UserName { get; set; }
public string PassWork { get; set; }
protected void Page_Load(object sender, EventArgs e)
{
if (Page.IsPostBack)
{
ValidateUser();
}
} //登录验证
private void ValidateUser()
{
var username = Request.Form["userName"];
if (username.Equals(""))
{
StrTip = "请输入用户名";
return;
}
var password = Request.Form["passWord"];
if (password.Equals(""))
{
StrTip = "请输入密码";
return;
} //模拟登录
if (username == "admin" && password == "admin")
{
UserInfo userInfo=new UserInfo()
{
UserName = "admin",PassWord = "admin",Info ="登录模拟"
}; //生成token
var token = Guid.NewGuid().ToString();
//写入token
Common.Common.AddCookie("token", token, Int32.Parse(ConfigurationManager.AppSettings["Timeout"]));
//写入凭证
RedisClient client = new RedisClient(ConfigurationManager.AppSettings["RedisServer"], );
client.Set<UserInfo>(token, userInfo); //跳转回分站
if (Request.QueryString["backurl"] != null)
{
Response.Redirect(Request.QueryString["backurl"].Decrypt(), false);
}
else
{
Response.Redirect(ConfigurationManager.AppSettings["DefaultUrl"], false);
}
}
else
{
StrTip = "用户名或密码有误!";
return;
} }
}
配置文件:
<appSettings>
<!--sso验证-->
<add key="UserAuthUrl" value="http://sso.a.com/"/>
<!--redis服务器-->
<add key="RedisServer" value="192.168.10.121"/>
<!--过期时间-->
<add key="Timeout" value="30"/>
<!--默认跳转站点-->
<add key="DefaultUrl" value="http://test1.a.com/"/>
</appSettings>
注销代码:
var tokenValue = Common.Common.GetCookie("token");
Common.Common.AddCookie("token",tokenValue,-);
HttpContext.Current.Response.Redirect(ConfigurationManager.AppSettings["DefaultUrl"]);
其他站点验证是否登录的代码:PassportService
public class PassportService
{
public static string TokenReplace()
{
string strHost = HttpContext.Current.Request.Url.Host;
string strPort = HttpContext.Current.Request.Url.Port.ToString();
string url = String.Format("http://{0}:{1}{2}", strHost, strPort, HttpContext.Current.Request.RawUrl);
url = Regex.Replace(url, @"(\?|&)Token=.*", "", RegexOptions.IgnoreCase);
return ConfigurationManager.AppSettings["UserAuthUrl"] + "?backurl=" + url.Encrypt();
}
public void Run()
{
var token = Common.Common.GetCookie("token"); RedisClient client = new RedisClient(ConfigurationManager.AppSettings["RedisServer"], ); UserInfo userInfo = client.Get<UserInfo>(token);
if (userInfo == null)
{
Common.Common.AddCookie("token", token, -);
//令牌错误,重新登录
HttpContext.Current.Response.Redirect(TokenReplace(), false);
}
else
{
Common.Common.AddCookie("token", token, Int32.Parse(ConfigurationManager.AppSettings["Timeout"]));
}
} public UserInfo GetUserInfo()
{
var token = Common.Common.GetCookie("token");
RedisClient client = new RedisClient(ConfigurationManager.AppSettings["RedisServer"], );
return client.Get<UserInfo>(token) ?? new UserInfo();
} }
三、最后看下效果图

四、代码下载
这里只做了一个简单的实现,提供了一个简单的思路,具体用的时候可以继续完善。
代码下载:
http://pan.baidu.com/s/1pK9U8Oj
五、加关注
如果本文对你有帮助,请点击右下角【好文要顶】和【关注我】
.NET基于Redis缓存实现单点登录SSO的解决方案的更多相关文章
- .NET基于Redis缓存实现单点登录SSO的解决方案[转]
一.基本概念 最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单点登录,现在就NET基于Redis缓存实现单点登录做一个简单的分享. 单点登录(Single Sign On),简称 ...
- Redis缓存实现单点登录SSO
.NET基于Redis缓存实现单点登录SSO的解决方案 .NET基于Redis缓存实现单点登录SSO的解决方案 一.基本概念 最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单 ...
- Atitit. 单点登录sso 的解决方案 总结
Atitit. 单点登录sso 的解决方案 总结 1. 系统应用场景and SSO模式选型 2 2. 系统应用的原则与要求 2 2.1. 开发快速简单::绝大部分系统来说,开发快速简单为主 2 2. ...
- Asp.Net Core基于Cookie实现同域单点登录(SSO)
在同一个域名下有很多子系统 如:a.giant.com b.giant.com c.giant.com等 但是这些系统都是giant.com这个子域. 这样的情况就可以在不引用其它框架的情况下, ...
- SSO 基于Cookie+fliter实现单点登录(SSO):工作原理
SSO的概念: 单点登录SSO(Single Sign-On)是身份管理中的一部分. SSO的一种较为通俗的定义是:SSO是指訪问同一server不同应用中的受保护资源的同一用户,仅仅须要登录一次,即 ...
- 基于云端的通用权限管理系统,SAAS服务,基于SAAS的权限管理,基于SAAS的单点登录SSO,企业单点登录,企业系统监控,企业授权认证中心
基于云端的通用权限管理系统 SAAS服务 基于SAAS的权限管理 基于SAAS的单点登录SSO 基于.Net的SSO,单点登录系统,提供SAAS服务 基于Extjs 4.2 的企业信息管理系统 基于E ...
- 单点登录(一)-----理论-----单点登录SSO的介绍和CAS+选型
什么是单点登录(SSO) 单点登录主要用于多系统集成,即在多个系统中,用户只需要到一个中央服务器登录一次即可访问这些系统中的任何一个,无须多次登录. 单点登录(Single Sign On),简称为 ...
- cas单点登录 SSO 的实现原理
原文出处: cutesource 欢迎分享原创到伯乐头条 单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户 ...
- 单点登录 SSO 的实现原理
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任. 单点登录在大型网站里使用 ...
随机推荐
- mysql regexp用法
正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...
- db2存储过程
一. 使用存储过程的好处 1. 减少客户机与服务器之间的网络使用率,以及数据库锁定保持的时间 应用程序通常在执行每个SQL语句都要跨网络两次,存储过程可以将SQL语句集中在一起, 从而使得对于每一组S ...
- eclipse常用配置
一. 手动方式安装svn插件 1. 根据本地的svn客户端的版本,到http://subclipse.tigris.org/ 下载eclipse对应版本的svn插件包 注:装eclipse里面的svn ...
- spring定时器(一)
使用的是spring的quartz功能,需导入com.springsource.org.quartz.jar包. 此定时器无法重置定时时间,需要的话可查看:spring定时器(二) spring的be ...
- 烂泥:源码安装apache
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 最近要开始学习nagios监控方面的知识了,但是nagios与apache结合的比较紧密,所以本篇文章就先把apache的源码安装学习下. 我们现在分以 ...
- actionlib的身世之谜
不知道为什么会把这么严肃认真的一篇技术整理贴起这么一个故事会风格类似的名字,就这样吧:^)shenmegui 园子里有人整理了actionlib的初学者教程,我来整理下actionlib的细节描述吧. ...
- HowTo: Linux Server Change OR Setup The Timezone
Method 1 #tzselect # select timezone e.g. Asia/Shanghai#echo 'Asia/Shanghai' > /etc/timezone # se ...
- unordered容器
1.散列容器(hash container) 散列容器通常比二叉树的存储方式可以提供更高的访问效率. #include <boost/unordered_set.hpp> #includ ...
- 【redis使用全解析】常见运维操作
作者:gnuhpc 出处:http://www.cnblogs.com/gnuhpc/ 1.1 启动 1.1.1 启动redis $ redis-server redis.conf 常见选项: ./r ...
- 超链接a的target属性
<a>标签的target意思很明确就是在哪里打开目标文档. 第一种情况: 默认情况:当我们没有设置超链接属性target的value值时默认是_self,即<a target=&qu ...