美文网首页SSO开发设计
前后端分离—关于登录状态那些事

前后端分离—关于登录状态那些事

作者: 95a6af369245 | 来源:发表于2019-06-27 14:53 被阅读327次

  背景

  登录是一个网站最基础的功能。有人说它很简单,其实不然,登录逻辑很简单,但涉及知识点比较多,如:

  密码加密、cookie、session、token、JWT等。

  我们看一下传统的做法,前后端统一在一个服务中:

  如图所示,逻辑处理和页面放在一个服务中,用户输入用户名、密码后,后台服务在session中设置登录状态,和用户的一些基本信息,

  然后将响应(Response)返回到浏览器(Browser),并设置Cookie。下次用户在这个浏览器(Browser)中,再次

  访问服务时,请求中会带上这个Cookie,服务端根据这个Cookie就能找到对应的session,从session中取得用户的信息,从而

  维持了用户的登录状态。这种机制被称作Cookie-Session机制。

  近几年,随着前后端分离的流行,我们的项目结构也发生了变化,如下图:

  我们访问一个网站时,先去请求静态服务,拿到页面后,再异步去后台请求数据,最后渲染成我们看到的带有数据的网站。在这种结构下,

  我们的登录状态怎么维持呢?上面的Cookie-Session机制还适不适用?

  这里又分两种情况,服务A和服务B在同一域下,服务A和服务B在不同域下。在详细介绍之前,我们先普及一下浏览器的同源策略。

  同源策略

  同源策略是浏览器保证安全的基础,它的含义是指,A网页设置的 Cookie,B网页不能打开,除非这两个网页同源。

  所谓同源是指:

  协议相同

  域名相同

  端口相同例如:http://www.a.com/login,协议是http,域名是www.a.com,端口是80。只要这3个相同,我们就可以在请求(Request)时带上Cookie,

  在响应(Response)时设置Cookie。

  同域下的前后端分离

  我们了解了浏览器的同源策略,接下来就看一看同域下的前后端分离,首先看服务端能不能设置Cookie,具体代码如下:

  后端代码:

  我们设置Cookie的path为根目录/,以便在该域的所有路径下都能看到这个Cookie。

  前端代码:

  我们在浏览器访问http://www.a.com:8888/index.html,访问前先设置hosts,将www.a.com指向我们本机。访问结果如图所示:

  我们可以看到服务器成功设置了Cookie。然后我们再看看同域下,异步请求能不能带上Cookie,代码如下:

  后端代码:

  前端代码如下:

  访问结果如图所示:

  再看看后台打印的日志:

  name:test-----value:same

  同域下,异步请求时,Cookie也能带到服务端。

  所以,我们在做前后端分离时,前端和后端部署在同一域下,满足浏览器的同源策略,登录不需要做特殊的处理。

  不同域下的前后端分离

  不同域下,我们的响应(Response)能不能设置Cookie呢?请求时能不能带上Cookie呢?我们实验结果如下,这里就不给大家贴代码了。

  由于我们在a.com域下的页面跨域访问b.com的服务,b.com的服务不能设置Cookie。

  如果b.com域下有Cookie,我们在a.com域下的页面跨域访问b.com的服务,能不能把b.com的Cookie带上吗?答案是也带不上。那么我们怎么解决

  跨域问题呢?

  JSONP解决跨域

  JSONP的原理我们可以在维基百科上查看,上面写的很清楚,我们不做过多的介绍。我们改造接口,

  在每个接口上增加callback参数:

  如果callback参数不为空,将返回js函数。前端改造如下:

  设置Cookie页面改造如下:

  请求Cookie时改造如下:

  所有的请求都加了callback参数,请求的结果如下:

  很神奇吧!我们设置了b.com域下的Cookie。如果想知道为什么?还是看一看JSONP的原理吧。我们再访问第二个页面,看看Cookie能不能

  传到服务。后台打印日志为:

  name:test-----value:same

  好了,不同域下的前后端分离,可以通过JSONP跨域,从而保持登录状态。但是,jsonp本身没有跨域安全规范,一般都是后端进行安全限制,

  处理不当很容易造成安全问题。

  CORS解决跨域

  CORS是一个W3C标准,全称是跨域资源共享(Cross-origin resource sharing)。CORS需要浏览器和服务器同时支持。目前,所有浏览器都支持该功能,IE浏览器不能低于IE10。

  整个CORS通信过程,都是浏览器自动完成,不需要用户参与。对于开发者来说,CORS通信与同源的AJAX通信没有差别,代码完全一样。

  浏览器一旦发现AJAX请求跨源,就会自动添加一些附加的头信息,有时还会多出一次附加的请求,但用户不会有感觉。

  如果想要详细理解原理,请参考维基百科

  CORS请求默认不发送Cookie和HTTP认证信息。若要发送Cookie,浏览器和服务端都要做设置,咱们要解决的是跨域后的登录问题,所以要允许跨域发送

  Cookie。

  后端要设置允许跨域请求的域和允许设置和接受Cookie。

  我们通过@CrossOrigin注解允许跨域,origins设置了允许跨域请求的域,allowCredentials允许设置和接受Cookie。

  前端要设置允许发送和接受Cookie。

  我们访问页面看一下效果。

  没有Cookie吗?别急,我们再从浏览器的设置里看一下。

  有Cookie了,我们再看看访问能不能带上Cookie,后台打印结果如下:

  name:test-----value:same

  我们使用CORS,也解决了跨域。

  总结

  前后端分离,基于Cookie-Session机制的登录总结如下

  前后端同域——与普通登录没有区别

  前后端不同域

  JSONP方式实现

  CORS方式实现

相关文章

  • 前后端分离 | 关于登录状态那些事

    背景 登录是一个网站最基础的功能。有人说它很简单,其实不然,登录逻辑很简单,但涉及知识点比较多,如:密码加密、co...

  • 前后端分离—关于登录状态那些事

    背景 登录是一个网站最基础的功能。有人说它很简单,其实不然,登录逻辑很简单,但涉及知识点比较多,如: 密码加密、c...

  • SpringBootSecurity学习(13)前后端分离版之J

    JWT 使用 前面简单介绍了把默认的页面登录改为前后端分离的接口异步登录的方法,可以帮我们实现基本的前后端分离登录...

  • 前后端分离的项目如何实现登录状态的保持。

    前后端分离的项目一般会使用token实现登录状态的保持。token其实就是一个随机字符串,当用户在登录页面输入账号...

  • 微信登录的几种方式 以及在前后端分离如何实现

    微信登录的几种方式 以及在前后端分离如何实现

  • 前后端分离开发

    含义 前后端分离开发顾名思义,就是将前端后端分离可以同时进行开发.前端就只管前端的事,后端就只管后端的事,比起传统...

  • 2018-12-06

    接口性能测试文档(预生产): 目标 后端接口性能测试前需要有量化目标。例如: N用户登录(或不登录状态),观察K线...

  • 前后端分离开发

    前后端分离开发顾名思义,就是将前端后端分离可以同时进行开发.前端就只管前端的事,后端就只管后端的事,比起传统的We...

  • 模拟RSA+AES登录

    背景:需要为接口自动化做准备,拿到登录的令牌。 目标:模拟前端登录 登录逻辑:(1)现在前后端分离登录,一般登录逻...

  • thinkphp5.1中使用tp5-rbac插件

    tp5-rbac插件的使用 背景说明:前后端分离架构,前端使用Vue,后端使用Thinkphp5.1.*登录认证使...

网友评论

    本文标题:前后端分离—关于登录状态那些事

    本文链接:https://www.haomeiwen.com/subject/hokrcctx.html