.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)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任. 单点登录在大型网站里使用 ...
随机推荐
- ORA-07445&ORA-00108错误案例
由于需要ORACLE的UAT测试环境,克隆了虚拟机后,修改IP地址后,启动实例遇到了ORA-07445 &ORA-00108错误. 案例环境: SQL> select * from ...
- mysql-5 数据检索(3)
计算字段 如果想在一个字段中既显示公司的名称,又显示公司的地址,但是这两个信息一般包含在不同的表列中 城市.州和邮政编码存储在不同的列中,但是邮件标签打印程序却需要把它们作为一个恰当格式的字段检索出来 ...
- 【CSharp】C#中equals与==小记
序: 昨天技术群中的一个小伙伴发了几个字符串以及值类型比较的面试题,没想到我们的答案不尽人意...下面是截图以及答案,看看与各位看官的答案是否相同. ...
- 烂泥:CentOS命令学习之scp复制
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 由于工作需要,需要把服务器A上的文件弄一份到服务器B上.自己比较懒不打算搭建FTP.Samba服务器,所以就打算使用scp命令,scp命令是通过ssh协 ...
- iOS tabbar 自定义小红点 消息显示,定制边框、颜色、高宽
一般我们需要显示消息数,会利用到系统提供的api UIApplication.sharedApplication().applicationIconBadgeNumber = 10 但如果我们不想显示 ...
- Linux vim编辑命令
yum install -y vim-enhanced 安装vim 命令 一般模式 shift 4 行尾 shift 6 或 0行首 gg 顶部 G 下部 复制 yy 剪切几行 数字 dd p粘贴 ...
- spring + redis 实现数据的缓存
1.实现目标 通过redis缓存数据.(目的不是加快查询的速度,而是减少数据库的负担) 2.所需jar包 注意:jdies和commons-pool两个jar的版本是有对应关系的,注意引入jar包是要 ...
- windows文件关联、打开方式列表之修改注册表攻略
这里全是修改注册表的方式.网上找了半天,有的仅有添加文件关联的方法,却没有添加到打开方式列表里面的方法:有的有添加到文件列表的方法,却是使 用控制面板->文件夹选项的.好难得才找齐所有,从添加文 ...
- Spring MVC @ResponseBody返回中文字符串乱码问题
朋友做小项目练手的时候遇到的,着实让他郁闷够呛..这个问题的确很恶心.. 项目中引用的json包,直接用@ResponseBody注解返回json字符串..有关这个的乱码问题网上很多,各种花样各种转码 ...
- MMORPG大型游戏设计与开发(客户端架构 part4 of vegine)
昨天是七夕,祝大家都过的快乐,希望这句迟到的问候不会造成大家心中的困扰.这一节讲到了前端比较重要的模块,性能以及调试异常模块.一个应用的性能往往是最核心的部分,就像人身体的各个器官一样,一小部分也不能 ...