我正在尝试使用 Jenkins json API,但无法使身份验证正常工作。
设置:
- Jenkins 安全性:
Jenkin 自己的用户数据库
- 访问:
Matrix-gebaseerde beveiliging
- CORS 通过 Jenkins CORS plugin
- 使用注册用户的用户名/API token
尝试过:
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 提供的答案:
我用过 Jenkins Cors Filter Plugin添加所需的 CORS header :
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);
});
可以通过特定用户的配置检索apitoken
以在Jenkins本身中使用。
关于jquery - 使用 jQuery 的 Jenkins json REST api 和 CORS 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33508417/