Fantacy
人工智能,智能运营,智能客服,企业知识管理系统(Kmaster,SuperKM)
posts - 86,comments - 162,trackbacks - 14

前几天遇到一个恶心的问题,跟同事一块解决了,在这里记录下过程。

比较懒,直接转他的blog:

http://www.cnblogs.com/caochenghua/p/6530053.html

 

 

报错信息如下

“System.IO.FileNotFoundException”类型的异常在 Google.Apis.dll 中发生,但未在用户代码中进行处理

其他信息: 未能加载文件或程序集“Zlib.Portable, Version=1.11.0.0, Culture=neutral, PublicKeyToken=431cba815f6a8b5b”或它的某一个依赖项。系统找不到指定的文件。

项目中已经包含了Zlib.Portable.dll ,查看了文件属性,确认版本号已经保持一致

 

使用PowerShell查看现有Dll的PublicKeyToken,发现是未强签名版本。

1   ([system.reflection.assembly]::loadfile("D:\Web\bin\Zlib.Portable.dll")).FullName
2  
3  Zlib.Portable, Version=1.11.0.0, Culture=neutral, PublicKeyToken=null

 

那原因应该就在这里了,

找到https://github.com/google/google-api-dotnet-client-samples代码并下载

用Visual Studio打开下载的项目,点项目-》管理NuGet程序包,提示自动更新依赖的DLL文件,更新完成

此时,我们需要的Zlib.Portable.dll已经可以在文件夹中显示了:google-api-dotnet-client-samples-master\packages\Zlib.Portable.Signed.1.11.0\lib\portable-net4+sl5+wp8+win8+wpa81+MonoTouch+MonoAndroid

打开Windows PowerShell使用以下命令比较新生成的Zlib.Portable.dll和原有的项目中Zlib.Portable.dll :

复制代码
1 ([system.reflection.assembly]::loadfile("D:\Zlib.Portable.dll")).FullName
2 
3 Zlib.Portable, Version=1.11.0.0, Culture=neutral, PublicKeyToken=431cba815f6a8b5b
4 
5  ([system.reflection.assembly]::loadfile("D:\Web\bin\Zlib.Portable.dll")).FullName
6 
7 Zlib.Portable, Version=1.11.0.0, Culture=neutral, PublicKeyToken=null
复制代码

 

区别是后者PublicKeyToken=null前者不是,至此原因大概明了,没有强签名的dll已经不能使用了,Google Review API对此进行了更加严格的限制是导致报错的原因吧

把新生成的Zlib.Portable.dll替换到服务器上,报错果然消失了!恢复正常

posted on 2017-03-15 10:49 calmzeal 阅读(...) 评论(...) 编辑 收藏