1
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){

$.ajax({
            type: "GET",
            dataType: 'jsonp',
            url: "http://myJira.com/rest/api/2/issue/MA-6614/comment",
            username : "myusrName",
            password : "myPwd",
            success: function (data) {
                 console.log( "Sample of data:", JSON.stringify(data)); 

            },
            error: function (errormessage) {
              console.log( "errorMessage:", errormessage); 
            }
        });
});


</script>
</head>
<body> 
</body>
</html>

在运行上面的代码时,我得到了SyntaxError: missing ; 声明错误之前。我在某处读到 Access-Control-Allow-Origin 应该用来解决问题。但是我在任何地方都找不到关于如何使用 Jira 的好的文档。

“更新”
如果我已经登录 jira,我会遇到上述错误。如果我在 jira 中注销然后运行上述代码,则会出现错误“NetworkError: 401 Unauthorized - http://myjira.com/rest/api/2/issue/MA-6614/comment?callback=jQuery1102010440085066514837_1388216960965&_=1388216960966

上面的代码似乎有两个问题。1. 无法在jira中进行身份验证。2. 如果我们已经在 jira 中进行了身份验证(这意味着浏览器有 cookie)并发出请求,那么由于 jsonp 会显示语法错误。

4

2 回答 2

3

所以我得到了答案。撤销对 jira 的支持以从 javascript 进行身份验证。Iitally jsonP 是选项,但现在不可能。我们必须对 jira 进行服务器端身份验证。这里的例子

https://developer.atlassian.com/display/JIRADEV/JIRA+REST+API+Example+-+Basic+Authentication

于 2014-01-08T05:48:49.003 回答
0

你可以用javascript来做到这一点。

function request(){
  var xhr = getXHR();

  xhr.addEventListener("error", transferFailed, false);
  xhr.addEventListener("abort", transferCanceled, false);

  xhr.open("GET", baseURL+"/rest/api/2/issue/KEY-1", false);
  xhr.setRequestHeader("Authorization", "Basic "+btoa("admin:admin"))
  xhr.setRequestHeader('Content-Type', 'application/json');
  xhr.send();
}

确保它是同步的,并且 jira 服务器配置具有:

标头始终设置 Access-Control-Allow-Credentials "true" 标头设置 Access-Control-Allow-Headers "Authorization, Origin, X-Requested-With, Content-Type, Accept"

于 2014-07-15T19:50:24.783 回答