PHP curl 与 Microsoft Dynamics CRM 2011 对话

标签 php rest curl dynamics-crm odata

我正在尝试从位于远程主机上的 Microsoft Dynamics CRM 2011 Online 提取一些数据; 如果我手动(从浏览器)登录并从在 Linux 主机上运行 PHP 的服务器执行我的操作,它就可以工作,但是我当然想在没有我的中介的情况下进行身份验证和运行 CRUD 操作:)。

但它一直显示“对象已移至此处”。页面进行身份验证。 如果我设置 CURLOPT_FOLLOWLOCATION => 1,它会显示 crm 的登录页面。

如果有人可以提出解决问题的任何线索......谢谢!

<?php

$useragent = "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.1) Gecko/20061204 Firefox/2.0.0.1";
$urlValue  = "/LeadSet?$select=Address1_City,FirstName,LastName";

$username  = "domain\user";
$pass      = "pass";


$handle = curl_init();    
curl_setopt_array($handle, 
        array (
            CURLOPT_USERAGENT => $useragent,
            CURLOPT_USERPWD   => $username . ':' . $pass,
            CURLOPT_HTTPAUTH  => CURLAUTH_ANY,
            CURLOPT_SSL_VERIFYPEER => false,
            CURLOPT_SSL_VERIFYHOST => false,
            CURLOPT_URL  => 'https://myhost.com/xrmservices/2011/OrganizationData.svc',
            CURLOPT_POST => 1,
            CURLOPT_POSTFIELDS     => $urlValue,
            CURLOPT_RETURNTRANSFER => true,
        )
);

$response = curl_exec($handle);
curl_close($handle);

header('Content-Type: text/plain;');
print_r($response);

最佳答案

我解决了通过 ntml 进行身份验证的问题,此代码显示了如何以 JSON 格式从 CRM 检索联系人。

$url='http://<server_adress>/organizationName/XRMServices/2011/OrganizationData.svc/ContactSet';
$ch = curl_init();
 $headers = array(
      'Method: GET',
      'Connection: keep-alive',
      'User-Agent: PHP-SOAP-CURL',
      'Content-Type: application/json; charset=utf-8',
      'Accept: application/json',
      'Host <server network adress>');

curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
curl_setopt($ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_NTLM);
curl_setopt($ch, CURLOPT_USERPWD, '<user>:<password>');
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$response = curl_exec($ch);
curl_close($ch);
//echo $response; 
$array=json_decode($response, true);
$size=count($array['d']['results']);
echo "Numero de registos:".$size."<p>";
echo "Contactos:<p>";
for($i=0;$i<$size;$i++){
 echo "Nome: ". $array['d']['results'][$i]['FullName']."<p>";
 echo "Cidade: ". $array['d']['results'][$i]['Address1_City']."<p>";
 echo "Emprego: ". $array['d']['results'][$i]['JobTitle']."<p>";
 echo "Morada: ". $array['d']['results'][$i]['Address1_Name']."<p>";
 echo "Telefone: ". $array['d']['results'][$i]['Address1_Telephone1']."<p>";
 echo "Email: ". $array['d']['results'][$i]['EMailAddress1']."<p>";
 echo "Pais: ". $array['d']['results'][$i]['Address1_Country']."<p>";
 echo "Codigo-postal: ". $array['d']['results'][$i]['Address1_PostalCode']."<p>";
 echo "Criado por: ". $array['d']['results'][$i]['CreatedBy']['Name']."<p>";
 echo "...................................................................................<p>";       
} 

如果有人知道如何在 rest 端点进行 crud 操作,请告诉我。

关于PHP curl 与 Microsoft Dynamics CRM 2011 对话,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10669377/

相关文章:

php - 用于创建组和邀请用户的正确表结构

php - 如何获取链接标签的href内容

node.js - Google CSE REST API : is v1 deprecated, 有 v2 吗?

rest - 检索 ID 集合而不是 REST 中资源的完整表示

php - 客户端-服务器架构决策

python - curl --noproxy "*"相当于 Python 的请求模块

PHP 与 list() 的未定义偏移量

php - 如何验证数据库中是否存在重复记录?

php - 关于向字符串添加数据的基本问题

web-services - 使用分页过滤远程结果