Compartilhar via


Como especificar o tipo de credencial do cliente

Depois de definir um modo de segurança (transporte ou mensagem), você terá a opção de definir o tipo de credencial do cliente. Essa propriedade especifica que tipo de credencial o cliente deve fornecer ao serviço para autenticação. Para obter mais informações sobre como definir o modo de segurança (uma etapa necessária antes de definir o tipo de credencial do cliente), consulte Como definir o modo de segurança.

Para definir o tipo de credencial do cliente no código

  1. Crie uma instância do vínculo que o serviço usará. Este exemplo usa a WSHttpBinding associação.

  2. Defina a Mode propriedade como um valor apropriado. Este exemplo usa o modo mensagem.

  3. Defina a ClientCredentialType propriedade como um valor apropriado. Este exemplo o define para usar a autenticação do Windows (Windows).

    ServiceHost myServiceHost = new ServiceHost(typeof(CalculatorService));
    // Create a binding to use.
    WSHttpBinding binding = new WSHttpBinding();
    binding.Security.Mode = SecurityMode.Message;
    binding.Security.Message.ClientCredentialType =
        MessageCredentialType.Windows;
    
    Dim myServiceHost As New ServiceHost(GetType(CalculatorService))
    ' Create a binding to use.
    Dim binding As New WSHttpBinding()
    binding.Security.Mode = SecurityMode.Message
    binding.Security.Message.ClientCredentialType = _
    MessageCredentialType.Windows
    

Para definir o tipo de credencial do cliente na configuração

  1. Adicione um <elemento system.serviceModel> ao arquivo de configuração.

  2. Como um elemento filho, adicione um <elemento de associações> .

  3. Adicione uma associação apropriada. Este exemplo usa o <elemento wsHttpBinding> .

  4. Adicione um <elemento de associação> e defina o name atributo como um valor apropriado. Este exemplo usa o nome "SecureBinding".

  5. Adicione uma <security> associação. Defina o mode atributo como um valor apropriado. Este exemplo o define como "Message".

  6. Adicione um elemento <message> ou <transport>, conforme determinado pelo modo de segurança. Defina o clientCredentialType atributo como um valor apropriado. Este exemplo usa "Windows".

    <system.serviceModel>
      <bindings>
        <wsHttpBinding>
          <binding name="SecureBinding">
            <security mode="Message">
                 <message clientCredentialType="Windows" />
             </security>
          </binding>
        </wsHttpBinding>
      </bindings>
    </system.serviceModel>
    

Consulte também