Возможно ли назвать Dynamics CRM 2011 с поздней привязкой службы организации WCF без SDK - прямая настраиваемая привязка? - PullRequest
50 голосов
/ 21 июля 2011

Я пытаюсь реализовать чистый сценарий WCF, в котором я хочу вызвать Служба WCF Dynamics CRM без использования вспомогательных классов SDK. По сути, я хотел бы реализовать федеративную аутентификацию для Dynamics CRM 2011 , используя только встроенную поддержку WCF из .net framework.

Причина, по которой я это делаю, заключается в том, что я хотел бы позже перенести этот сценарий на BizTalk.

Я успешно сгенерировал прокси-классы с помощью SvcUtil, но часть политик и утверждений безопасности не совместима со схемой конфигурации. SvcUtil предлагает вместо этого создать привязку из кода, что я и пытаюсь сделать.

Полученный код здесь:

        private static void CallWcf()
    {
        OrganizationServiceClient client = null;

        try
        {
            // Login Live.com Issuer Binding

            var wsHttpBinding = new WSHttpBinding();
            wsHttpBinding.Security = new WSHttpSecurity();
            wsHttpBinding.Security.Mode = SecurityMode.Transport;

            // Endpoint Binding Elements

            var securityElement = new TransportSecurityBindingElement();
            securityElement.DefaultAlgorithmSuite = SecurityAlgorithmSuite.TripleDes;
            securityElement.IncludeTimestamp = true;
            securityElement.KeyEntropyMode = SecurityKeyEntropyMode.CombinedEntropy;
            securityElement.MessageSecurityVersion = MessageSecurityVersion.WSSecurity11WSTrust13WSSecureConversation13WSSecurityPolicy12BasicSecurityProfile10;
            securityElement.SecurityHeaderLayout = SecurityHeaderLayout.Strict;

            var securityTokenParameters = new IssuedSecurityTokenParameters();
            securityTokenParameters.InclusionMode = SecurityTokenInclusionMode.AlwaysToRecipient;
            securityTokenParameters.ReferenceStyle = SecurityTokenReferenceStyle.Internal;
            securityTokenParameters.RequireDerivedKeys = false;
            securityTokenParameters.TokenType = null;
            securityTokenParameters.KeyType = SecurityKeyType.SymmetricKey;
            securityTokenParameters.KeySize = 192;
            securityTokenParameters.IssuerAddress = new EndpointAddress("https://login.live.com/extSTS.srf");
            securityTokenParameters.IssuerMetadataAddress = null;
            securityTokenParameters.DefaultMessageSecurityVersion = null;
            securityTokenParameters.IssuerBinding = wsHttpBinding;

            securityElement.EndpointSupportingTokenParameters.Signed.Add(securityTokenParameters);

            var textMessageEncodingElement = new TextMessageEncodingBindingElement();
            textMessageEncodingElement.MaxReadPoolSize = 64;
            textMessageEncodingElement.MaxWritePoolSize = 16;
            textMessageEncodingElement.MessageVersion = MessageVersion.Default;
            textMessageEncodingElement.WriteEncoding = System.Text.Encoding.UTF8;

            textMessageEncodingElement.ReaderQuotas.MaxStringContentLength = 8192;
            textMessageEncodingElement.ReaderQuotas.MaxArrayLength = 16384;
            textMessageEncodingElement.ReaderQuotas.MaxBytesPerRead = 4096;
            textMessageEncodingElement.ReaderQuotas.MaxNameTableCharCount = 16384;

            var httpsTransportElement = new HttpsTransportBindingElement();
            httpsTransportElement.ManualAddressing = false;
            httpsTransportElement.AuthenticationScheme = System.Net.AuthenticationSchemes.Anonymous;

            CustomBinding binding = new CustomBinding();
            binding.Elements.Add(securityElement);
            binding.Elements.Add(textMessageEncodingElement);
            binding.Elements.Add(httpsTransportElement);

            client = new OrganizationServiceClient(binding, new EndpointAddress(EndpointUri));
            client.ClientCredentials.UserName.UserName = Username;
            client.ClientCredentials.UserName.Password = Password;
            client.Open();

            var columnSet = new schemas.microsoft.com.xrm._2011.Contracts.ColumnSet();
            var identifier = new Guid("fbf8240e-2c85-e011-ad55-1cc1de0878eb");

            columnSet.Columns = new string[] { "name" };
            var entity = client.Retrieve("account", identifier, columnSet);
        }

        finally
        {
            if (client != null)
                client.Close();
        }
    }

Я новичок в федеративной аутентификации и с трудом выясняю потенциальные различия между многими доступными привязками, поэтому я был бы признателен за любую помощь в этом отношении.

1 Ответ

2 голосов
/ 29 января 2014

Это возможно, но чрезвычайно сложно.У нас был проект с использованием Dynamics, который был перенесен в ADFS, и требовалось добавить много дополнительного кода вокруг обновления токенов (код формы autorefreshsecuritytoken.cs, deviceidmanager.cs и toolserviceproxies.cs из SDK), и он все еще использовал SDK для всего.

Имейте в виду, что вам также необходимо установить windows.identification в ОС, что является еще одним набором функций для копирования.

В конце вы всегда можете просто использовать JustDecompile или аналогичный, чтобы увидеть, что такое SDKделает.

...