您的位置:首页 > 运维架构 > 网站架构

VS2005发布网站问题及"aspnet_merge.exe”已退出,代码为 1的错误以及所有代码文件生成一个dll

2008-02-19 12:40 1021 查看
解决方法一:如果遇到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类(在不同的目录中或者是ascx和aspx的同名文件),这样的问题通过一般的生成完成和发布网站肯定都是检测不出来的,运行也是正常的。VS 2005的WEB项目默认的把命名空间给去掉了,可以手动增加一个命名空间,cs代码中加入namespace的语句块,另外别忘了在aspx文件的<@page>的Inherits中写入对应的[namespace].[类名];经过这样的操作再次编译成一个程序集就没有问题了(备注:这个项目前后一共发现了5对类名称一致的情况,加上命名空间或是改名称就可以解决了)。

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

==================================================================================

VS2005发布网站时不会像VS2003一样生成规则的DLL文件、而生成的DLL文件名含有随机数且不能一个项目生成一个DLL文件。

所以,每次网站改动了,一发布,就要全站上传,很不习惯,很不爽;

为了做到像vs2003一样,听说微软发布了WebDeployment Project插件可解决此问题,就搞了一个;安装很简单。

下载网址:
http://download.microsoft.com/download/c/c/b/ccb4877f-55f7-4478-8f16-e41886607a0e/WebDeploymentSetup.msi

右键在当前解决方案里生成一个:Add Web Deployment Project 项目, 在该项目里就可以设置生成DLL的命名方式了

但是发布时老是报出
"aspnet_merge.exe”已退出,代码为1的错误
而且发布的DLL并没有合成一个,还是像以前一样,一大堆;

去网上查了一下,有的说是中文编码问题,有的说是数组索引超出限制等;没办法啊,自己解决吧,但是这错误从哪里找起啊;

还好,看网上有人说,将VS 2005的工具-选项-项目和解决方案-生成并运行,设置“MSBuild 项目生成输出详细信息”,选择“详细”。再次生成Web Deployment Projects项目,“输出”框内的信息就变得非常丰富了;这样就可以查看哪里出错了;

果然,再次发布,错误停在了
An error occurred when merging assemblies: ILMerge.Merge: ERROR!!: Duplicate type ‘web_left’ found in assembly 'App_Web_k7ytr'

它的意思是说web_left的类,已经存在了,我去项目里搜索这个字符串,果然,出现了四次;两次是在cs文件中的class定义处,另两处自然是页面的inherits调用处;

不用说,这是某个程序员在复制页面时,没有做任何改动,连cs引用也没有改;我马上改了,再次生成;

又停了下来,提示与前面一样,只是类名不同罢了,看来同样的错误有很多,唉,只好再改,然后再生成,根据提示,找到错误处,再改;生成是好慢的,搞了一个下午,全改完了;

最终,生成成功!呵呵;所有的cs生成的dll合成了一个dll;

在页面的头部,cs引用处,变成了
<%@ page language="C#" autoeventwireup="true" inherits="web_GovOpen_Article, BuilderWeb" enableEventValidation="false" viewStateEncryptionMode="Never" %>
注意,inherits处,引用的dll名称,不再带有随机数了;

再说些其它的,在VS2005的“输出”窗口中,还看了这样的信息
命令:
C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/aspnet_compiler.exe -v /webSite -p "D:/项目二期/webSite" -u -f -d "D:/项目二期/BuilderWeb/webRoot//"
任务“AspNetCompiler”正在使用“C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/aspnet_compiler.exe”中的“aspnet_compiler.exe”。

挺熟悉的,原来它是用aspnet_compiler.exe来生成的,当初自己还用它的命令行形式自己搞过呢;

再看后面
Running aspnet_merge.exe ...
命令:
C:/Program Files/MSBuild/Microsoft/WebDeployment/v8.0/aspnet_merge.exe "D:/项目二期/BuilderWeb/webRoot" -o BuilderWeb -debug -copyattrs
任务“AspNetMerge”正在使用“C:/Program Files/MSBuild/Microsoft/WebDeployment/v8.0/aspnet_merge.exe”中的“aspnet_merge.exe”。

不用问,aspnet_merge.exe的功能是合并dll文件了;

正是因为aspx引用的cs文档中的类重名,所以在合并时才会报错,以前是分开在不同的dll中的,重名问题没有暴露出来,合并了就出问题了;

现在可以明白这个“代码为1的错误”了吧。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐