- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一个头擦。这是交易。
在将使用Delphi 2007 for .NET构建的ASP.NET应用程序的Beta版部署到测试服务器时,遇到了一个奇怪的问题。该应用程序无法启动,因为它无法加载我正在使用的ADO.NET数据提供程序的正确版本。
只有通过在bin目录中包含旧程序集的版本,应用程序才能运行。但是,我不想被这个旧的.NET数据提供者所束缚,因此我决心找到解决此问题的方法。
我最初使用.net数据提供程序程序集(用作“本地复制”)来编译项目,这应该导致Delphi使用我将该程序集版本复制到项目管理器中的“引用”文件夹时选择的副本。我选择的实际程序集是版本9.10.2.0,即与应用程序一起出现在bin目录中的程序集的版本。但是,在运行时,应用程序试图绑定到同一程序集的早期版本9.0.2.7。
(实际上,无论我是否使用GAC版本的“本地复制”都会发生此问题,因此我认为这不是问题。)
在研究此问题时,我创建了一个新项目,并添加了对9.10.2.0程序集的引用。尽管如此,.NET 2.0配置实用程序和Reflector都显示该应用程序是对9.0.2.7程序集的引用进行编译的。
检查GAC,我看到9.0.2.7和9.10.2.0版本都已注册。尝试删除9.0.2.7版本失败,因为该提供程序的版本仍在引用GAC中的程序集。
我进入注册表并手动删除了对9.0.2.7提供程序的所有引用。然后,我能够将其从GAC删除。这没有任何改变。从现有应用程序中删除程序集,然后再添加9.10.2.0版本,然后进行编译,仍然会导致将错误的程序集信息插入到应用程序中。和以前一样,创建引用9.10.2.0程序集的新应用程序无效,因为对9.0.2.7的引用仍被插入可执行文件中。
我已经检查了Delphi库搜索路径。我还从计算机(包括从ASP.NET临时文件目录)中完全删除了旧程序集文件的每个实例。我仍然有问题。我曾尝试使用Issam Ali的AppManifest实用工具来手动调整清单,但是显然,它在Delphi 2007 for .NET中不支持ASP.NET应用。
因此,GAC不再包含对9.0.2.7的引用,在注册表中也没有对其的引用,在项目或Delphi选项对话框中没有指向旧提供程序目录的路径,旧提供程序程序集不在文件系统上,并且9.0.2.7不会出现在任何项目文件中。它也不会出现在web.config,machine.config或我检查过的任何其他文件中。尽管如此,只要我引用9.10.2.0版本的程序集,Delphi就会坚持使用此版本的程序集。 (是的,我重新启动了Delphi,还重新启动了在其中进行此开发的虚拟机。)
即使在卸载9.10.2.0数据提供程序(较早的版本已卸载)并重新安装之后,将数据提供程序引用添加到应用程序中也会导致运行时应用程序尝试加载旧的提供程序(即使未引用旧的提供程序)显然仍保留在系统中)。
我尝试了其他解决方案(在这里值得一提),但没有一个奏效。有人看到吗?我将继续解决这个问题,但很想听听建议。我只是无法让Delphi停止将旧的装配信息插入项目中。
对于咧嘴笑,我包括了失败的错误日志。该日志实质上是复制我从融合日志中获得的信息。该日志来自我从GAC删除9.0.2.7程序集后创建的简单应用程序之一。请注意,它从一开始就在寻找提供程序的旧版本。
程序集管理器从以下位置加载:c:\ WINDOWS \ Microsoft.NET \ Framework \ v2.0.50727 \ mscorwks.dll
在可执行文件c:\ windows \ microsoft.net \ framework \ v2.0.50727 \ aspnet_wp.exe下运行
---详细的错误日志如下。
===预绑定状态信息===
日志:用户= TRAINING8A \ ASPNET
日志:DisplayName = Advantage.Data.Provider,版本= 9.0.2.7,文化=中性,PublicKeyToken = e33137c86a38dc06
(完全指定)
日志:Appbase = file:/// C:/ Inetpub / wwwroot / TestAdsVer2 /
日志:初始PrivatePath = C:\ Inetpub \ wwwroot \ TestAdsVer2 \ bin
调用程序集:TestAdsVer2,版本= 1.0.3572.17384,文化=中性,PublicKeyToken =空。
日志:此绑定在默认的加载上下文中启动。
日志:使用应用程序配置文件:C:\ Inetpub \ wwwroot \ TestAdsVer2 \ web.config
日志:使用主机配置文件:c:\ windows \ microsoft.net \ framework \ v2.0.50727 \ aspnet.config
日志:使用来自c:\ WINDOWS \ Microsoft.NET \ Framework \ v2.0.50727 \ config \ machine.config的计算机配置文件。
日志:政策后参考:Advantage.Data.Provider,版本= 9.0.2.7,区域性=中性,PublicKeyToken = e33137c86a38dc06
日志:尝试下载新的URL文件:/// c:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/Temporary ASP.NET Files / testadsver2 / 07545aea / 3d068a5 / Advantage.Data.Provider.DLL。
日志:尝试下载新的URL文件:/// c:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/Temporary ASP.NET Files / testadsver2 / 07545aea / 3d068a5 / Advantage.Data.Provider / Advantage.Data.Provider .DLL。
日志:尝试下载新的URL文件:/// C:/Inetpub/wwwroot/TestAdsVer2/bin/Advantage.Data.Provider.DLL。
WRN:比较程序集名称会导致不匹配:次要版本
ERR:无法完成装配的设置(hr = 0x80131040)。探测终止
这种情况持续了很长时间,以至于我在LanceSC答案中添加的评论不再显示。但是我要做的事情是我要解决的一个有趣的问题。
这是我对LanceSC的最后两条评论
表现出此问题的安装位于不再起作用的VM中。我认识的另一个开发人员也遇到过同样的问题。解决的办法是放弃安装。我觉得此.NET数据提供程序的特定版本的安装程序中的某些内容留下了一些奇怪的工件,从而导致了问题。此数据提供程序的任何其他内部版本都不会发生。我不再追求这个问题的答案。
发言时间过早。我的一位同事今天(2010年3月5日)遇到了相同的错误,只是该.NET数据提供程序的早期版本(9.0.2.1)。他现在处于我以前的位置。他无法使用任何版本的数据提供程序运行他的应用程序,请保存旧版本。该程序集被用作本地副本,而旧版本不在gac中。使用他的计算机,我们使用详细选项运行了MSBuild。构建工作正常,没有错误。但是,编译应用程序无法运行,无法找到提供程序的旧版本。
摘要
我的同事辞职了,重新安装了Delphi 2007(很幸运,他正在使用VM,并且在Delphi 2007中安装了第二个VM,但从未安装有问题的.NET数据提供程序。这也是我的策略。
至此,我已经得出结论,这个问题是无法解决的。但是,我将这个问题再等待一个星期左右。如果在接下来的几周内没有提出可行的解决方案,我将结束这个问题。
同时,我已要求我的同事与行为不端的提供商保留VM,以便测试提出的任何解决方案或调查。
最佳答案
Delphi 2007使用MSBuild执行实际的构建。但是,他们产品中用于在IDE和MSBuild之间同步更改的代码非常脆弱。我怀疑构建文件与IDE不同步。更新它们的简单方法如下:
打开注册表编辑器,转到
HKEY_LOCAL_MACHINE\SOFTWARE\Borland\BDS\5.0\Globals
将ForceEnvOptionsUpdate的值更改为1。
打开RAD Studio IDE。
为了确认我的怀疑,您需要找到Delphi.NET馈给MSBuild的文件。它们位于当前用户的个人资料下的某个位置。您可能还希望查看Delphi帮助中的选项,以使其执行详细的MSBuild输出。
关于asp.net - 带有Delphi 2007 for .NET的ASP.NET。无法加载文件或程序集…找到的程序集的 list 定义与程序集引用不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1556016/
C#内部访问修饰符的定义是内部:只能在包含程序集或友元程序集内访问。所以我的问题是什么是 C# 程序集?在包含程序集或 friend 程序集之内是什么意思?它是否意味着在同一个命名空间或项目中? 最佳
任何人都可以回答以下问题。我正在使用 c# 语言。 我可以将程序集调用为 .ddl 或 .exe 文件吗? 我可以将 Assembly Manifest 称为程序集吗? 程序集、元数据和程序集 lis
我正在从 Python 运行一个 .NET COM 程序集,只有当我将程序集 dll 和依赖项复制到我的 Python 根路径 c:\Python27 时才能使它正常工作。 这是不整洁的,所以我想将
作为世界上任何一名程序员,他/她一生中至少有一次,我正在尝试创建我的“革命性”,新的且唯一的操作系统。 :D 好吧,我正在使用虚拟模拟器(Oracle VM Virtual Box),为此我创建了一个
我创建了以下程序来读取 5 个数字,然后 dumpreg查看输入的数字... INCLUDE Irvine32.inc .data count = 5 scor
如何在保护模式下执行 IN 和 OUT 等受限指令? 我发现它需要足够高的特权级别(CPL)才能执行 IO 指令。我怎样才能在内核模式下运行,拥有 IO 权限或任何其他可能对我有帮助的东西? - 我希
目录 C# 程序集、模块和类型概念及关系 概述 程序集 模块 类型 程序集、模块和类型的关系 总结 引用
构建 maven assembly ,我留下了这样的东西: ${project.basedir} / LICENS
我的应用程序由几个核心程序集和几个扩展/插件程序集组成。为了让 MEF 知道插件必须提供的所有部件,即使我永远不会使用它们的任何部件,我也必须加载这些程序集。这使得应用程序需要更多时间来启动(如果我要
我对我们的构建基础结构有一个非常具体的要求,即将另一个 JAR 依赖项的一些内容复制到我的 Web 应用程序的特定子文件夹中。我们正在使用 maven-assembly-plugin,一个自然的方法是
为什么下面的指令会设置符号标志? mov al,0FEh sub al,2 据我了解,AL寄存器可以保存2^8 - 1或255。0FEh = 254(十进制)。减去 2 叶 252。这似乎是正数。 (
我以前使用过 NUnit,但已经有一段时间了,而且从来没有在这台机器上使用过。我在 Program Files 下解压了 2.4.8 版本,并且在尝试加载测试时不断收到此错误。 Could not l
我说的是一个使用 C# 进行游戏编程的小型游戏引擎。所以,我有一个嵌入单声道运行时的 C++ 应用程序(我称之为“启动器”)。我有一个用 C# 编写的程序集,它是我的游戏引擎类库。启动器按照 Embe
我对汇编相当陌生,并尝试从标准输入读取值(从 C 调用 scanf 函数)并将其打印回标准输出(使用 printf)。 .text readstr: .asciz "%d" #strin
谢谢帮助,我的问题是关于从下面的代码中收到的 ax 值? mov al,22h mov cl,0fdh imul cl 真机结果:ff9a 我的预期:00:9a(通过二进制相乘) 第一个数字是 22h
我正在开发一个汇编程序,该程序将整个文本文件读入缓冲区,然后将其显示在控制台中。它立即显示 24 行(每行的最大长度为 80,因为我使用 80 宽 * 25 高的 dossbox )然后等待用户输入,
我正在使用一个简单的程序集片段,使用 BIOS 作为引导加载程序的一部分将字符打印到屏幕上。这是引导加载程序代码。 [org 0x7c00] [bits 16] %include "a20_check
我只是想知道这段代码是什么意思: XOR EAX,EBX XOR EBX,EAX XOR EAX,EBX 最佳答案 那是 xor swapping . 在寄存器上执行它不会遇到常见的难看的失败案例。
我在新电脑上的 XNA 项目开始出现奇怪的错误。我有两个关于解决方案的项目和一个由它们使用的库。其中一个项目,一个 XNA 游戏项目,运行完美。另一个项目是 WindowsForm 和 XNA 的混合
是的,我正在努力实现类似的目标 __asm__(jmp label;); 其中 label 应替换为内存中保存的字符串值(结构体的字段)。 有没有办法做到这一点(或类似的方法可以让我跳转到运行时确定的
我是一名优秀的程序员,十分优秀!