HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“默认”。
Posted
技术标签:
【中文标题】HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“默认”。【英文标题】:The HTTP request is unauthorized with client authentication scheme 'Anonymous'. The authentication header received from the server was 'default'.' 【发布时间】:2021-12-27 12:11:14 【问题描述】:我正在通过编写 API 自动化。 MStest 框架。我试图自动化的 wsdl 需要 Kerberos 身份验证。即使我提供了 client_Id、client_secret 和用户/通过身份验证,我仍然收到 401 未经授权的错误。由于我是新手,我可能会在这里问一些愚蠢的问题,但到目前为止我没有得到任何答案。
异常:“HTTP 请求未经授权,客户端身份验证方案为‘匿名’。从服务器接收到的身份验证标头为‘默认’。”
内部异常:“远程服务器返回错误:(401) Unauthorized.”
''' [测试方法]
public void GetUsers()
APIClient= new AutoStudioFW.APIService.APIServiceclient();
System.Net.ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;
System.Net.ServicePointManager.ServerCertificateValidationCallback = delegate return true; ;
APIClient.ClientCredentials.UserName.UserName = "userabc";
APIClient.ClientCredentials.UserName.Password = "passabc";
_httpRequestProperty = new HttpRequestMessageProperty();
_httpRequestProperty.Headers[System.Net.HttpRequestHeader.Authorization] = "Basic " + Convert.ToBase64String(Encoding.ASCII.GetBytes(APIClient.ClientCredentials.UserName.UserName + ":" + OrionAPIClient.ClientCredentials.UserName.Password));
_httpRequestProperty.Headers.Add("client_id", "01ab34cd");
_httpRequestProperty.Headers.Add("client_secret", "abc123secret");
scope = new System.ServiceModel.OperationContextScope(APIClient.InnerChannel);
System.ServiceModel.OperationContext.Current.OutgoingMessageProperties[HttpRequestMessageProperty.Name] = _httpRequestProperty;
var GetUser = APIClient.getCurrentUser("555");
【问题讨论】:
【参考方案1】:您可以尝试在配置中设置安全模式:
<security mode="TransportCredentialOnly">
<transport clientCredentialType="Windows" proxyCredentialType="None" realm="" />
<message clientCredentialType="UserName" algorithmSuite="Default" />
</security>
WCFTestClient The HTTP request is unauthorized with client authentication scheme 'Anonymous'
【讨论】:
以上是关于HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“默认”。的主要内容,如果未能解决你的问题,请参考以下文章
HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“默认”。
HTTP 请求未经客户端身份验证方案“匿名”授权。从服务器收到的身份验证标头是“基本领域”
WCF-TransportWithMessageCredential HTTP 请求未经授权,客户端身份验证方案“匿名”