0

我正在开发一个 Django 1.11 应用程序,作为一些 Salesforce 对象的 UI,用于django-salesforce与 Salesforce 进行通信。

我必须让用户选择从与其联系人相关的 Salesforce 附件对象下载文件。

# Django Attachment model on my_app/models.py

...

class Attachment(models.Model):
    parent = models.ForeignKey(Contact, models.DO_NOTHING,
                               sf_read_only=models.NOT_UPDATEABLE)
    name = models.CharField(max_length=255, verbose_name='File Name')
    content_type = models.CharField(max_length=120, blank=True, null=True)
    body_length = models.IntegerField(sf_read_only=models.READ_ONLY)
    body = models.TextField()

...

在这个附件模型上,我可以访问字段上文件内容的其余 URL body,但不能访问实际内容。

有没有一种方法可以从附件中获取文件内容,而不必为此实现 OAuth 客户端?

4

2 回答 2

1

a)由 REST API 封装的请求handle_api_exceptions

from salesforce.backend.driver import handle_api_exceptions
# from salesforce.dbapi.driver import handle_api_exceptions  # can be changed soon to this
from django.db import connections

session = connections['salesforce'].sf_session
rows = Attachment.objects.filter(...)
for row in rows:
    url = session.auth.instance_url + row.body
    blob = handle_api_exceptions(url, session.get).text

B)您可以通过以下方式获取 SOAP 客户端(需要 Beatbox)

from salesforce.utils import get_soap_client
import base64

soap = get_soap_client('salesforce')
for ...:
    ret = soap.query("SELECT Body FROM Attachment WHERE Id = '...'")
    blob = base64.b64decode(ret)[0]['Body'])

有用的相关答案是:

编辑我希望您的意思是用户 = 一些联系人,而不是与具有某种形式的付费许可证的 SFDC 对象用户相关的联系人。出于安全原因,它们只能通过您的站点下载,而不是直接下载。任何 OAuth 都可能无法改进它。

于 2017-09-05T10:38:58.117 回答
0

Salesforce 有一个专用端点来流式传输文件 blob

{{endpoint}}/services/data/v{{version}}/connect/files/{{file_id}}/content

参数:

  1. 端点:实例 URL
  2. 版本:API版本
  3. file_id: contentDocument 记录id
于 2021-01-08T04:33:48.740 回答