Я написал как клиент WCF, так и удаленный интернет-сервер WCF.
На удаленном сервере WCF работает WPF, размещенный в традиционной оболочке службы Windows (т. Е. Не IIS).
В настоящее время он отлично работает с базовым HTTP-связыванием.Я использую Visual Studio 2010 + .NET 4.0 + C #.
Может ли кто-нибудь указать мне правильные шаги, чтобы изменить мой код, чтобы я мог добавить имя пользователя + SSL-аутентификацию?
РЕДАКТИРОВАНИЕ:
В конце службы я переопределил UserNamePasswordValidator следующим образом:
public class CustomUserNameValidator : UserNamePasswordValidator
{
public override void Validate(string userName, string password)
{
Console.WriteLine("Got to here");
}
}
В конце службы я указал ссылку накласс проверки имени пользователя:
ServiceHost serviceHost = new ServiceHost(typeof(PhiFeedServer.PhiFeed)); // ,baseAddress);
const bool passswordAuthentication = true;
if (passswordAuthentication)
{
// These two lines switch on username/password authentication (see custom class "CustomUserNameValidator" in common file PhiFeed.svc.cs)
// See http://msdn.microsoft.com/en-us/library/aa354513.aspx
serviceHost.Credentials.UserNameAuthentication.UserNamePasswordValidationMode = UserNamePasswordValidationMode.Custom;
serviceHost.Credentials.UserNameAuthentication.CustomUserNamePasswordValidator = new CustomUserNameValidator();
}
// Start the service
serviceHost.Open();
На стороне клиента:
EndpointAddress endpointAddress = new EndpointAddress("http://localhost:20000/PhiFeed?wdsl");
BasicHttpBinding serviceBinding = new BasicHttpBinding();
serviceBinding.ReceiveTimeout = new TimeSpan(0, 0, 120);
proxy = new PhiFeedClient(serviceBinding, endpointAddress);
proxy.ClientCredentials.UserName.UserName = "myusername";
proxy.ClientCredentials.UserName.Password = "mypassword";
Однако, когда я запускаю все, он даже не вызывает валидатор имени пользователя - что происходит?