一、基本概念

最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单点登录,现在就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"], 6379);
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,-1);
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"], 6379); UserInfo userInfo = client.Get<UserInfo>(token);
if (userInfo == null)
{
Common.Common.AddCookie("token", token, -1);
//令牌错误,重新登录
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"], 6379);
return client.Get<UserInfo>(token) ?? new UserInfo();
} }

三、最后看下效果图

四、代码下载

这里只做了一个简单的实现,提供了一个简单的思路,具体用的时候可以继续完善。

代码下载:

http://pan.baidu.com/s/1pK9U8Oj

原文地址:http://www.cnblogs.com/yinrq/p/5276628.html#undefined

.NET基于Redis缓存实现单点登录SSO的解决方案[转]的更多相关文章

  1. .NET基于Redis缓存实现单点登录SSO的解决方案

    一.基本概念 最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单点登录,现在就NET基于Redis缓存实现单点登录做一个简单的分享. 单点登录(Single Sign On),简称 ...

  2. Redis缓存实现单点登录SSO

    .NET基于Redis缓存实现单点登录SSO的解决方案 .NET基于Redis缓存实现单点登录SSO的解决方案   一.基本概念 最近公司的多个业务系统要统一整合使用同一个登录,这就是我们耳熟能详的单 ...

  3. Atitit. 单点登录sso 的解决方案 总结

    Atitit.  单点登录sso 的解决方案 总结 1. 系统应用场景and SSO模式选型 2 2. 系统应用的原则与要求 2 2.1. 开发快速简单::绝大部分系统来说,开发快速简单为主 2 2. ...

  4. Asp.Net Core基于Cookie实现同域单点登录(SSO)

    在同一个域名下有很多子系统 如:a.giant.com  b.giant.com   c.giant.com等 但是这些系统都是giant.com这个子域. 这样的情况就可以在不引用其它框架的情况下, ...

  5. SSO 基于Cookie+fliter实现单点登录(SSO):工作原理

    SSO的概念: 单点登录SSO(Single Sign-On)是身份管理中的一部分. SSO的一种较为通俗的定义是:SSO是指訪问同一server不同应用中的受保护资源的同一用户,仅仅须要登录一次,即 ...

  6. 基于云端的通用权限管理系统,SAAS服务,基于SAAS的权限管理,基于SAAS的单点登录SSO,企业单点登录,企业系统监控,企业授权认证中心

    基于云端的通用权限管理系统 SAAS服务 基于SAAS的权限管理 基于SAAS的单点登录SSO 基于.Net的SSO,单点登录系统,提供SAAS服务 基于Extjs 4.2 的企业信息管理系统 基于E ...

  7. 单点登录(一)-----理论-----单点登录SSO的介绍和CAS+选型

    什么是单点登录(SSO) 单点登录主要用于多系统集成,即在多个系统中,用户只需要到一个中央服务器登录一次即可访问这些系统中的任何一个,无须多次登录. 单点登录(Single Sign On),简称为 ...

  8. cas单点登录 SSO 的实现原理

    原文出处: cutesource   欢迎分享原创到伯乐头条 单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户 ...

  9. 单点登录 SSO 的实现原理

    单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任. 单点登录在大型网站里使用 ...

随机推荐

  1. 【Network】UDP 大包怎么发? MTU怎么设置?

    这里主要用UDP来发送视频,当发送的数据大于1500时分包发送,保证每包小于1500.发送好办,分割后循环发就可以了,关键是接收时的处理.先做一下处理的方法 :发送时每包上面加上标识,比如RTP的做法 ...

  2. 2014 39th ACM-ICPC 西安赛区 总结

    西安,打铁. 出发前听说是大赛区,签到的时候看了秩序册的队伍情况,264支队伍. 在听说是大赛区之前,我觉得我们队应该是银首,运气好+发挥超常的话或许有金,即保银冲金. 听到大赛区之后,觉得可能金区有 ...

  3. PHP 基础(赋值及函数)

    开端<?php>结尾</php> 弱类型语言  定义变量的时候 不需要 声明   但是 每一个变量前   都必须  加$ 符号 储存文件按  统一放到 安装文件夹下面的  WA ...

  4. i春秋手动病毒查杀

    1:查看系统进程程   tasklist命令 2:当任务管理器无法打开的时候可以利用 taskkill /f /im [程序所显示的pid]   两个参数的意思分别是强制和程序在内存中的印象 3:ms ...

  5. 解决linux系统启动之:unexpected inconsistency:RUN fsck

    现象: 虚拟机在启动过程中提示: unexpected inconsistency;RUN fsck MANUALLY 原因分析: 1.由于意外关机导致的文件系统问题 解决方法: 方法1: 输入ROO ...

  6. 使用原生ajax处理json组成的数组

    和前一篇文章一样,直接上代码了,只是做个记录. 数据的提供页面,tigong.php <?php header("content-type:text/html;charset=utf- ...

  7. centos7修改主机名

    临时修改: hostname centos7 永久修改: # hostnamectl set-hostname cen07

  8. CozyRSS开发记录1-原型图与Grid

    CozyRSS开发记录1-原型图与Grid 1.使用MockPlus画出最简陋的原型图 这个界面参考了目前我最常使用的RSS阅读-傲游浏览器的内置RSS阅读器.主体框架划分为上.左下.右下三块,分别是 ...

  9. 用JMeter进行Performance Test

    用JMeter可以对Http请求进行Performance Test,来分析哪些方法花费的时间多,哪些方法花费的时间少,有了这样的分析结果后,我们就可以集中力量来改进费时的方法. 官方文档请参考如下链 ...

  10. 使用lnmp一键安装包后yum源出现的问题与解决

    遇到一个问题就是执行 Yum update 或使用yum安装软件等命令的时候会有一个链接报404,使用find查找到该链接与kbsingh-CentOS-Extras.repo这个包有关,删除后yum ...