错误 — 如果向导遇到无法自动转换的内容,就会产生错误项。这些项需要进行特别处理才能完成转换。通常,错误是您尝试运行应用程序时会产生编译错误的东西。
第 2 部分:常见的转换问题
虽然 Visual Studio 2005 旨在与使用 Visual Studio®.NET 2003 开发的代码一起工作,但是您可能会遇到一个或多个常见的转换问题。本节,我们将了解一些最常见的问题。
注 转换向导在 Visual Studio 2005 的最新版本中已经升级,并且可以自动检测和修复以下一些问题。然而,如果该向导遗漏了特定的问题,您可以手动应用下面描述的解决方案来完成 Web 项目的转换。
问题 1 :代码隐藏类文件 (CB-CB) 引用
注 CB 是 Web 窗体 (*.aspx) 或用户控件 (*.ascx) 的代码隐藏文件的缩写。
新的编译模型使用多个通常在服务器上动态编译的程序集。该模型改善了 Web 站点的性能和可更新性。
然而,如果您的代码隐藏文件引用其他的代码隐藏文件,那么您将有一个中断的引用,这是因为引用的代码隐藏文件将不再位于同一个程序集中。
以下是一些可能引发此问题的常见方式:
-
使用 Web 窗体或用户控件作为另一个 Web 窗体或用户控件的基类。
-
使用 LoadControl() 并将结果转换为另一个用户控件,例如
UserControl1 c1 = (UserControl1)LoadControl("~/UserControl1.ascx");
-
创建一个 Web 窗体类实例,例如
WebForm1 w1 = new WebForm1();
,其中 WebForm1 是在 Web 窗体的代码隐藏文件中定义的一个类。
如何修复
要解决此问题,需要更改应用程序以便找到该引用。因为这是一个 CB-CB 引用,所以解决问题的最简单方法是添加对进行该引用的 Web 窗体或用户控件的引用指令。这将通知编译器要链接到哪个程序集。
我们假设出现以下情况:
文件
ASP.NET 1.x 代码
Page1.ascx
|
-
|
Page1.ascx.cs
|
Control1 c = (Control1)LoadControl("~/Control1.ascx");
|
将代码更改为使用引用指令:
文件
ASP.NET 2.0 代码
Page1.ascx
|
<%@ Reference Control="~/Control1.ascx" %> |
Page1.ascx.cs
|
Control1 c = (Control1)LoadControl("~/Control1.ascx");
|
通过使用引用指令,明确地通知编译器在哪里寻找您要使用的 Web 窗体或控件。请注意,在 Visual Studio 2005 的最新版本中,转换向导将自动执行此操作。
问题 2 :独立类文件 (SA - CB) 引用
注 SA 是独立类文件的缩写。
如果您有一个引用代码隐藏类文件中代码的独立类文件,则可能会遇到另一种中断的引用。这与中断的 CB-CB 引用类似,除了在 App_Code 文件夹中有一个独立类文件,该文件试图引用一个单独的页程序集。引发此问题的一个常见方式是访问 CB 类中的一个类变量。
如何修复
修复一个中断的 SA-CB 引用涉及的更多。由于该问题出现在 SA 文件中,因此不能使用引用指令来找到该引用。而且在转换后,SA 文件移动到 App_Code 文件夹,因此该类文件将无权在编译时访问 App_Code 程序集。
解决方案是在编译时引用的 App_Code 文件夹中创建一个抽象的基类,该基类将在运行时从页程序集中加载实际的类。
我们假设出现以下情况:
文件
ASP.NET 1.x 代码
Control1.ascx
|
inherits="Control1"
|
Control1.ascx.cs
|
class Control1 : System.Web.UI.UserControl {
public static string myName = "Control1";
public void foo() { some code }
}
|
Code1.cs
|
String myName = "Class1 + " + Control1.myName;
|
更改代码以使用抽象基类:
文件
ASP.NET 2.0 代码
Control1.ascx
|
inherits="migrated_Control1"
|
Control1.ascx.cs
|
class migrated_Control1 : Control1 {
override public void foo() { some code }
}
|
App_Code\Code1.cs
|
String myName = "Class1 + " + Control1.myName;
|
App_Code\Stub_Control1.cs
|
abstract class Control1 : System.Web.UI.UserControl {
public static string myName = "Control1";
abstract public void foo();
}
|
由于抽象基类现在位于 App_Code 文件夹中,因此允许独立类文件和 CB 文件在编译期间找到一个类(本例中名为 Control1)。然而,独立类文件将在运行时使用后绑定加载原始类(在本例中,重命名为 migrated_control)。注意:在 Visual Studio 2005 的最新版本中,转换向导将自动创建此代码。
问题 3 :循环引用
如果代码隐藏文件引用其他代码隐藏
文件,这个被引用的代码隐藏文件又引用原始文件,就会发生循环应用。这种情况可能发生在两个或更多代码隐藏文件中,例如:
还会发生在程序集之间,其中一个程序集引用另一个
程序集,引用的程序集又引用原始程序集,例如:
如何修复
第一种循环引用的解决方案是:用其中一个引用在 App_Code 文件夹中创建一个抽象基类,然后从相关联的 Web 窗体或用户控件文件中删除引用指令。这将破坏循环引用。
第二种循环引用是 ASP.NET 编译器由于性能原因而“批处理”程序集的副产品。默认情况下,它将 Web 窗体和用户控件放在一个文件夹中,然后将它们编译成一个程序集。
解决此问题的方式有很多,但是我们建议将引用的页(例如,Pages2.aspx.vb 和 Pages3.aspx.vb)移动到它们自己的文件夹中。
默认情况下,ASP.NET 编译器将创建一个包含这些页的单独的程序集,程序集 A 和 B 之间的循环引用将被删除。
问题 4 :资源管理器
在 Visual Studio .NET 2003 中,资源管理器用于管理 Web 应用程序中的资源。典型的示例如下所示:
文件
ASP.NET 1.x 代码
Control1.ascx.cs
|
Assembly a = Assembly.Load("myApp");
ResourceManager rm = new ResourceManager("myApp.Resource1", a);
String s = rm.GetString("foo");
|
Resource1.resx
|
Contains name/value pair "foo = bar"
|
此类代码有问题,因为它取决于知道要加载的程序集名称,但在 Visual Studio 2005 中该名称不再是一个固定名称。
如何修复
由于 Visual Studio 2005 使用不确定的程序集命名,因此需要将代码更改为使用新的资源模型。最简单的方法是将 Resource1.resx 移到一个名为 App_GlobalResources 的文件夹中。通过强命名,Visual Studio 2005 自动将在该文件夹中找到的所有资源用于 Web 应用程序(利用 IntelliSense 使资源成为可发现的)。下面是转换后的示例:
文件
ASP.NET 2.0 代码
Control1.ascx.cs
|
String s = Resources.Resource1.foo;
|
App_GlobalResources\ Resource1.resx
|
Resource1.resx moved to App_GlobalResources
Contains name/value pair "foo = bar"
|
这只是使用 Visual Studio 2005 中新的资源模型的一种方法,您应该查看该资源模型文档,以发现该模型中的新增功能。
问题 5 :不再对已排除的文件进行排除
在 Visual Studio .NET 2003 中,必须明确确定是否在 Web 项目中包括文件。如果没有明确列出包含某个文件,则该文件会排除在项目之外。还可以通过将一个代码文件的生成操作设为“none”,来停止生成该代码文件。该信息存储在项目文件中。
转换时必须考虑几个问题,例如:
在 Visual Studio 2005 的最新版本中,转换向导将原样保留排除的文件并在转换报告中注明。因此,您的 Web 项目将包含额外的、未转换的文件,它们现在是项目的一部分。根据文件的扩展名,编译器可能会尝试编译该文件,这可能会引发应用程序中的冲突。
如何修复
转换之后,可以从项目中删除任何不想要的、以前排除的文件。您也可以使用“Exclude from Project”功能(可以在解决方案资源管理器找到)排除它们,通过使用安全的扩展名“.exclude”对它们进行重命名,以便有效地从 Web 应用程序中删除它们。
注 用“.exclude”扩展名排除的文件仍然是 Web 项目的一部分,但不对它们进行编译,如果它们碰巧在服务器上,IIS/ASP.NET 也不支持这些文件。注 未来版本的转换向导将更主动,并且在它认为安全的情况下将排除文件。
问题 6 :孤立的 resx 文件
Visual Studio .NET 2003 为 Web 窗体和用户控件生成了一个 resx(资源)文件。通常情况下,用户不使用这些文件,因为它们是自动生成的并且可能会改写用户添加的代码。
转换之后并不删除这些 resx 文件,因为迁移向导不确定用户是否已经添加了需要保存的资源。
如何修复
查看生成的 resx 文件并将用户数据保存到它自己的资源文件中。将该数据合并到一个资源文件中会更好。
根据需要将该资源文件移到特殊的文件夹 App_GlobalResources or App_LocalResources 中,这样 Web 应用程序就可以使用它了。
用这种方式保存用户数据后,从 Web 项目中删除生成的 resx 文件。
问题 7 :代码隐藏文件中的额外类型
在 Visual Studio®.NET 2003 中,通过在 Web 窗体或用户控件之一的代码隐藏文件中存储类型,有可能在不同页之间共享类型(例如,结构、枚举、接口、模块等)。
该模型在 Visual Studio 2005 中是中断的,因为一个 Web 窗体和多个用户控件编译到它们自己的程序集中,其他类型不再可发现。
如何修复
转换向导完成应用程序转换后,就会将任何非私有的额外类型移到 App_Code 文件夹中它自己的独立代码文件中。由于必须跨程序集工作,因此您可能还需要将访问修饰符更改为 public。通过 Web 应用程序,共享类型将进行自动编译,并且是可发现的。
问题 8 :访问自动生成的控制变量
在 Visual Studio®.NET 2003 中,代码隐藏的类文件包含用户和自动生成的设计器代码。后者可以包含控制变量声明和页功能。虽然不建议这样做,但是一些开发人员将控制变量的访问权限更改为 Public,这样就可以在它们的类之外对它们进行修改。示例如下所示:
文件
ASP.NET 1.x 代码
UserCtrl1.ascx
|
<asp:Label id="Label1" runat="server">UC1</asp:Label>
|
UserCtrl1.ascx.cs
|
public System.Web.UI.WebControls.Label Label1;
|
Page1.ascx.cs
|
UserCtrl1 uc1 = (UserCtrl1)LoadControl("~/UserCtrl1.ascx");
uc1.Label1.Text = "Foo";
|
在 Visual Studio 2005 中,因为是通过部分类将用户和自动生成的设计器代码分开了,所以此更改不起作用。部分类允许一个类跨多个文件,并且用于维护用户和自动生成的代码之间干净的分隔。
如何修复
通常情况下,建议您将代码更改为不依赖于自动生成的代码的更改的访问级别。然而,如果代码中有数百个位置调用诸如自动生成这样的变量并且需要快速运行代码,那么有一个很有用的替代方案。您可以将原始控制变量重命名为其他名称,然后创建一个公有属性来访问重命名的控制变量。例如:
文件
ASP.NET 2.0 代码
UserCtrl1.ascx
|
<asp:Label id="p_Label1" runat="server">UC1</asp:Label>
|
UserCtrl1 hidden partial class
|
// this will be auto-generated in the hidden, partial class
protected System.Web.UI.WebControls.Label p_Label1;
|
UserCtrl1.ascx.cs
|
public System.Web.UI.WebControls.Label Label1 {
get { return p_Label1; }
set { p_Label1 = value; }
}
|
Page1.ascx.cs
|
UserCtrl1 uc1 = (UserCtrl1)LoadControl("~/UserCtrl1.ascx");
uc1.Label1.Text = "Foo";
|
问题 9 :无法切换到设计视图
Visual Studio 2005 中内置的新 Visual Web 设计器在正确的 HTML 方面比 Visual Studio .NET 2003 更严格。如果 aspx 页包含不匹配的标记或格式不正确的 HTML,则该设计器将不允许您在 Visual Studio 2005 内切换到设计视图。相反,您将被限制在代码视图,直到修复了问题为止。发生该问题的原因是 Visual Studio 2005 内置有新的源代码保留和验证功能。
如何修复
为了避免此问题,您所能做的就是确保 aspx 页中的标记格式正确。如果在从代码视图切换到设计视图的后转换时遇到问题,则该问题几乎肯定是错误的标记。
问题 10 :无法解析文件名
您可能会看到有些模糊的错误消息,告诉您无法解析某个文件。这意味着在 HTML 标记上找不到 ‘Codebehind’ 或 ‘Src’ 属性。
如果您的 Web 窗体或用户控件不包含以上任何一个属性,则该向导找不到匹配的代码隐藏文件,也无法转换该页。
如何修复
如果这碰巧是一个纯 HTML 页,则该错误可以忽略,如果应用程序具有使用 aspx 扩展名的 HTML 页,则会经常遇到此错误。
为了避免此问题,请确保为 html 文件正确命名,并且在 HTML 标记上的 Web 窗体和用户控件中使用 ‘Codebehind’ 和 ‘Src’ 属性。
注 在下一个版本的 Web 项目迁移向导中,通过使用以下消息可以使该错误更易于描述。
相关推荐
### 常见的ASP.NET 2.0转换问题及解决方案 #### 简介 在将现有的ASP.NET 1.x应用程序迁移至ASP.NET 2.0的过程中,开发者们经常会遇到一些挑战。ASP.NET 2.0作为1.x版本的重要升级,不仅带来了诸多新特性,也改变了...
本方案提供了一个简洁有效的解决方法,通过一个Java文件和在`web.xml`配置文件中的简单设置,可以有效地解决乱码问题。 首先,我们要理解乱码产生的原因。在Web应用中,乱码通常发生在以下几个环节: 1. **请求...
### Java Web开发中常见的中文乱码问题解析 在Java Web开发过程中,中文乱码问题是开发者经常遇到的一个挑战。这些问题主要源于Java默认的Unicode编码与HTML页面及表单默认的Latin-1编码之间的不兼容,以及在不同的...
在Web项目开发中,中文乱码问题是一个常见但棘手的问题,主要出现在用户输入的数据在传输过程中出现编码不一致导致的。以下是一些解决此类问题的关键知识点和实践方法: 1. **请求编码与响应编码设置** 当用户通过...
### Loadrunner11常见问题解决方案 #### 录制不弹IE问题解决方法总结(不常见的解决方法) 在使用LoadRunner11进行Web应用测试时,可能会遇到无法弹出Internet Explorer浏览器的问题,这会影响到脚本的录制。以下...
Web打印的解决方案主要关注如何在Web环境中有效地呈现和打印页面内容,尤其是对于普通报表的处理。在传统的Web项目中,通常使用JavaScript来处理打印需求,因为它可以在客户端直接操作DOM元素,实现页面的动态修改和...
本解决方案主要探讨如何通过Java技术实现这一功能,同时涉及文档转换为PDF以及SWF格式,以便进行预览。 首先,我们需要了解的是,由于Office文档格式的复杂性,直接在浏览器中打开可能会导致兼容性问题。因此,通常...
本文主要讨论了针对严谨型前端开发人员的浏览器解析差异导致的兼容性问题及其解决方案。 首先,问题一涉及到不同浏览器对标签默认外补丁和内补丁的处理差异。在无样式控制的情况下,各标签的`margin`和`padding`...
这份"jsp开发中遇到的问题及解决方案"的压缩包文件,旨在为J2EE项目的开发提供帮助,解决实践中可能遇到的常见难题。以下是针对JSP、Web开发以及J2EE开发的一些关键知识点和常见问题的解决方案: 1. **JSP基本语法...
在我们的解决方案中,WebSocket服务器将扮演关键角色,负责从RTSP源拉取视频流并将其转发给Web客户端。 RTSP (Real Time Streaming Protocol) 是一种用于控制多媒体数据流的协议,常用于IP摄像机等设备,提供实时...
在现代的Web应用中,提供在线预览功能已经成为一种常见的需求,尤其是对于处理各种文档格式如...虽然这个过程涉及到多个步骤和技术,但通过合理的架构设计和代码实现,可以提供一个高效、安全的文档预览解决方案。
下面,我们将针对“WEBI报表2常见问题及解决方法总结”这一主题进行深入探讨,旨在为用户提供一系列实用的解决方案。 #### 1. 图片显示问题及其解决办法 在WEBI报表中,有时图片可能无法正常显示。这通常与图片源...
在Java Web开发中,中文乱码问题一直是开发人员面临的常见问题之一。中文乱码通常是由于在字符编码转换过程中,字符集不一致或设置不当所导致。为了解决这一问题,首先需要了解Java Web工程字符编码的基本理论,包括...
### 解决Web开发中的中文问题 在Web开发过程中,中文乱码问题是非常常见的一个问题,尤其对于使用Tomcat服务器的应用程序来说。本篇文章将详细介绍导致这一问题的原因以及如何解决这一问题。 #### 一、问题背景与...
然而,在实际操作过程中,用户可能会遇到各种问题,以下是一些常见的IIS网站发布问题及其解决方案: 1. 2012R2系统卸载.NET 4.5后出现cmd弹框问题 当意外卸载了.NET Framework 4.5后,系统可能从完整模式转换为...
在IT行业中,转换数据格式是一项常见的任务,尤其是在处理大量数据时。标题提到的"通过web端转换excel为xml文件,可一次性转换多个xml"是一...这样的解决方案在数据分析、数据交换和自动化工作流中具有广泛的应用价值。
在实际项目中,理解并熟练使用Proj4js库能有效解决跨坐标系统数据集成的问题,提升Web地图应用的准确性和兼容性。通过学习和实践,开发者能够更好地应对复杂的地理信息处理需求,为用户提供更加精确的地理位置服务。
### VS2005(C#)项目调试常见问题与解决方案 在进行软件开发时,遇到各种调试问题是家常便饭,尤其是使用Visual Studio 2005和C#语言进行项目开发时。以下是一些常见的VS2005(C#)项目调试问题及其解决方案的汇总,...