有关于asp.net 2.0程序中出现引用了一个System.Web.dll 4.0版本引起的错误

leonbingo 2014-11-26 10:36:22
我最近维护一个项目,遇到了这样一个问题,一个asp.net 程序,本身基于.net 3.5 开发,部署在IIS上面,应用程序池肯定是选择asp.net 2.0版本,其他页面都没有问题,就是,其中有一个页面会报错,报错非常奇怪,说的是找不到 System.web, 4.0.0.0, 这明明是一个.NET 3.5程序,为什会出来一个引用了4.0的dll,仔细查看了每个项目的.NET 版本,都是3.5,没有用过4.0,现在有一个截图如下

请各位提供解决方案,如何排查该类问题,是一个很大的维护项目。


分不够尽管说,开新帖就是,主要是解决问题。
...全文
375 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
弘毅致远 2014-11-28
  • 打赏
  • 举报
回复
另外.net dll有个version,还有个runtime version。两个可能不一样。

我们现在用的mvc version是3的,runtime version却是4。从这个方面去看看。
弘毅致远 2014-11-28
  • 打赏
  • 举报
回复
1.看服务器最近是不是有update或者装了新的应用,or部署了新应用。如果有,针对性的找出可能涉及到.net库更新的地方,把旧的dll copy回来。 2.如果没有更新,把现有复杂的多个应用都尽可能切分开。为当前出问题的应用建一个独立干净的环境。 3.重启服务器试试。我们之前碰到过.net mvc 莫明其妙出问题,找不出什么原因。IIS重启多次也无效,后来重启server又自动ok了。 4.终极策列,及早上报领导,请专家。技术问题总有解决方案的,会者不难,难者不会。不要等到严重自己付不起责任的时候才去汇报。
暖枫无敌 2014-11-27
  • 打赏
  • 举报
回复
检查下这台服务器上是不是有安装什么其他软件,或者有什么更新造成冲突什么的。
leonbingo 2014-11-27
  • 打赏
  • 举报
回复
不知道是什么导致程序一定要去找4.0的dll
leonbingo 2014-11-27
  • 打赏
  • 举报
回复
很难啊。。。
程序猿老曾 2014-11-27
  • 打赏
  • 举报
回复
根据提示好像是有些文件没有被找到!! 最好还是好好检查下那个报错的界面。 像你说的其他环境是好的,你要检查下其他环境和这个出错的环境究竟有什么不一样。 我觉得可能不是System.Web 4.0.0.0的问题!!
leonbingo 2014-11-27
  • 打赏
  • 举报
回复
引用 7 楼 taomanman 的回复:
[quote=引用 4 楼 leonbingo 的回复:] [quote=引用 1 楼 taomanman 的回复:] 很可能是使用VS编译版本造成的.NET Framework的问题,参考以下,可能能帮到你解决问题哦: 点我看看
你这个不对啊,我说过了我所有的程序都是基于.net 3.5的,是老程序,,而且每个项目我都看过,都是3.5的,这个项目已经运行了5,6年了,[/quote] 是不是系统后来升级过,拷贝过aspx文件和dll到项目中,但是升级时版本不一致,然后拷贝过来的,虽然你发布应用是.NET 2.0的应用程序池[/quote] 同样的发布,我们有多套环境,其他环境是好的,只是在这一个环境里面出这错,系统会尝试载入2.0和4.0的system.web我怎么都没找到什么地方引用了,我从正常工作的环境里把dll拷贝过来都不行,所以我问怎么排查调试
暖枫无敌 2014-11-27
  • 打赏
  • 举报
回复
引用 4 楼 leonbingo 的回复:
[quote=引用 1 楼 taomanman 的回复:] 很可能是使用VS编译版本造成的.NET Framework的问题,参考以下,可能能帮到你解决问题哦: 点我看看
你这个不对啊,我说过了我所有的程序都是基于.net 3.5的,是老程序,,而且每个项目我都看过,都是3.5的,这个项目已经运行了5,6年了,[/quote] 是不是系统后来升级过,拷贝过aspx文件和dll到项目中,但是升级时版本不一致,然后拷贝过来的,虽然你发布应用是.NET 2.0的应用程序池
  • 打赏
  • 举报
回复
web.config里面是不是配置成了4.0,如果不是的话,再找下match.config
wangweimutou 2014-11-27
  • 打赏
  • 举报
回复
帮顶啦。。。。。。。。。。。。。。
leonbingo 2014-11-26
  • 打赏
  • 举报
回复
引用 5 楼 caozhy 的回复:
有没有引用第三方的库,间接引用到了system.web 4.0? 另外,建议找一台干净的,没有装过.net 4.0的机器测试下。
有引用第三方库,关键问题是,在有一台机器上运行好的,不知道要怎么排查
threenewbee 2014-11-26
  • 打赏
  • 举报
回复
有没有引用第三方的库,间接引用到了system.web 4.0? 另外,建议找一台干净的,没有装过.net 4.0的机器测试下。
leonbingo 2014-11-26
  • 打赏
  • 举报
回复
引用 1 楼 taomanman 的回复:
很可能是使用VS编译版本造成的.NET Framework的问题,参考以下,可能能帮到你解决问题哦: 点我看看
你这个不对啊,我说过了我所有的程序都是基于.net 3.5的,是老程序,,而且每个项目我都看过,都是3.5的,这个项目已经运行了5,6年了,
暖枫无敌 2014-11-26
  • 打赏
  • 举报
回复
右键你的项目,仔细查看下.NET FrameWork的版本吧
暖枫无敌 2014-11-26
  • 打赏
  • 举报
回复
还有就是检查下IIS权限是否充足,对于你那个页面的功能,是否有写权限啊什么的
暖枫无敌 2014-11-26
  • 打赏
  • 举报
回复
很可能是使用VS编译版本造成的.NET Framework的问题,参考以下,可能能帮到你解决问题哦: 点我看看
网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令做个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表添加 Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要添加的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次会话。如果在本次会话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表已有的条目。   bootcfg /disableredirect 在启动引导程序禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执行彻底检查。该参数不对驱动器做任何更改。 /r   找到坏扇区并恢复可读取的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)找到该文件,将试着在 Windows 安装 CD 找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建新的分区。   /delete   删除现有分区。   device_name   要创建或删除分区的设备。设备名称可从 map 命令的输出获得。例如,设备名称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除分区。仅与 /delete 同时使用。以下是驱动器名称的范例:   D:   partition_name   以分区名称表示的待删除分区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是分区名称的范例:   DeviceHardDisk0Partition1    大小   要创建的分区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除分区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上添加一个 20 MB 的分区:   diskpart /add Device HardDisk0 20   Fixboot

62,025

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧