2

我想通过 API 检索任何 salesforce 对象的所有列表视图。怎么做?

4

3 回答 3

4

这是一个老问题,但是,使用 REST API 和 Salesforce 的查询语言,您可以使用端点:

{your instance url}/services/data/v32.0/query?q=SELECT Id,Name FROM {object type}

或者

使用端点:

{your instance url}/services/data/v32.0/sobjects/{object type}/listviews

一些例子:

获取所有列表视图:https ://na16.salesforce.com/services/data/v32.0/query?q= SELECT Id,Name FROM ListView

要获取具有对象类型帐户的所有列表视图:https ://na16.salesforce.com/services/data/v32.0/sobjects/Account/listviews

在 PHP 中:

$url = "{your instance url}/services/data/v32.0/sobjects/Account/listviews";
$headers = array('Authorization: OAuth ' . {your access token});
$ch = curl_init ();  
curl_setopt ( $ch, CURLOPT_URL, $url );  
curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, TRUE );  
curl_setopt ( $ch, CURLOPT_FOLLOWLOCATION, TRUE );  
curl_setopt ( $ch, CURLOPT_HTTPHEADER, $headers);  

$requestBody = curl_exec ($ch);
$result = json_decode($requestBody, true);

当然,您需要先通过 OAUTH 登录以获取访问令牌和实例 URL。

于 2015-04-30T23:33:58.183 回答
1

如果您正在寻找的是 SOAP api,它被称为describeSObject- 用于特定对象,或“describeGlobal” - 用于您组织的所有数据。

有关 SOAP 消息,请参阅下面的参考链接: http://wiki.developerforce.com/page/Sample_SOAP_Messages_(10.0_API)

于 2013-04-25T23:57:13.203 回答
0

为给定对象创建一个StandardSetController(您将用于实例化它的查询可以具有“LIMIT 1”或其他内容,无需选择所有记录)。然后使用getListViewOptions().

请记住,它将返回对当前用户可见的视图(因此只有公共视图+标记为“仅对我可见”的视图)。

编辑: 要从外部访问它(通过 SOAP 或 REST API)...我不知道通过 REST 调用获取这些的方法。您可能需要编写一些 Apex 并公开将返回此数据的自定义 REST 资源。这并不难,有关示例,请参见http://www.salesforce.com/us/developer/docs/apexcode/index_Left.htm#StartTopic=Content/apex_rest_code_sample_basic.htm

于 2012-11-15T07:18:31.727 回答