J'ai créé une procuration d'un service Web avec Visual Studio 2008, et il a créé pour moi l'entrée suivante dans le app.config:Se connecter avec WCF à un WebService authentifié avec nom d'utilisateur/mot de passe
<system.serviceModel>
<bindings>
<basicHttpBinding>
<binding name="MyNameHandlerSoapBinding" closeTimeout="00:01:00"
openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"
useDefaultWebProxy="true">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<security mode="None">
<transport clientCredentialType="None" proxyCredentialType="None"
realm="" />
<message clientCredentialType="UserName" algorithmSuite="Default" />
</security>
</binding>
</basicHttpBinding>
</bindings>
<client>
<endpoint address="http://www.***/***/***"
binding="basicHttpBinding" bindingConfiguration="MyNameHandlerSoapBinding"
contract="***.MyNameHandler" name="MyName">
</endpoint>
</client>
</system.serviceModel>
webservice est l'authentification par nom d'utilisateur/mot de passe, je dois donc l'ajouter quelque part ici. Je suis un peu perdu dans la mer de la documentation WCF, je pense que je dois changer de basicHttpBinding à wsHttpBinding ou customBinding pour pouvoir ajouter les éléments d'authentification, mais je ne le comprends pas vraiment. Quelqu'un pourrait-il donner un conseil rapide ou un lien utile qui dit comment le faire?
EDIT:
J'ai changé la section de sécurité:
<security mode="Transport">
<transport clientCredentialType="Basic" proxyCredentialType="None"
realm="" />
</security>
et ajouté dans le code:
ws.ClientCredentials.UserName.UserName = "";
ws.ClientCredentials.UserName.Password = "";
Maintenant, il semble qu'il utilise peut-être les pouvoirs, mais il est me donner l'erreur:
l'URI fourni système « http » est URI non valide devrait « https »
Je ne sais même pas si cela est la bonne façon de procéder ...
WCF est la configuration d'enfer. Quel magasin d'auth que voulez-vous utiliser? Windows ... adhésion ASP ou personnalisé comme une base de données? Et avez-vous regardé à travers cela: http://msdn.microsoft.com/en-us/library/bb398990.aspx –
En effet. C'est un service Web externe qui a un nom d'utilisateur/mot de passe unique à utiliser pour tous mes appels. Et c'est http. Donc, je suppose que cela pourrait être plus d'une autorisation de point de terminaison, si cela a du sens! – antonioh
Il est d'abord question que vous ne pouvez pas spécifier le nom d'utilisateur et mot de passe n'importe où dans la configuration (mais seulement dans le code) - encore une fois, voulez-vous avoir votre mot de passe dans un fichier de configuration en texte clair? VRAIMENT? –