.NET Windows客户端程序在代理环境下的相关设置
这里是一点经验的简短总结
之前在用SmartClient+Remoting的方式开发业务管理系统的时候,就遇到过一次HTTP代理配置的问题。当时,由于Remoting无法自动配置代理,所以采取的办法就是在登录界面上提供代理网络配置的选项,让用户手动录入代理服务器的地址,端口,用户名和密码。
在.NET 4.0中对于Web Service和WCF,就可以通过设置WebRequest.DefaultWebProxy.Credentials = CredentialCache.DefaultNetworkCredentials;来自动配置大部分代理服务器。这种方式其实就是使用IE中对代理服务器的配置。
对于DefaultNetworkCredentials的使用可以参考我另外一篇博客:DefaultNetworkCredentials vs DefaultCredentials
通过以上代码配置后,并不能保证一定能正确访问,所以还需要进行如下处理:
- 通过代码配置为默认代理后
- 访问一下网络是否连通
- 如果没有连通,尤其访问407这个验证错误的代码,
- 那么就需要提示用户输入代理服务器用户名和密码
我的实现代码如下:
custom code for set proxy
除了通过代码来配置默认代理外,也可以在配置文件中对WCF等进行配置,如下:
<basicHttpBinding><binding name="MyClientBinding" proxyAddress="http://gateway:8080" useDefaultWebProxy="false"></binding></basicHttpBinding>or<customBinding><binding name="MyCustomClientBinding"><binaryMessageEncoding /><httpTransport proxyAddress="http://gateway:8080" useDefaultWebProxy="false" /></binding></customBinding>or<system.net><defaultProxy useDefaultCredentials="true"><proxy bypassonlocal="False" proxyaddress="http://gateway:8080" /></defaultProxy></system.net>