許多文件擴(kuò)展名和一個(gè)可執(zhí)行應(yīng)用程序綁定。正因?yàn)檫@樣你才可以使用Invoke-Item打開(kāi)一個(gè)文檔。
要找出一個(gè)給定后綴名的文件是由那個(gè)默認(rèn)引用程序打開(kāi)它,并不麻煩。我們可以使用Windows系統(tǒng)中的注冊(cè)表,自行編程解決。但是在掃描注冊(cè)表時(shí),要稍微留意一下32位和64位機(jī)器的問(wèn)題,這不是本文重點(diǎn),點(diǎn)到為止。
另外一種途徑,稍顯旁門(mén)左道,調(diào)用Windows API。下面的例子會(huì)演示如何調(diào)用。采取這種途徑最大的優(yōu)勢(shì)是借力于操作系統(tǒng)。而你的付出成本只是用C#代碼間接調(diào)用Windows API中的函數(shù)而已:
$Source = @" using System;using System.Text;using System.Runtime.InteropServices;public class Win32API { [DllImport("shell32.dll", EntryPoint="FindExecutable")] public static extern long FindExecutableA(string lpFile, string lpDirectory, StringBuilder lpResult); public static string FindExecutable(string pv_strFilename) { StringBuilder objResultBuffer = new StringBuilder(1024); long lngResult = 0; lngResult = FindExecutableA(pv_strFilename, string.Empty, objResultBuffer); if(lngResult >= 32) { return objResultBuffer.ToString(); } return string.Format("Error: ({0})", lngResult); } } "@ Add-Type -TypeDefinition $Source -ErrorAction SilentlyContinue $FullName = 'c:/Windows/windowsupdate.log'$Executable = [Win32API]::FindExecutable($FullName) "$FullName will be launched by $Executable"
唯一有個(gè)限制,就是FindExecutable()需要檢查的文件是存在的,你不能只用文件擴(kuò)展名去請(qǐng)求。
另外@reidca反饋說(shuō)該方法不能檢測(cè)MMC加載項(xiàng)打開(kāi)的文件,比如cer和pfx證書(shū)文件,程序會(huì)崩潰。
新聞熱點(diǎn)
疑難解答
圖片精選