首先,Msi是个数据库,也是第一次知道,用Orca数据库编辑工具能查看这个数据库中的各个表和字段;
知道了这些之后,就是如何在代码里实现了:
1、引用Microsoft Windows Installer Object Library这个Com组件,用它来操作这个数据库;可能会遇到引用失败,提示未能引用这个类,我就是一直引用不上,后来鼠标放到这个引用上,发现引用的是个本地的dll文件(C:\Windows\System32\msi.dll),直接把该文件拷贝到项目下,能正常引用,气不气;
2、然后就是代码,像这样:
//获取msi的版本号
private string GetMsiVersion(string installerPath) { Type t = Type.GetTypeFromProgID("WindowsInstaller.Installer"); Installer inst = (Installer)Activator.CreateInstance(t); Database d = inst.OpenDatabase( installerPath, MsiOpenDatabaseMode.msiOpenDatabaseModeReadOnly); View v = d.OpenView( "SELECT * FROM Property WHERE Property = 'ProductVersion'"); v.Execute(null); Record r = v.Fetch(); string result = r.get_StringData(2); return result; }
其他获取或修改,可以根据Orca工具,查看的表和字段,去自行修改sql语句就行了