当前位置: 首页 > news >正文

关于网站建设的网站有哪些微商城官网地址

关于网站建设的网站有哪些,微商城官网地址,石家庄市网站制作价格,网站建设+公司上次在《JSON Web Token - 在Web应用间安全地传递信息》中我提到了JSON Web Token可以用来设计单点登录系统。我尝试用八幅漫画先让大家理解如何设计正常的用户认证系统#xff0c;然后再延伸到单点登录系统。 如果还没有阅读《JSON Web Token - 在Web应用间安全地传递信息》然后再延伸到单点登录系统。 如果还没有阅读《JSON Web Token - 在Web应用间安全地传递信息》我强烈建议你花十分钟阅读它理解JWT的生成过程和原理。 用户认证八步走 所谓用户认证Authentication就是让用户登录并且在接下来的一段时间内让用户访问网站时可以使用其账户而不需要再次登录的机制。 小知识可别把用户认证和用户授权Authorization搞混了。用户授权指的是规定并允许用户使用自己的权限例如发布帖子、管理站点等。 首先服务器应用下面简称“应用”让用户通过Web表单将自己的用户名和密码发送到服务器的接口。这一过程一般是一个HTTP POST请求。建议的方式是通过SSL加密的传输https协议从而避免敏感信息被嗅探。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 540px; height: 288px; 接下来应用和数据库核对用户名和密码。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 574px; height: 234px; 核对用户名和密码成功后应用将用户的id图中的user_id作为JWT Payload的一个属性将其与头部分别进行Base64编码拼接后签名形成一个JWT。这里的JWT就是一个形同lll.zzz.xxx的字符串。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 676px; height: 272px; 应用将JWT字符串作为该请求Cookie的一部分返回给用户。注意在这里必须使用HttpOnly属性来防止Cookie被JavaScript读取从而避免跨站脚本攻击XSS攻击。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 710px; height: 234px; 在Cookie失效或者被删除前用户每次访问应用应用都会接受到含有jwt的Cookie。从而应用就可以将JWT从请求中提取出来。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 500px; height: 234px; 应用通过一系列任务检查JWT的有效性。例如检查签名是否正确检查Token是否过期检查Token的接收方是否是自己可选。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 668px; height: 294px; 应用在确认JWT有效之后JWT进行Base64解码可能在上一步中已经完成然后在Payload中读取用户的id值也就是user_id属性。这里用户的id为1025。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 584px; height: 294px; 应用从数据库取到id为1025的用户的信息加载到内存中进行ORM之类的一系列底层逻辑初始化。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 574px; height: 234px; 应用根据用户请求进行响应。 frameborder0 scrollingno stylefont-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; white-space: normal; background-color: rgb(254, 254, 242); border-width: initial; border-style: none; width: 464px; height: 274px; 和Session方式存储id的差异 Session方式存储用户id的最大弊病在于要占用大量服务器内存对于较大型应用而言可能还要保存许多的状态。一般而言大型应用还需要借助一些KV数据库和一系列缓存机制来实现Session的存储。 而JWT方式将用户状态分散到了客户端中可以明显减轻服务端的内存压力。除了用户id之外还可以存储其他的和用户相关的信息例如该用户是否是管理员、用户所在的分桶见[《你所应该知道的A/B测试基础》一文](/2015/08/27/introduction-to-ab-testing/等。 虽说JWT方式让服务器有一些计算压力例如加密、编码和解码但是这些压力相比磁盘I/O而言或许是半斤八两。具体是否采用需要在不同场景下用数据说话。 单点登录 Session方式来存储用户id一开始用户的Session只会存储在一台服务器上。对于有多个子域名的站点每个子域名至少会对应一台不同的服务器例如 www.taobao.comnv.taobao.comnz.taobao.comlogin.taobao.com 所以如果要实现在login.taobao.com登录后在其他的子域名下依然可以取到Session这要求我们在多台服务器上同步Session。 使用JWT的方式则没有这个问题的存在因为用户的状态已经被传送到了客户端。因此我们只需要将含有JWT的Cookie的domain设置为顶级域名即可例如 1Set-Cookie: jwtlll.zzz.xxx; HttpOnly; max-age980000; domain.taobao.com 注意domain必须设置为一个点加顶级域名即.taobao.com。这样taobao.com和*.taobao.com就都可以接受到这个Cookie并获取JWT了。 原文地址http://www.cnblogs.com/RealmKing/articles/6085715.html .NET社区新闻深度好文微信中搜索dotNET跨平台或扫描二维码关注
http://www.huolong8.cn/news/305929/

相关文章:

  • 长春网站制作推广多点网络网站制作系统
  • 医院做网站的风格成都企业seo
  • 怎么做qq分享网站创建公司的基本流程
  • 门户网站建设专业wordpress阅读量怎么查看
  • 网站如何进行建设微信公众号 wordpress
  • 网站上传安装wordpress调用外部数据库
  • 网站虚拟主机租用深圳品牌网站制作公司哪家好
  • 设备外贸用哪个网站宣城公司做网站
  • 网站建设小程序开发报价高端网站建设seo
  • 帝国cms做搜索网站漳州正规网站建设价格
  • 加强机构编制网站建设力度南京安居建设公司
  • 做网站信息深圳有哪些做网站公司
  • 可以兼职做设计的网站创业先做网站
  • 公益网站建设需求微信与wordpress
  • 上海网站建设兴策IP不能安装wordpress
  • 宁夏建设厅网站6专业苏州网站建设
  • wordpress 做网站工商公示系统查询入口
  • 无锡手机网站制作费用网站版面的图文是怎么做的
  • 威海住房建设局网站洛阳鼎和电力建设有限公司网站
  • 东营做网站优化公司企业信用信息查询公示系统年审
  • 网站建设与网页设计视频百度快照优化排名怎么做
  • 自己用电脑网站建设深圳网站建设推广公司
  • asp网站伪静态文件下载做网站怎么做起来的
  • 上海网站建设费用北京网站建设公司排行榜
  • 文章写作网站做网站项目时 需求分析的内容
  • 做设计网上揽活哪个网站最好濮阳推广公司
  • 做网站多少钱特惠西宁君博s如何修改管理网站
  • 衡水企业网站网站策划书撰写流程
  • 专业网站建设详细方案做网站的公司不会设计
  • 电子商务网站功能设计与分析用python写一个简单的网页