2017-09-01 112 views
0

这是我第一次与Epicor一起使用Prophet 21。我很难弄清楚在用户帐户进行身份验证后如何在HTTP请求头中传递令牌。将标头传递给Prophet 21 API

https://localhost:4443/api/security/token/?username= {USERNAME} &密码= {} PASSWORD

返回令牌,但我不知道什么是请求头应设置。我曾尝试令牌,的accessToken,以及很多其他的组合,但我总是收到此消息:

<TokenError xmlns:i="http://www.w3.org/2001/XMLSchema-instance"> 
    <Description>Token Validation Exception Occured</Description> 
    <Error>invalid_request</Error> 
    <Uri/> 
</TokenError> 

这里是我想要一个例子:

https://localhost:4443/api/inventory/v2/parts/

Token = token eoWffZR0PlReRLwHopOTNSoBccwj96VSkjGYX2QnGdLjqY10mREmjwh4GDXqpf7HBBHrFImN3T4RtHEPjBK+VQ5EniquqnBbOAvlzf+5amV3rKDB67w5XbyoOzD2YSiFOULoRRY2Iaxe7pAy5JaWQ== 

Token = eoWffZR0PlReRLwHopOTNSoBccwj96VSkjGYX2QnGdLjqY10mREmjwh4GDXqpf7HBBHrFImN3T4RtHEPjBK+VQ5EniquqnBbOAvlzf+5amV3rKDB67w5XbyoOzD2YSiFOULoRRY2Iaxe7pAy5JaWQ== 

我不会包含更多的例子,但我尝试了各种组合。我也回顾了非常无用的SDK文档。例如,这里是JavaScript代码示例,但它包含的功能不在文档中,因此我无法了解它是如何构建请求的。

<script type="text/javascript"> 
    var gToken; 

    function getTokenUI(){ 
     var userName = $('#name').val(); 
     var passWord = $('#password').val(); 
     var jsonToken = getToken(userName, passWord) 
     gToken = jsonToken.AccessToken 
     $('#return ul').append('<li>' + gToken + '</li>'); 
    } 

    function getOppUI() { 
     var oppID = $('#oppid').val(); 
     var xhr = ajaxRequest("GET", OppResourceURL(oppID), null, "json", gToken); 
     $('#restreturn ul').append('<li>' + xhr.responseText + '</li>'); 

     var jsonObj = $.parseJSON(xhr.responseText); 

     $.each(jsonObj, function(key, val) { 
      $('body').append('<div>' + key + ": " + val + '</div>'); 
     }); 
    } 
</script> 

我基本上寻找一些结构头的帮助,所以我可以发送令牌。我想使用Laravel PHP框架来做到这一点。

预先感谢您为此付出的时间和协助。

回答

0

所以事实证明,这个认证是非常标准的,我刚刚被文档中的Token引用抛弃了。

设置授权=承载{令牌}起作用。