出错提示:
在32位错做系统的开发机上引用了第三方插件(oracle的dataaccess)完成的项目,将发布的程序拷贝到64位的服务器上进行发布时提示无法加载或找不到dataaccess文件。
错误原因:
因为是在32位的的服务器上开发,在添加引用文件时,添加的引用文件是在32位操作系统上使用的,而在64位系统中则会找64位的文件所以导致找不到或版本不对,从而导致报错。
解决方法:
1、在64位操作系统找到对应的引用文件(oracle的dataaccess),要是64位操作系统使用的文件,拷贝该文件替换掉发布项目中bin文件中对应的文件;
2、修改配置文件Web.config:在对应的配置节点增加下面的内容:
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Oracle.DataAccess"
publicKeyToken="89B483F429C47342"
culture="neutral" />
<bindingRedirect
oldVersion="2.112.1.2"
newVersion="2.112.1.0"/>
</dependentAssembly>
</assemblyBinding>
</runtime>
说明:在发布的时候一定要将引用的第三方文件的属性中的“是否复制到本地”设置为true,否则发布的程序或缺少该程序集。