Bitrix24 CRM haben webhook functional Leads (Clients) zu CRM hinzuzufügen. Die gesamte Dokumentation ist auf PHP geschrieben, aber ich möchte ASP.NET verwenden. Hier ist, wie sie tun es auf php:Bitrix24 REST-API Post-Anforderung mit ASP.NET
$queryUrl = 'https://restapi.bitrix24.ru/rest/1/31uhq2q855fk1foj/crm.lead.add.json';
$queryData = http_build_query(array(
'fields' => array(
"TITLE" => "NEW LEAD"
),
'params' => array(
"REGISTER_SONET_EVENT" => "Y"
)
));
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_SSL_VERIFYPEER => 0,
CURLOPT_POST => 1,
CURLOPT_HEADER => 0,
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_URL => $queryUrl,
CURLOPT_POSTFIELDS => $queryData
));
$result = curl_exec($curl);
curl_close($curl);
$result = json_decode($result, 1);
Ich versuche, die gleiche Sache mit ASP.NET zu tun, aber Fehler 400 als Antwort bekommen. Ich bin mir fast sicher, dass das Problem in den Anfrageparametern, Zeile const string data = @"[{""fields"":{""title"":""Test""}}]";
, liegt. Ich habe Tonnen von Kombinationen ausprobiert, aber nichts hat funktioniert.
const string url = @ "https://companyname.bitrix24.ru/rest/14/31uhq2q855fk1foj/crm.lead.add.json";
const string data = @"[{""fields"":{""title"":""Test""}}]";
HttpClient client = new HttpClient();
client.BaseAddress = new Uri(url);
byte[] cred = Encoding.UTF8.GetBytes("email:password");
client.DefaultRequestHeaders.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Basic", Convert.ToBase64String(cred));
client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json"));
HttpContent content = new StringContent(data, Encoding.UTF8, "application/json");
HttpResponseMessage messge = client.PostAsync(url, content).Result;
string description;
if (messge.IsSuccessStatusCode) {
string result = messge.Content.ReadAsStringAsync().Result;
description = result;
}
Vielen Dank für diese Antwort Eine Sache: Ich musste 'params' in' @params' ändern weil es ein Schlüsselwort ist.Alles andere hat gut funktioniert :) – randomsuffer
Hoppla, ja. Entschuldigung, ich habe in meiner Quelle nach anderen Methoden gesucht und Code "per Beispiel" direkt in SO-Antwort geschrieben. Meine Antwort wurde korrigiert. – Dmitry