您的位置:首页 > 理论基础 > 计算机网络

解决内网通过代理服务器访问外网部署WebService报错问题“请求因 HTTP 状态 407 失败” - 转载

2008-05-15 10:40 991 查看
(转载自:http://www.cnblogs.com/Bear-Study-Hard/archive/2006/04/20/379922.html)

具体情况如下:

在外网的服务器上部署了一个Web Service,由于公司网络原因,仅能通过内网穿过代理服务器来访问外网的Web Service。在添加外网的Web Service时,出现了提示窗口,如下图:



提示输入公司内网域的用户名和密码。我输入了自己的用户名和密码,正常添加引用。

然后在调用时出现了问题,报错信息为:

请求因 HTTP 状态 407 失败:Proxy Authentication Required ( The ISA Server requires authorization to fulfill the request. Access to the Web Proxy service is denied. )。

需要代理服务器认证,上网查了好多的帖子,发现给出的解决方案有误,原内容为:

首先引用命名空间

using System.Net;

定义一个代理类

WebProxy myProxy = new WebProxy("192.168.0.3:8080",true);

然后又定义了一个用于身份验证的类

myService.Credentials = new NetworkCredential("username","password","domainname");

其中的myService变量为一个实例化的Web Service对象。

个人理解其实这是不对的,这个Credentials在注释中为“获取或设置XML Web services 客户端身份验证的安全凭据”。我们要设置的应该是通过代理时我们使用的安全凭据,所以这个设置是不对的。在上面定义的myProxy代理对象中,也有一个Credentials属性,它才是真正的“获取或设置提交给代理服务器进行身份验证的凭据”。所以我们将代码作如下修改:

设置代理对象的Credentials属性

myProxy.Credentials = new NetworkCredential("username "," password "," domainname ");

然后将定义的代理对象赋给Web Service对象的Proxy代理属性即可

myService.Proxy = myProxy;

作完这些设置就可以调用Web Service提供的接口了。

测试访问代理成功。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐