博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前后端分离的项目,如何解决登陆问题
阅读量:5091 次
发布时间:2019-06-13

本文共 686 字,大约阅读时间需要 2 分钟。

方案一:使用token

  1、前端把account和password,提交到服务端的登陆api

  2、服务端验证正确后,生成一个token,并把token和userId,存在缓存里(推荐使用redis数据库),然后把token返回给前端。

  3、前端每次的请求头中带有token,这样就能够轻松的实现。

方案二:使用cookie

  1、client发送username和password到server

  2、server认证成功后,写cookie到client,然后返回ok的json,其中cookie的key要存放在redis中,value就是用户信息,并且要设置key的超时时间。可以设置超时时间为60分钟。

  3、当客户端(client)收到ok服务端的响应后,执行相应的业务操作,以后每次请求服务端都会带上cookie,不用写代码。

  4、服务端(server)的fliter,每次会验证传过来的cookie中的key是否在redis中存在,如果存在,那么就代表在之前登陆过,cookie存在过。没有就返回错误标识。在登陆成功后,每次调用服务端的接口的时候

  ,都要为redis中的key进行续期,如为60分钟。

  5、当redis中的key超过60分钟,自己会删除这个key,那么再次请求服务端的时候,就会收到需要登陆的返回值。

  6、当用户主动从server(服务端)退出的时候,也会主动在server中删除redis中的key。

  

转载于:https://www.cnblogs.com/hengzhou/p/9395458.html

你可能感兴趣的文章
vim 括号匹配 以及各种跳转技巧
查看>>
正在学习或准备学习 Web 应用开发的初学者
查看>>
各大公司架构实践聚合
查看>>
西安前端交流会 - 【前端求职、就业、面试技巧】- 第5期-2015.3.29 报名了
查看>>
Linux-进程间通信(四): 域套接字
查看>>
jq check 复选变单选。
查看>>
C#父类子类对象关系
查看>>
(转)RACI模型(RACI Model)
查看>>
关于&&和||
查看>>
HTML5 学习笔记(一)——HTML5概要与新增标签
查看>>
浅谈MySQL之@1
查看>>
Jenkins使用
查看>>
三层VS控制器
查看>>
函数传递参数的本质
查看>>
Python学习第二篇
查看>>
Python学习第三篇——逻辑判定
查看>>
c++入门之函数指针和函数对象
查看>>
一个数组中同时找到最大/最小值
查看>>
python终端下打印颜色
查看>>
《从Paxos到ZooKeeper 分布式一致性原理与实践》阅读【Leader选举】
查看>>