简单的四种方式单点登录实现(SSO)

82 篇文章 1 订阅

转载自品略图书馆 http://www.pinlue.com/article/2020/03/2106/2610040113226.html

 

单点登录(Single Sign On),简称为 SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

在做单点登录之前观察了很多网站,比如微软中国登录跳转到微软美国统一登录页面再跳转过来,淘宝天猫登录,京东登录。

方法1

登录成功之后通过 url带token参数跳转  比如阿里云登录万网的方式

方法2

在js里获取登录服务器的token

jQuery.getScript("http://localhost:8081",function(){console.log(token);}); 方法3

登录成功之后 跳转到  (一站登录把全站都登录上)

<script src='b.com/login?uid=xxxx&token=xxxxx'></script>

<script src='c.com/login?uid=xxxx&token=xxxxx'></script>

方法4

登录成功之后 跳转到  (一站登录把全站都登录上)

<iframe src="http://www.pinlue.com/"/>

思路:

比如A应用 使用 公共SSO登录

A应用先判断自个session是否为空,为空再用方法2js跨域获取SSO的信息,获取到之后再调用 A应用自己存session方法,登录成功刷新。

在整个过程考虑一下安全问题就可以了。

以上的几种方式是我自己整理不需要加入复杂比较重的框架的简单SSO实现

用以上的方法必须设置SSO服务端允许跨域

/**

* 公共获取是否登录

* @param

* @param httpSessionl

* @return

*/

@RequestMapping(value = "/checklogin")

@ResponseBody

public String login(HttpSession httpSessionl, HttpServletResponse response){

response.setHeader("Access-Control-Allow-Origin", "*");//允许所有域名可访问  解决跨域问题

response.setHeader("P3P","CP=IDC DSP COR ADM DEVi TAIi PSA PSD IVAi IVDi CONi HIS OUR IND CNT");//解决IE跨域问题

Object token1=  httpSessionl.getAttribute("token");

if(token1!=null){

return "var isLogin=true;var token='"+token1+"';"; //script调用 返回json格式的数据

}else{

return "var isLogin=false";

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值