我一直在使用Postman in-tab扩展来测试调用JHipster资源API的调用,发现它工作得很好(JHipster设置使用OAuth2)。我使用JHipster登录页面进行了身份验证,然后打开了一个带有Postman扩展的新选项卡。
我刚刚将JHipster应用程序切换为使用JWT,这种使用Postman的方法不再有效,我在调用API时获得了许可。此外,Postman的标签内扩展程序已被弃用,以支持独立应用程序。
问题:是否有关于设置Postman以对JHipster / JWT进行身份验证的文档?
答案 0 :(得分:13)
可以将Postman与JWT JHipster app一起使用。
Authorization
标头的任何API请求。 JWT令牌是" Bearer"右边的值。您还可以在密钥jhi-authenticationToken
下的浏览器的localStorage中找到此令牌。编辑Postman中的标题并添加Authorization
标题。该值应如下所示:
Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiJydRkZWxsIiwiYXV0aCI6IlJPTEVfQURNSU4sUk9MRV9U0VSIiwiZXhwIjoxNDgzOTg1MDkzfQ.1A13sBvr3KDWxJQpKDKOS33KAVjWIb3mS_qfxLBOCq_LbMwNHnysAai0SNXXgudMOulAnXYN9_Mzlcv1_zctA
答案 1 :(得分:12)
/api/authenticate
with the following body:
{"password":"admin","username":"admin"}
. You will receive the following response: {"id_token":"aabbccddeeff"}
Authorization: Bearer aabbccddeeff
/api/authenticate
endpoint 答案 2 :(得分:2)
如果您已经部署了单个微服务,并且想要对其进行单独测试,则可以配置Postman使用预请求脚本来构建JWT令牌。
application-dev.yml
文件并获取base64-secret
值:security:
authentication:
jwt:
# This token must be encoded using Base64 and be at least 256 bits long (you can type `openssl rand -base64 64` on your command line to generate a 512 bits one)
base64-secret: N2Y2MmFkNzg2ZTI4NTZiZGEwMTZhYTAzOTBhMjgwMzlkMzU2MzRlZjJjZDA2MzQ0NGMxOGFlZThjOWY0MjkzNGVlOGE3ZjkxZGI5ZTQxOGY3MjEwNWUwYTUxMTUxODYxY2U4ZWMzZjVhMjg0NTZkNzlhNWUyMmEyNjQ5NzkxZmI=
将值放在Postman环境中名为jhipster_jwt_secret
的变量中。
配置您的请求前脚本(this is largely copied from a Gist):
function base64url(source) {
// Encode in classical base64
encodedSource = CryptoJS.enc.Base64.stringify(source);
// Remove padding equal characters
encodedSource = encodedSource.replace(/=+$/, '');
// Replace characters according to base64url specifications
encodedSource = encodedSource.replace(/\+/g, '-');
encodedSource = encodedSource.replace(/\//g, '_');
return encodedSource;
}
var header = {
"typ": "JWT",
"alg": "HS256"
};
var payload = {
"sub": "user",
"auth": "role"
};
var secret = CryptoJS.enc.Base64.parse(postman.getEnvironmentVariable("jhipster_jwt_secret"));
// encode header
var stringifiedHeader = CryptoJS.enc.Utf8.parse(JSON.stringify(header));
var encodedHeader = base64url(stringifiedHeader);
// encode data
var stringifiedPayload = CryptoJS.enc.Utf8.parse(JSON.stringify(payload));
var encodedPayload = base64url(stringifiedPayload);
// build token
var token = encodedHeader + "." + encodedPayload;
// sign token
var signature = CryptoJS.HmacSHA256(token, secret);
signature = base64url(signature);
var signedToken = token + "." + signature;
postman.setEnvironmentVariable("jwt_token", signedToken);
{{jwt_token}}
。答案 3 :(得分:1)