** 使用 ASP.NET Web ** ** 服务代理的 URL ** ** 行为属性
**
郑佐 2005-4-6
在 vs.net 里调用 asp.net web service 的时候,默认生成的代理类的 URL 行为是使用静态值,如果 web 服务进行转移,那就有可能会出现不能访问的情况,需要对 Web 服务重新引用生成新的代理类,这对程序部署带来许多不便,解决办法就是设置 URL 行为使用动态值,对于许多人没有去关注所以可能都不知道有这一项功能,包括我以前的同事,因此写了这篇文章,对一些朋友提供些许帮助,当然最好的说明还是通过实例。
比如原先的 web service 在 192.192.132.97 上,在对 web service 进行修改后部署到企业内部的另一台电脑上, IP 为 192.192.132.95 。
选中引用该 Web 服务的解决方案中 Web References 下的节点(这里 ServerFileManager 为文件夹名称),列出下面的属性:
URL : http://localhost/RedManager/Web References/ServerFileManager/
URL 行为:静态
Web 引用 URL : http:// 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"/> 再来看看服务代理类的构造函数有什么变化,
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 程序设计技术内幕》 。