13

我正在使用 Windows 应用程序中的 WSDL 来使用 Web 服务。当我尝试使用方法时,出现以下错误:-

HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“”

{“远程服务器返回错误:(401) Unauthorized.”}

我有用户凭据,但不知道如何在 Windows 应用程序中使用 c# 代码传递它。

4

2 回答 2

13

这是它对我的工作方式:-

配置文件设置如下所示:-

<configuration>
    <system.serviceModel>
        <bindings>
          <basicHttpBinding>
            <binding name="bindingName"  >
              <security mode="TransportCredentialOnly">
                <transport clientCredentialType="Basic" proxyCredentialType="None" realm=""/>
                <message clientCredentialType="UserName" algorithmSuite="Default"/>
              </security>
            </binding>

          </basicHttpBinding>
        </bindings>
        <client>
            <endpoint address="http://10.10.10.10:1880/testpad/services/Testwebservice"
                binding="basicHttpBinding" bindingConfiguration="bindingName"
                contract=testService.GetData" name="test_Port1" />
        </client>
    </system.serviceModel>
</configuration>

在这里我传递用户凭据:-

 var ser = new GetDataClient();
 ser.ClientCredentials.UserName.UserName = "userid";
 ser.ClientCredentials.UserName.Password = "Pa$$word1";
于 2013-06-13T17:52:25.730 回答
0

您可以尝试使用此处提到的方法生成您的服务客户端代理。一旦有了 WCF 客户端代理的实例,它就会有一个属性ClientCreditials,您可以根据需要填充该属性。希望这可以帮助。

于 2013-06-10T20:25:05.243 回答