成功验证后,使用PHP的Salesforce REST API,INVALID_SESSION_ID

时间:2016-01-21 07:15:18

标签: php curl salesforce

我将我的网络应用程序连接到salesforce并成功完成了Web服务器OAuth流程中的所有步骤,以获取access_token和相关信息: https://developer.salesforce.com/docs/atlas.en-us.api_placeorder.meta/api_placeorder/intro_understanding_web_server_oauth_flow.htm

每个步骤似乎都会返回文档中指定的预期结果集,但是当我尝试使用最终访问令牌发出请求时,我收到错误消息,说明我的会话ID无效。这是我的代码:

    // Execute a request for access_token and related info
    $output = json_decode(curl_exec($ch));
    curl_close($ch);
    var_dump($output);

    // Extract token and instance_url from output
    $sf_url = $output->instance_url . '/services/data/v35.0/';
    $sf_auth = 'Bearer ' . $output->access_token;

    // Execute a new cURL request with auth values
    $ci = curl_init();
    curl_setopt($ci, CURLOPT_URL, $sf_url);
    curl_setopt($ci, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ci, CURLOPT_HTTPHEADER, array(
        'Accept' => '*/*',
        'Authorization' => $sf_auth,
        'X-PrettyPrint' => 1
    ));

    $output2 = curl_exec($ci);
    curl_close($ci);
    var_dump($output2);

来自$ output的转储给出:

object(stdClass)#194 (7) { 
["access_token"]=> string(112) "xxxxxxxxxxxxxxxx" 
["signature"]=> string(44) "xxxxxxxxxxxxxx" 
["scope"]=> string(3) "api" 
["instance_url"]=> string(27) "https://cs10.salesforce.com" 
["id"]=> string(68) "https://test.salesforce.com/id/xxxxx/xxxxx"
["token_type"]=> string(6) "Bearer" 
["issued_at"]=> string(13) "1453358xxxxxx" }

$ output2的转储给出:

string(75) "[{"message":"Session expired or invalid","errorCode":"INVALID_SESSION_ID"}]"

非常感谢任何帮助。

*更新*

我也尝试过使用username-password auth flow,我得到了相同的结果。我可以获得访问令牌,但我无法查询数据库,并且返回的错误与INVALID_SESSION_ID相同。

我使用了Postman插件进行chrome,传递了用户名密码流的所有相同信息,并且它可用于进行查询。我不确定不同的做法,似乎传递的所有数据都是一样的。

1 个答案:

答案 0 :(得分:0)

我找到了答案,我使用了错误的语法来设置curl标头。我试图将值作为关联数组传递,但正确的方法是这样的:

curl_setopt($ci, CURLOPT_HTTPHEADER, array(
    'Accept: application/json',
    'Authorization:' . $sf_auth,
    'X-PrettyPrint:1'
));