我正在尝试使用 Jenkins json API,但无法使身份验证正常工作。
setup:
- 詹金斯安全:
Jenkin’s own user database
- access:
Matrix-gebaseerde beveiliging
- CORS 通过Jenkins CORS 插件 https://wiki.jenkins-ci.org/display/JENKINS/Cors+Filter+Plugin
- 使用注册用户的用户名/api 令牌
tried:
var username = "username";
var apiToken = "apiToken";
// username / api-token on url (basic authentication)
$.ajax({
url: "http://"+username+":"+apiToken+"@host:port/job/test/api/json",
method: "GET"
});
// username / api-token supplied using jQuery's username/password properties
$.ajax({
url: "http://host:port/job/test/api/json",
method: "GET",
username: username,
password: apiToken
});
// username / api-token by setting "Authorization" header directly
$.ajax({
url: "http://host:port/job/test/api/json",
method: "GET",
headers: {
"Authorization": "Basic " + btoa(username + ":" + apiToken)
}
});
所有这些尝试都会产生相同的结果:响应:403 禁止
回应 @nick 提供的答案:
我用过詹金斯Cors 过滤器插件 https://wiki.jenkins-ci.org/display/JENKINS/Cors+Filter+Plugin添加所需的 CORS 标头:
Access-Control-Allow-Origins: http://mydomain
Access-Control-Allow-Methods: GET, POST, OPTIONS
Access-Control-Allow-Headers: Authorization
@nick的解决方案要求您在同一浏览器中进行身份验证。
为了通过 REST 调用提供凭据,我添加了一个"Authorization" header
像这样:
$.ajax({
url:'https://myserver.com/job/MYJOB/lastBuild/api/json',
method: 'GET',
headers: {'Authorization': 'Basic ' + btoa('username:apitoken')}
}).done(function(data) {
console.log(data);
}).fail(function() {
console.error(arguments);
});
The apitoken
可以通过特定用户的配置来检索以在 Jenkins 本身中使用。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)