【发布时间】: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");
}
【问题讨论】:
标签: api wcf soap automation kerberos