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