2017-02-21 50 views
0

我已经按照PM文档(http://wiki.processmaker.com/3.1/OAuth_2.0)中的教程进行了操作,并且没有成功访问访问令牌。 目前我正在使用PM的试用版,我想访问我的Java应用程序js文件中的API,但浏览器返回以下错误“XMLHttpRequest无法加载'myPMServerAddress'已被CORS策略阻止: Access-Control-Allow-Origin'标题出现在所请求的资源上,因此'http://localhost:8100'不允许访问'“。从外部应用程序访问ProcessMaker BPM框架的API

任何帮助? 我注册的(用户应用程序 - > +新)网站盒子内我的应用程序服务器(http://localhost:8100)的形式和我的代码看起来如下:

var restServer = 'https://trial.processmaker.com/'; 
var workspace = 'sysmyWorkspace/'; 
var jqxhr = $.ajax({ 
    type: "POST", 
    url: restServer + workspace + 'oauth2/token',  
     data: { 
     grant_type : 'password', 
     scope  : '*', 
     client_id : 'myClientId', 
     client_secret: 'myClientSecret', 
     username  : 'admin', 
     password  : 'myPassword' 
    } 
}) 
    .done(function(data) { 
     if (data.error) { 
      alert("Error in login!\nError: " + data.error + "\nDescription: " + data.error_description); 
     } 
     else if (data.access_token) {     
      alert("data access token received!");    
      var d = new Date(); 
      d.setTime(d.getTime() + 60*60*1000); 
      document.cookie = "access_token=" + data.access_token + "; expires=" + d.toUTCString(); 
      document.cookie = "refresh_token=" + data.refresh_token; //refresh token doesn't expire 
     } 
     else { 
      alert(JSON.stringify(data, null, 4)); 
     } 
    }) 
    .fail(function(data, statusText, xhr) { 
     alert("Failed to connect.\nHTTP status code: " + xhr.status + ' ' + statusText); 
    });  
}); 
+0

解决方案:虽然PM的工作人员表示这是他们试用版服务器上的安全问题,但我发现这是工作区中的错误。 https://trial.processmaker.com/sysmyWorkspace/oauth2/token是我想要达到的地址,但我应该从工作空间中删除'sys'并使用https://trial.processmaker.com/myWorkspace/oauth2 /令牌 – chri3g91

+0

啊,这解决了你的问题?有趣。 –

回答

0

您需要在客户端禁用CORS

Ubuntu的: 谷歌铬 - 禁用网络安全的user-data-dir的

为Windows女士: 进入到命令提示符,进入其中的chrome.exe是文件夹,然后键入

chrome.exe - 禁用网络安全

我可以测试没有错误。

相关问题