一种基于二个系统之间的重定向操作,可利用第一个系统的账号密码在第二个系统后台登录后,获取第二个系统所需要的token,直接存储在cookie中,再传给第二个系统,这样第二个系统就无需输入账号密码登录。

需求分析:

二个业务系统,共享一套用户账号密码表,所以第一个系统能登录的账号,也能登录第二个系统,但是第一个系统只需要账号密码登录,无需token登录,而第二系统需要token登录。

为了确保可直接在第一个系统跳转到第二个系统,目前需要二个东西,一是利用账号密码登录第二个系统时,第二个系统生成的token,二是重定向第二个系统时所需要拼接的url,因为是用户登录,url上肯定会有用户信息,所以需要拼接。

因为利用token登录的本质也就是,通过账号密码生成一个token去验证登录,所以获取到token就无需账号密码了。

代码就也分步骤把,思路就是上面的了

1.首先利用第一个系统的账号密码去登录第二个系统

       R<?> logininfo = systemUserService.doLogin(loginParam);

2. 获取登录后生成的token,一般还会获取传入的token过期时间

String _token = loginObject.getStr("access_token");
Integer expires = loginObject.getInt("expires_in");

3,将token存入cookie,再将cookie存入response(这里注意这个接口前端传的是一个respone)

Cookie expiresCookie = new Cookie("expires_in", String.valueOf(expires));
Cookie tokenCookie = new Cookie("access_token", _token);

expiresCookie.setPath("/");
expiresCookie.setDomain(frontendDomain);
tokenCookie.setPath("/");
tokenCookie.setDomain(frontendDomain);

response.addCookie(expiresCookie);
response.addCookie(tokenCookie);

response.setHeader("Authorization", "Bearer " + _token);

// 保证cookie可以保证正确写到浏览器,然后执行页面跳转
String html = "<script type='text/javascript'>location.href='" + redirectUrl + "';</script>";
response.getWriter().print(html);

最后返回的也是response即可。里面有tokencookie,还有expirecookie。还有重定向的url路径

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值