在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 详细使用: 1、下载后安装、右键选择vs2005中的项目、会出现一个选项"Add Web Deployment Project" 双击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目录,每个程序集都很明显,对部分升级工作很有帮助。 最近用vs2005写asp.net程序,发布时遇到很多麻烦,觉得和vs2003有很多的不同,以前还一直抱怨Boland 的 Delphi 2005难用,满口称赞vs2005呢,现在觉得vs2005也有很多不尽人意的地方。早知道当初还选择dotnet1.1了,现在用vs2005+dotnet2.0,发布时真是多花了好多力气,且听一一道来。 首先,一开始我还以为vs2005和vs2003一样,可是无论我怎样点击生成网站却始终找不到生成的dll,后来才知道,要用发布网站才可以的。可是对于一个web应用程序进行发布时,vs2005却生成了多个由随机字符命名的dll文件,看上去就很难受,而其管理维护起来十分不方便,更让人不能接受的是在发布webservice 的时候,对于每一个webservice网站应用程序vs2005生成一个名为App_Code.dll 的文件,找不到可以修改生成文件名的地方。无奈之中,只好上网找资料。后来了解到WebDeployment (点击这里进入WebDeployment下载页面)这个小插件可以解决上述问题,于是就下载来看看。是e文的,用起来不是很方便,但确实可以解决问题。有关WebDeployment的参考请查阅一下网址 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.1和2.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而言根据字符的长度不同和字符中英文字母的个数不同,有时候会出错,有时候不会出错。 经过反复试验,笔者找到了一种不是办法的办法,就是在字符串后边狂加 空格 由于笔者的WebMethod Description 在web上输出,因此最后多些空格不太影响效果。 暂且这样解决巴。无奈啊。 希望我的一点经验能给大家带来帮助,导致WebDeployment出错的原因也许还有很多,不过在你遇到错误时,可以先检查一下你程序中的字符串,暂时把他们置为””,试试看。没准就是他引起的问题啊。 我们的解决方案包括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对类名称一致的情况,加上命名空间或是改名称就可以解决了)。 |
