有关于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,现在有一个截图如下

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


分不够尽管说,开新帖就是,主要是解决问题。
...全文
425 17 打赏 收藏 转发到动态 举报
AI 作业
写回复
用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的问题,参考以下,可能能帮到你解决问题哦: 点我看看

62,244

社区成员

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

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

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

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