Microsoft Dynamics CRM - Layanan Web
Microsoft Dynamics CRM menyediakan dua layanan web penting yang digunakan untuk mengakses CRM dari aplikasi eksternal dan memanggil metode web untuk melakukan operasi data bisnis umum seperti membuat, menghapus, memperbarui, dan menemukan di CRM.
Pertimbangkan skenario berikut -
Anda memiliki aplikasi .NET eksternal, yang perlu berbicara dengan CRM. Misalnya, Anda mungkin ingin menyisipkan catatan Kontak di CRM saat pelanggan baru terdaftar di aplikasi eksternal Anda.
Atau mungkin, Anda ingin mencari catatan di CRM dan menampilkan hasil pencarian di aplikasi eksternal Anda.
Dalam skenario seperti itu, Anda dapat menggunakan layanan web yang diekspos oleh CRM untuk menggunakannya dalam aplikasi Anda dan melakukan operasi buat, hapus, perbarui, dan temukan di CRM.
Layanan Web IDiscoveryService
Layanan web ini mengembalikan daftar organisasi tempat pengguna tertentu berada dan titik akhir URL untuk setiap organisasi.
Layanan Web IOrganizationService
Layanan web ini adalah layanan web utama yang digunakan untuk mengakses data dan metadata di CRM. IOrganizationService menggunakan dua rakitan penting -Microsoft.Xrm.Sdk.dll dan Microsoft.Crm.Sdk.Proxy.dll. Rakitan ini dapat ditemukan dalam paket CRM SDK di dalamBin map.
Microsoft.Xrm.Sdk.dll
Rakitan ini menentukan metode dan jenis xRM inti, termasuk kelas proxy untuk membuat sambungan ke Microsoft Dynamics CRM lebih sederhana, metode otentikasi, dan kontrak layanan.
Microsoft.Crm.Sdk.Proxy.dll
Majelis ini mendefinisikan permintaan dan tanggapan untuk pesan non-inti serta pencacahan yang diperlukan untuk bekerja dengan data organisasi. Berikut adalah namespace yang didukung oleh dua majelis ini.
Masing-masing rakitan ini mendukung pesan tertentu, yang akan digunakan untuk bekerja dengan data yang disimpan di entitas mana pun. Daftar lengkap pesan yang didukung oleh mereka dapat ditemukan di tautan berikut -
Supported xRM Messages - https://msdn.microsoft.com/en-us/library/gg334698.aspx
Supported CRM Messages - https://msdn.microsoft.com/en-us/library/gg309482.aspx
Metode Layanan Web IOrganizationService
Itu IOrganizationService menyediakan delapan metode yang memungkinkan Anda melakukan semua operasi umum pada sistem dan entitas kustom serta metadata organisasi.
Sr Tidak | Metode & Deskripsi |
---|---|
1 | IOrganizationService.Create Membuat rekor. |
2 | IOrganizationService.Update Memperbarui catatan yang sudah ada. |
3 | IOrganizationService. Retrieve Mengambil rekaman. |
4 | IOrganizationService. RetrieveMultiple Mengambil koleksi catatan. |
5 | IOrganizationService. Delete Menghapus record. |
6 | IOrganizationService. Associate Membuat link antar record. |
7 | IOrganizationService.Disassociate Menghapus link antar record. |
8 | IOrganizationService.Execute Digunakan untuk pemrosesan rekaman umum serta pemrosesan khusus seperti resolusi kasus, deteksi duplikat, dll. |
Contoh Layanan Web
Untuk memahami bagaimana layanan web bekerja di CRM, kita akan melihat contoh yang diberikan oleh CRM SDK. Dalam contoh ini, kami akan membuat rekaman Akun baru, memperbaruinya, dan akhirnya menghapusnya menggunakan CRMIOrganizationService layanan web.
Step 1- Buka folder tempat Anda mengekstrak CRM SDK. Sekarang buka solusi QuickStartCS.sln dengan menjelajahi lokasi berikut: SDK \ SampleCode \ CS \ QuickStart
Step 2 - Kami akan menjelajahi QuickStart dengan Simplified Connectionproyek. Bukaapp.configdalam proyek ini. Secara default, fileconnectionStrings bagian dalam file ini akan diberi komentar.
Dari ini, hapus komentar kunci string koneksi pertama dan edit tiga detail berikut -
Url- Tentukan URL instance CRM Anda. Dalam kasus kami, karena kami menggunakan versi online CRM, Anda harus menyebutkan URL itu.
Username - Nama pengguna CRM Online Anda.
Password - Kata sandi CRM Online Anda.
Step 3 - Buka SimplifiedConnection.cs mengajukan dalam proyek ini dan Runmethod di dalamnya.
public void Run(StringconnectionString, boolpromptforDelete) {
try {
// Establish a connection to the organization web service using CrmConnection.
Microsoft.Xrm.Client.CrmConnection connection =
CrmConnection.Parse(connectionString);
// Obtain an organization service proxy.
// The using statement assures that the service proxy will be properly disposed.
using(_orgService = new OrganizationService(connection)) {
//Create any entity records this sample requires.
CreateRequiredRecords();
// Obtain information about the logged on user from the web service.
Guid userid = ((WhoAmIResponse)_orgService.Execute(new WhoAmIRequest())).UserId;
SystemUser systemUser = (SystemUser)_orgService.Retrieve("systemuser",userid,
new ColumnSet(newstring[]{"firstname","lastname"}));
Console.WriteLine("Logged on user is {0} {1}.",
systemUser.FirstName,systemUser.LastName);
// Retrieve the version of Microsoft Dynamics CRM.
RetrieveVersionRequest versionRequest = new RetrieveVersionRequest();
RetrieveVersionResponse versionResponse =
(RetrieveVersionResponse)_orgService.Execute(versionRequest);
Console.WriteLine("Microsoft Dynamics CRM version {0}.",
versionResponse.Version);
// Instantiate an account object. Note the use of option set
enumerations defined in OptionSets.cs.
// Refer to the Entity Metadata topic in the SDK documentation to
determine which attributes must
// be set for each entity.
Account account = new Account{Name = "Fourth Coffee"};
account.AccountCategoryCode = new OptionSetValue(
(int)AccountAccountCateg oryCode.PreferredCustomer);
account.CustomerTypeCode = new OptionSetValue(
(int)AccountCustomerTypeCod e.Investor);
// Create an account record named Fourth Coffee.
_accountId = _orgService.Create(account);
Console.Write("{0} {1} created, ",account.LogicalName,account.Name);
// Retrieve the several attributes from the new account.
ColumnSet cols = new ColumnSet(
new String[]{"name","address1_postalcode","lastusedincampaign"});
Account retrievedAccount =
(Account)_orgService.Retrieve("account", _accountId, cols);
Console.Write("retrieved, ");
// Update the postal code attribute.
retrievedAccount.Address1_PostalCode = "98052";
// The address 2 postal code was set accidentally, so set it to null.
retrievedAccount.Address2_PostalCode = null;
// Shows use of a Money value.
retrievedAccount.Revenue = new Money(5000000);
// Shows use of a Boolean value.
retrievedAccount.CreditOnHold = false;
// Update the account record.
_orgService.Update(retrievedAccount);
Console.WriteLine("and updated.");
// Delete any entity records this sample created.
DeleteRequiredRecords(promptforDelete);
}
}
// Catch any service fault exceptions that Microsoft Dynamics CRM throws.
catch(FaultException<microsoft.xrm.sdk.organizationservicefault>) {
// You can handle an exception here or pass it back to the calling method.
throw;
}
}
Step 4- Metode ini pada dasarnya mendemonstrasikan semua operasi CRUD menggunakan layanan web CRM. Kode pertama membuat instance organisasi, lalu membuat catatan Akun, memperbarui catatan yang dibuat dan akhirnya menghapusnya. Mari kita lihat komponen penting dari kode ini. Untuk melihat perubahan saat dalam perjalanan di CRM saat kode ini berjalan, Anda dapat men-debug kode ini selangkah demi selangkah (seperti yang kita bahas di bawah) dan sekaligus melihat perubahan di CRM.
Step 4.1 - Menetapkan koneksi ke organisasi menggunakan string koneksi yang telah kami modifikasi Step 2.
Microsoft.Xrm.Client.CrmConnection connection = CrmConnection.Parse(connectionString);
Step 4.2 - Mendapatkan instance proxy dari layanan web organisasi CRM.
_orgService = new OrganizationService(connection)
Step 4.3 - Membuat objek entitas Akun baru dan menetapkan Namanya, AccountCategoryCode, dan CustomerTypeCode.
Account account = new Account{Name = "Fifth Coffee"};
account.AccountCategoryCode = new OptionSetValue(
(int)AccountAccountCategoryCode.P referredCustomer);
account.CustomerTypeCode = new OptionSetValue(
(int)AccountCustomerTypeCode.Investor);
Step 4.4 - Membuat rekaman baru menggunakan metode Buat layanan organisasi.
_accountId = _orgService.Create(account);
Jika Anda menavigasi ke CRM, Anda akan melihat catatan akun yang baru dibuat.
Step 4.5 - Setelah akun dibuat, layanan mengambil kembali catatan dari CRM menggunakan metode Retrieve web service.
ColumnSet cols = new ColumnSet(new String[]{
"name","address1_postalcode","lastusedincampaign"});
Account retrievedAccount =
(Account)_orgService.Retrieve("account", _accountId, cols);
Step 4.6 - Setelah Anda memiliki catatan yang diambil, Anda dapat mengatur nilai catatan yang diperbarui.
retrievedAccount.Address1_PostalCode = "98052";
retrievedAccount.Address2_PostalCode = null;
retrievedAccount.Revenue = new Money(5000000);
retrievedAccount.CreditOnHold = false;
Step 4.7 - Setelah mengatur nilai terbaru dari record, perbarui record kembali ke database CRM menggunakan metode Update web service.
_orgService.Update(retrievedAccount);
Jika Anda membuka catatan di CRM, Anda akan melihat nilai-nilai ini diperbarui di sana.
Step 4.8 - Terakhir, hapus data menggunakan metode Hapus layanan web.
_orgService.Delete(Account.EntityLogicalName, _accountId);
Jika Anda sekarang menyegarkan rekaman yang sama di CRM, Anda akan melihat bahwa rekaman tidak lagi tersedia karena sudah dihapus.
Kesimpulan
Dalam bab ini, kami membahas dua layanan web penting yang disediakan oleh CRM dan contoh kerja tentang bagaimana layanan web ini dapat digunakan dari aplikasi eksternal untuk melakukan berbagai operasi CRUD.