设为首页 收藏本站
查看: 1171|回复: 0

[经验分享] golang前后端jwt对接

[复制链接]

尚未签到

发表于 2018-9-20 08:32:02 | 显示全部楼层 |阅读模式
0x0 什么是jwt
  JWT是JSON Web Token的缩写,可以用作授权认证。传统的授权认证一般采用session,由于session存储在服务端,加大了服务端的计算量,
  
而且多台服务器之间存在着session同步的问题。而JWT存储在客户端,不仅减少了服务端的计算量,而且天生支持分布式。

0x1 jwt的结构
  JWT由三部分组成:
  
Header:头部,表明类型和加密算法
  
Claims:声明,即载荷(承载的内容)
  
Signature:签名,这一部分是将header和claims进行base64转码后,并用header中声明的加密算法加盐(secre)后构成。
  
即:
  
tmpstr = base64(header)+base64(claims)
  
signature = encrypt(tmpstr,secret)
  
最后三者用"."连接,即:
  
token = base64(header).base64(claims).signature
  详细的介绍可以看jwt中文文档.
  
另外jwt官网有调试工具,可以辅助查错。

0x2 在web中如何使用
  客户端发送登录请求(这个登录请求是不需要jwt验证的),在登录请求里返回token。
  
客户端把token保存起来,以后其它需要token的请求就在header里带上token。

0x3 实战

在echo框架中使用jwt
  这里是官方文档和教程,说的比较清楚了。
  
我们仅需要在登录接口里生成jwt的token,并返回,jwt中间件会自动帮我们做jwt的验证。可以把先做分组路由,在分组里使用jwt中间件。
  
如果不使用框架,可以直接用jwt-go

配合axios.js
  我们的前端使用了vue+axios,他嫌每次都拼接header麻烦,于是帮他在网上查了一下,可以配置axios为自动添加header。
  
axios的代码如下:参考了这篇博客
  

require('es6-promise').polyfill(); // 引入一次就行  
import axios from 'axios';
  

  
// 创建 axios 实例
  
const Axios = axios.create({
  baseURL: 'your base url',
  timeout: 5000,
  
});
  

  
Axios.interceptors.request.use(
  config => {
  if (config.method === 'post') {
  const formData = new FormData();
  Object.keys(config.data).forEach(key => formData.append(key, config.data[key]));
  config.data = formData;
  }
  

  if (config.url !="/login" && localStorage.token != undefined ){
  config.headers.Authorization = 'Bearer ' + localStorage.token;
  }
  return config;
  },
  error => {
  return Promise.reject(error);
  }
  
);
  

  
Axios.interceptors.response.use(
  res => {
  return Promise.resolve(res);
  },
  error => {
  return Promise.reject(error);
  }
  
);
  

  
// 将 Axios 实例添加到Vue的原型对象上
  
export default {
  install(Vue) {
  Object.defineProperty(Vue.prototype, '$Axios', { value: Axios });
  }
  
};
  

  

  注意if (config.method === 'post') 这里是把post过去的数据转为表单,如果不加这一句,提交过去的是文本了,在服务器端无法用getpost(key)这种方式获取参数了。

0x4 调试
  要善于利用官网调试工具,我便在jwt加密上掉坑里了。
  
加密时使用的是HS256,而验证时用的是HS512。

0x5 扩展
  由于jwt载荷使用的是base64编码,可以很容易被破解,所以不要放入敏感信息,也不建议放入过多的信息。
  
jwt里可以存过期时间,所以可以用来做时效性的应用,而且不需要使用数据库。
  
另外也要避免jwt的重放攻击。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-598520-1-1.html 上篇帖子: Golang archlinux下环境配置 下篇帖子: c#实现golang 的channel
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表