1

我有一个正在运行的 ServiceNow 实例,我正在尝试使用 JSON 库拉出所有用户。如果我输入转储此数据的 URL,我可以轻松查看 JSON 用户列表,我正在尝试创建一个网页,该网页将获取此 JSON 列表并从中制作用户列表。我不断遇到跨域问题,CORS 无法使用,因此我试图根据用户的信息动态加载脚本。这是我试图开始工作的代码。

        function test() {
        var username = document.getElementById("username").value;
        var password = document.getElementById("password").value;
        var domain = document.getElementById("domain").value;
        var targeturl = "https://" + username + ":" + password + "@"
            + domain + "/sys_user_list.do?JSON&sysparm_action=getRecords";
        $.getScript(targeturl + "&callback=dumpData")
        function dumpData(data) {
            alert(data);
        }
    }

此时脚本似乎可以正确加载,但会导致语法错误。

Uncaught SyntaxError: Unexpected token :

我应该如何进行 getScript 调用以便获取我的 JSON 数据?这甚至是一种有效的方法吗,我在试图解决这个问题时偶然发现了它,这似乎是我唯一的选择。我已经尝试过 YQL,但这不起作用。

编辑:

我已经重做代码以使用 $.ajax,这里是代码

            $.ajax({
            url: 'https://' + username + ':' + password + "@" + domain + '/sys_user_list.do?JSON&sysparm_action=getRecords&callback=test',
            type: "GET",  
            success: function (data) {
                alert("hello");
            },
            crossDomain: true,
            dataType: "jsonp",
            jsonpCallback: 'test'
        });
        function test(data) {
            alert("It worked!");
        }

我已经搜索了所有与此相关的帖子,但仍然无法弄清楚这一点。有人对如何纠正这种情况有任何建议吗?它仍然给出无效的语法错误。是不是不可能得到这个 JSON 数据?

我也尝试过 YQL 来获取数据,但也遇到了安全问题。

谢谢,

克里斯

4

2 回答 2

1

根据我在 Calgary 上使用 JSON Web Services 插件的经验,ServiceNow 不支持 JSONP,仅支持 JSON。

您可能需要构建一个自定义的脚本化 Web 服务来获得正确的格式。我也没有看到 JSONP 在都柏林出现。

链接示例: https://<instance>.service-now.com/<table>.do?JSON&sysparm_action=getRecords&displayvalue=true

displayvalue=true将参考字段的 sys_id 交换为人性化的替代方案。

要访问数据结构,很简单:

function callMe() {

  $.getJSON('url.json', function(myData) {

    for (n = 0; n < myData.records.length; n++) {
      console.log(myData.records[n].<column1> + '\n' +
                myData.records[n].<column2> + '\n' +
                myData.records[n].<column3> + '\n' +
                myData.records[n].<column4> + '\n\n'
               );
    }
  });
};

您最好使用 CMS/jelly 来制作此列表。

于 2014-03-17T19:57:01.893 回答
0

也许你应该尝试$.ajax({});而不是$.getSrript();做跨域,例如$.ajax({url: "your_url.php",dataType; "jsonp",success: function(data){ document.write(data);} });

于 2013-07-02T21:42:46.443 回答