使用ASP.NET Web服务代理的URL行为属性
发表于:2007-06-30来源:作者:点击数:
标签:
使用ASP.NETWeb服务代理的URL行为属性 郑佐2005-4-6 在vs .net 里调用asp.netwebservice的时候,默认生成的代理类的URL行为是使用静态值,如果web服务进行转移,那就有可能会出现不能访问的情况,需要对Web服务重新引用生成新的代理类,这对程序部署带来许多
使用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"/>
</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程序设计技术内幕》。
原文转自:http://www.ltesting.net