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


SalesForce REST API PHP, Not able to see uploaded Attachment

我正在尝试使用REST API将附件加载到一个特定的案例中,我已经成功完成了这项工作。

文件正在上传到那个特定的案例中。我使用base64_encode向SalesForce发送二进制数据,因为他们需要发送二进制数据。

但问题是,当我看到销售人员控制面板中的文件时,所有文件都列在那里,大小正确,名称正确等等
但当我查看/下载随脚本上传的任何文件时,它都不会打开。该文件显示errror。即,当我用其余的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);

然后在编码之后,我在像这个一样的主体元素中连接$db_img

。。。。。。。。。。。。。。。。。。。…'.$db_img.'。。。。。。。。。。。。。。。。。。。。;

我自己想好了。我想我也应该公布答案。我正在使用以下函数向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);
}