SalesForce REST API PHP,无法查看上传的附件

时间:2015-03-25 16:39:49

标签: php rest salesforce

我正在尝试使用我已成功完成的REST API将附件添加到特定案例中。

正在将文件上传到该特定情况。我正在使用base64_encode将二进制数据发送到SalesForce,因为它们需要发送二进制数据。

但问题是,当我在销售人员控制面板中看到文件时, 所有文件都列在那里,大小正确,名称正确等 但是当我查看/下载随脚本上传的任何文件时,它都没有打开。该文件显示错误。 即。当我使用其余的API上传png图像时,我无法在从销售人员控制面板下载后打开图像。

任何人都可以帮忙吗? 我认为销售人员可能无法从base64_encode解码上传的文件,是吗?

提前致谢

这是代码

$fp = fopen($file, 'r');
$db_img = fread($fp, filesize($file));
$db_img = addslashes($db_img);
$db_img = base64_encode($db_img);

然后在编码后我在body元素中连接$ db_img,就像这样

...................

...'.$db_img.'...

.................;

1 个答案:

答案 0 :(得分:0)

我自己想通了。我想我也应该发布答案。我使用以下函数将附件添加到Case对象。

根本不需要转换为base64

public function add_attachment($case_id, $full_file_path, $file_name) {
    $url = $this->instance_url."/services/data/v33.0/chatter/feed-elements";

    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST");



    $headers = array();
    $headers[] = "Authorization: OAuth $this->access_token";
    $headers[] = 'Content-Type: multipart/form-data; boundary=a7V4kRcFA8E79pivMuV2tukQ85cmNKeoEgJgq';

    $post_text = '--a7V4kRcFA8E79pivMuV2tukQ85cmNKeoEgJgq
    Content-Disposition: form-data; name="json"
    Content-Type: application/json; charset=UTF-8

    {
       "body":{
          "messageSegments":[
             {
                "type":"Text",
                "text":"Task Attachment"
             }
          ]
       },
       "capabilities":{
          "content":{
             "description":"Task Attachment",
             "title":"'.$file_name.'"
          }
       },
       "feedElementType":"FeedItem",
       "subjectId":"'.$case_id.'"
    }

    --a7V4kRcFA8E79pivMuV2tukQ85cmNKeoEgJgq
    Content-Disposition: form-data; name="feedElementFileUpload"; filename="'.$file_name.'"
    Content-Type: image/png

    '. file_get_contents($full_file_path).'

    --a7V4kRcFA8E79pivMuV2tukQ85cmNKeoEgJgq--';

    curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
    curl_setopt($curl, CURLOPT_POST, true);
    curl_setopt($curl, CURLOPT_VERBOSE, 1);
    curl_setopt($curl, CURLOPT_POSTFIELDS, $post_text);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLINFO_HEADER_OUT, true);

    $response_json = curl_exec($curl);
    $status = curl_getinfo($curl, CURLINFO_HTTP_CODE);
    //print_r($info);

    if ( $status != 201 ) {
        $this->errors[] = "Error: call to URL $url failed with status $status, response $json_response, curl_error " . curl_error($curl) . ", curl_errno " . curl_errno($curl);         
        return FALSE;
    }
    $this->status = $status;
    $this->curl_error = curl_error($curl);
    $this->curl_errno = curl_errno($curl);
    return  json_decode($response_json,TRUE);

}