VS2005.net web应用程发布、问题及解决方法(转)

在Visual Studio 2003下开发网站的都知道ASP.NET 1.1网站生成后都是一个唯一命名的程序集(项目名称.DLL),但是这种情况在Visual Studio 2005的网站开发中不见了。Visual Studio 2005给我们提供了“发布网站”这样方便的功能,不用在像以前一样COPY的部署,但是采用其“发布网站”的功能,会在站点的BIN目录中产生App_Code.compiled,App_Code.dll,App_Web_xxxxxx.dll,项目名称.dll等等这样的程序集,如果不采用预编译的方式那么产生的文件会更加的多,因为很多都是随机命名也没有什么规律可言;这样会给那些想COPY更新的人带来不便,因为原来的文件不能被覆盖,需要先删除再COPY;有很多时候可能就是更新了后台代码,直接生成项目或是WEB的程序集,像以前一样直接覆盖DLL的方式也很简单。

也许很多人不会考虑BIN下存放的东西,只要站点能运行就好了,那么这样的人读到这里也就没有必要再看此文章,要知道时间是宝贵的,浪费在自己不关心的事情上很不值得的。

VS2005发布网站时不会像VS2003一样生成规则的DLL文件、而生成的DLL文件名含有随机数且不能一个项目生成一个DLL文件、让人有一些遗憾、为了做到像vs2003一样,微软发布了WebDeployment Project插件可解决此问题,下面笔者将介绍采用Microsoft Web Deployment Projects在Visual Studio 2005中生成唯一程序集的方法。

关于Microsoft Web Deployment Projects工具可以从微软站点获得详尽的资料,我也没什么好说的了微软写的很清楚了,呵呵。

下载地址:http://msdn.microsoft.com/asp.net/reference/infrastructure/wdp/default.aspx

详细使用:
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnaspp/html/web_deployment_projects.asp
安装后在“生成”和WEB项目的上下文菜单看到“Add Web Deployment Project…”,好了添加一个Web Deployment Project项目,起一个名称,这个名称就是将来编译后生成的程序集名称,默认的名称“当前项目名称_deploy”
实例一:

1、下载后安装、右键选择vs2005中的项目、会出现一个选项"Add Web Deployment Project"

2、选择添加一个WebDeployment Project(输入程序集名称和发布地址)

3、此时解决方案中会多出一个项目

4、右键选择该项目设置相应属性


5、右键选择该项目(DataBind2005)选择“生成”、此时会发布网站到指定的目录、生成DLL文件同vs2003一样、更新时只需
上传DLL文件

 
 实例二:

双击Web Deployment Project的项目出现属性页面

Compilation中的Output Folder设置项目输出路径

Output Assemblies中的四大选项:

n        Merge all outputs to a single assembly-所有输出都编译成一个程序集(参数:程序集名称)

n        Treat as library component (remove the App_Code.compiled file)-App_Code视为类库(删除App_Code.compiled文件)

n        Merge each individual folder output to its own assembly-WEB项目中单独的目录会编译到一个程序集中(参数:程序集前缀)

n        Merge all pages and control outputs to a single assembly-所有页面控件编译到一个程序集中(参数:程序集名称)

n        Create a separate assembly for each page and control output-为每一个页面和控件创建程序集

Signing使用key文件建立强命名空间的程序集

Deployment

n        Enable Web.config file section replacement-用不同的config文件替换Web.config中的节点

n        Create an IIS virtual directory for the output folder-创建IIS虚拟目录(参数:虚拟目录名称)

n        Remove the App_Data folder from output location-删除输出目录中的App_Data目录

好了通过简单的设置,就可以生成一个看上去非常“干净利落”的bin目录,每个程序集都很明显,对部分升级工作很有帮助。
 实例三: 

最近用vs2005asp.net程序,发布时遇到很多麻烦,觉得和vs2003有很多的不同,以前还一直抱怨Boland Delphi 2005难用,满口称赞vs2005呢,现在觉得vs2005也有很多不尽人意的地方。早知道当初还选择dotnet1.1了,现在用vs2005+dotnet2.0,发布时真是多花了好多力气,且听一一道来。

       首先,一开始我还以为vs2005vs2003一样,可是无论我怎样点击生成网站却始终找不到生成的dll,后来才知道,要用发布网站才可以的。可是对于一个web应用程序进行发布时,vs2005却生成了多个由随机字符命名dll文件,看上去就很难受,而其管理维护起来十分不方便,更让人不能接受的是在发布webservice 的时候,对于每一个webservice网站应用程序vs2005生成一个名为App_Code.dll 的文件,找不到可以修改生成文件名的地方。无奈之中,只好上网找资料。后来了解到WebDeployment  点击这里进入WebDeployment下载页面)这个小插件可以解决上述问题,于是就下载来看看。是e文的,用起来不是很方便,但确实可以解决问题。有关WebDeployment的参考请查阅一下网址

http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnaspp/html/web_deployment_projects.asp

http://msdn.microsoft.com/asp.net/reference/infrastructure/wdp/default.aspx

       可我在使用过程中又发现许多新的问题,WebDeployment用起来十分不稳定,会莫名其妙的出现错误,同样的代码有时能通过编译有时不能,错误提示十分含糊笼统,总是提示:

错误       1     aspnet_merge.exe”已退出,代码为 1

而且这些代码在不使用WebDeployment  的时候都很正常,都能编译通过。

相信许多朋友都遇到过这种问题,实在让人迷茫阿,于是笔者自己手用命令行动执行aspnet_merge.exe      dll进行管理合并。得到以下信息

Utility to merge precompiled ASP.NET assemblies.

Copyright (c) Microsoft Corporation. All rights reserved. 

An error occurred when merging assemblies: 索引超出了数组界限。

如图:

怎么会有数组越界错误,让人迷茫,于是又上网查资料,有人遇到同样的问题,可是没人知道是什么问题。笔者这时又查到另外一个专门对.net assembly 进行管理的工具 ILMerge.exe 下载地址

有关ILMerge.exe 的参考请浏览以下网址:http://research.microsoft.com/%7Embarnett/ilmerge.aspx

它目前支持.net1.12.0,可以把多个.net assembly合并成一个,笔者在想可不可以用它对Vs2005生成的dll进行合并,于是下载了ILMerge.exe试试看,他只支持命令行方式,有点麻烦,我还是按帮助试试看了,结果是让人失望的,在我对aspnet_merge.exe 无法合并的dll进行合并时,出现同样的错误

An error occurred when merging assemblies: 索引超出了数组界限。

 

极度迷茫…….,该怎么办呢?问题没有解决,不能放弃。于是笔者把自己写的程序代码全都注释掉,一点一点放开,慢慢寻找问题所在。终于,让我找到了我的程序的“bug”(其实不能称作为我的bug,因为他在vs2005.net2.0中都能正确执行只是进行合并时有问题我写了一个webservice,可以通过编译同过WebDeployment生成也没为题指定服务说明

[WebMethod(Description ="")]

仍然没有问题,改为:

[WebMethod(Description ="sdfdfsdfsdfsdfsdfsfsf")] Description = 英文字符串

仍然没有问题,改为:

[WebMethod(Description ="包括汉子的字符串..SSSsds ")],即Description =包括汉子的字符串

问题出现了,Description包含汉子时候,对于WebDeployment而言根据字符的长度不同和字符中英文字母的个数不同,有时候会出错,有时候不会出错。
      看来是WebDeploymentILMerge本身有一定的bug,笔者猜想可能是编码问题造成的,WebDeploymentILMerge都是英文版的,也许是在计算字符串长度时由于汉子和英文字母不同,而造成的错误吧,这只是我的猜想,大家仅作参考。

经过反复试验,笔者找到了一种不是办法的办法,就是在字符串后边狂加 空格

由于笔者的WebMethod Description web上输出,因此最后多些空格不太影响效果。

暂且这样解决巴。无奈啊。

 希望我的一点经验能给大家带来帮助,导致WebDeployment出错的原因也许还有很多,不过在你遇到错误时,可以先检查一下你程序中的字符串,暂时把他们置为””,试试看。没准就是他引起的问题啊。

 
说明:还有一种方法,vs2005装SP1后新建项目里面会出现“ASP.NET Web应用程序”,用这个做网站生成的DLL文件就同vs2003一样。但是如果你之前的网站是用vs2005的网站上新建的,那用这种方式可能要修改一定的代码。

解决方法一:如果遇到WebDeployment Project发布,生成的dll还是跟之前的一样多,而且出现"aspnet_merge.exe"已退出,代码为 1的错误,是因为你的代码里有中文导致的,看来是WebDeployment,ILMerge本身有一定的bug,笔者猜想可能是编码问题造成的,WebDeployment,ILMerge都是英文版的,也许是在计算字符串长度时由于汉子和英文字母不同,而造成的错误吧,这只是我的猜想,大家仅作参考。
解决方法二:实际上在我们的一个实际ASP.NET 2.0的解决方案中来应用这种方式出现了问题,下面我就讲一下我的解决过程希望对大家有所帮助。

我们的解决方案包括22个项目(主要是类库),其中的一个WEB项目是负责用户UI的,传统的生成或是发布网站的方式没有任何问题,当使用Web Deployment Projects工具生成唯一程序集时出现了错误信息“Aspnet_merge.exe Exited with Code 1”(Aspnet_merge.exe 退出,错误代码1),这样的信息根本无法让我们办断到底是哪里出了问题。好,下面依次打开VS 2005的工具-选项-项目和解决方案-生成并运行,设置“MSBuild 项目生成输出详细信息”,选择“详细”。再次生成Web Deployment Projects项目,注意“输出”框内的信息现在变得非常丰富了,最后导致无法编译的问题终于出来了“An error occurred when merging assemblies: ILMerge.Merge: ERROR!!: Duplicate type ‘_Default’ found in assembly 'App_Web_k5hhsnh0'”,它的意思是说在程序集中发现了相同的类型_Default,经过我检查确实在我们的WEB项目中存在了两个_Default类(在不同的目录中),这样的问题通过一般的生成完成和发布网站肯定都是检测不出来的,运行也是正常的。VS 2005的WEB项目默认的把命名空间给去掉了,可以手动增加一个命名空间,cs代码中加入namespace的语句块,另外别忘了在aspx文件的<@page>的Inherits中写入对应的[namespace].[类名];经过这样的操作再次编译成一个程序集就没有问题了(备注:这个项目前后一共发现了5对类名称一致的情况,加上命名空间或是改名称就可以解决了)。

上面就是结合我的项目实际解决的问题,暂时还没有发现别的错误出来。使用有问题的朋友也多多交流。

 

转自:http://menghua117.blog.163.com/blog/static/786066200802211021157/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值