现在的位置: 首页 > 综合 > 正文

使用ASP.NET Web服务代理的URL行为属性

2013年08月19日 ⁄ 综合 ⁄ 共 1772字 ⁄ 字号 评论关闭

使用ASP.NET Web服务代理的URL行为属性

郑佐 2005-4-6

         vs.net里调用asp.net web service的时候,默认生成的代理类的URL行为是使用静态值,如果web 服务进行转移,那就有可能会出现不能访问的情况,需要对Web服务重新引用生成新的代理类,这对程序部署带来许多不便,解决办法就是设置URL行为使用动态值,对于许多人没有去关注所以可能都不知道有这一项功能,包括我以前的同事,因此写了这篇文章,对一些朋友提供些许帮助,当然最好的说明还是通过实例。

比如原先的web service192.192.132.97上,在对web service进行修改后部署到企业内部的另一台电脑上, IP192.192.132.95

选中引用该Web服务的解决方案中Web References下的节点(这里ServerFileManager为文件夹名称),列出下面的属性:

URL http://localhost/RedManager/Web References/ServerFileManager/

URL行为:静态

Web 引用 URLhttp:// 192.192.132.97/RedUpload/UpLoadFileService.asmx

文件夹名称:ServerFileManager

 

这里需要通过修改新的IP地址为192.192.132.95,重新进行编译才能再次正确调用原来的服务。

查看代理类的生成的构造函数如下:

public UpLoadFileService()

{

     this.Url = "http:// 192.192.132.95/RedUpload/UpLoadFileService.asmx";

}

上面就是问题所在,都被写死在里面了。

 

下面是解决办法

修改URL行为值为动态,web.Config中会添加下面配置信息,

<appSettings>

         <add key="RedManager.ServerFileManager.UpLoadFileService" value="http://192.192.132.95/RedUpload/UpLoadFileService.asmx"/>

</appSettings>

再来看看服务代理类的构造函数有什么变化,

public UpLoadFileService()

{

     string urlSetting = System.Configuration.ConfigurationSettings.AppSettings["RedManager.ServerFileManager.UpLoadFileService"];

     if ((urlSetting != null))

{

         this.Url = string.Concat(urlSetting, "");

     }

     else

{

         this.Url = "http:// 192.192.132.95/RedUpload/UpLoadFileService.asmx";

     }

}

自此,我们可以通过修改web.config配置文件中的配置信息而不需要重新编译代码来调整程序。

如果使用命令行,可以通过Web 服务描述语言工具 (Wsdl.exe)来实现,

Wsdl.exe /urlkey: RedManager.ServerFileManager.UpLoadFileService "http:// 192.192.132.95/RedUpload/UpLoadFileService.asmx

或者

Wsdl.exe /appsettingurlkey: RedManager.ServerFileManager.UpLoadFileService "http:// 192.192.132.95/RedUpload/UpLoadFileService.asmx

         从上面看到在配置文件中<appSettings>添加了<add key="" value="" />,个人感觉实现更好的方式是使用专门的元素节点来包括这些信息,不和appSettings下的其他信息混合,就像.net framework2.0中的数据库连接字符串一样有专门的设置。本文参考《Microsoft.NET程序设计技术内幕》

抱歉!评论已关闭.