解决内网通过代理服务器访问外网部署WebService报错问题“请求因
发布时间:2020-12-17 02:56:35 所属栏目:安全 来源:网络整理
导读:具体情况如下: 在外网的服务器上部署了一个 Web Service ,由于公司网络原因,仅能通过内网穿过代理服务器来访问外网的 Web Service 。在添加外网的 Web Service 时,出现了提示窗口,如下图: ?提示输入公司内网域的用户名和密码。我输入了自己的用户名和
具体情况如下:
在外网的服务器上部署了一个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提供的接口了。
测试访问代理成功。
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- angularjs – 从指令中更改属性
- 关于webservice和三方调接口的心得
- angularjs – 使用Angular UI Router在URL中设置动态参数
- scala在处理文件时是否提供异步非阻塞IO?
- 如何在angularjs中禁用IE8和IE9上的#hashbang重定向
- angularjs – 使用$http POST Content-Type application /
- 从Angular 2 FormGroup获取所有验证错误
- BootstrapTable使用实例
- Angular Material 2 – 自动完成中的自定义mat-option / md
- 阿里云ECS(经典网络)如何实现内网互联?开放新机器访问旧