标签:IntPtr MsiInterop string database C# viewPtr buffer MSI
原文链接:http://www.cnblogs.com/skywind/archive/2011/11/17/2252617.htmlPurpose: Parse MSI installer, to get information such as product name, product code, properties etc.
MSI is a standard windows install techonoly, so there are APIs for developers to access. But they are c/c++ methods, instead of C#. After google, i found the ‘Wrapping the Windows Installer 2.0 API’(http://www.codeproject.com/KB/cs/msiinterop.aspx), which is can let .net developers access MSI api easily.
After download the library, you can visit MSI datatable like this
1: using System;
2: using WindowsInstaller;
3:
4: namespace MsiTest
5: {
6: class Program
7: {
8: static void Main(string[] args)
9: {
10: test("c:\\xxx.msi");
11: }
12:
13: private static void test(string fileName)
14: {
15: IntPtr databasePtr;
16: var retDatabase = MsiInterop.MsiOpenDatabase(fileName, MsiDbPersistMode.ReadOnly, out databasePtr);
17:
18: IntPtr viewPtr;
19: var ret = MsiInterop.MsiDatabaseOpenView(databasePtr, "SELECT Value FROM Property where Property = 'SecureCustomProperties'", out viewPtr);
20:
21: IntPtr recordPtr = IntPtr.Zero;
22: ret = MsiInterop.MsiViewExecute(viewPtr, IntPtr.Zero);
23: ret = MsiInterop.MsiViewFetch(viewPtr, ref recordPtr);
24:
25: uint buffer_length = 2550;
26: string return_buffer = new string(' ', (int)buffer_length);
27: MsiInterop.MsiRecordGetString(recordPtr, 1, return_buffer, ref buffer_length);
28: MsiInterop.MsiCloseAllHandles();
29:
30: Console.WriteLine(return_buffer.Trim());
31: }
32:
33: }
34: }
35:
36:
转载于:https://www.cnblogs.com/skywind/archive/2011/11/17/2252617.html
标签:IntPtr,MsiInterop,string,database,C#,viewPtr,buffer,MSI 来源: https://blog.csdn.net/weixin_30715523/article/details/96728609
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。