Rubrik: OLE/Registry/DLL · Verknüpfungen | VB-Versionen: VB.NET | 25.10.06 |
Verknüpfte Anwendung finden (.NET) Mit dieser Funktion lässt sich die im System zu einem bestimmten Dokument verknüpfte Anwendung ermitteln. | ||
Autor: Michael Schober | Bewertung: | Views: 11.472 |
ohne Homepage | System: WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Oftmals muß man/möchte man wissen, mit welcher Anwendung ein bestimmter Dokumenttyp geöffnet wird, d.h. welche Anwendung im System mit diesem Dateityp verknüpft ist. Mit der nachfolgenden Funktion ist dies kein Problem. Sie übergeben der Funktion einfach das entsprechende Dokument als Parameter und die Funktion liefert dann den Dateinamen inkl. Pfad der verknüpften Anwendung zurück.
Voraussetzung, dass das alles korrekt funktioniert, ist, dass das Dokument auch tatsächlich existiert. Existiert der übergebene Dateiname nicht, erstellt die Funktion eine temporäre Datei, die im Anschluß wieder gelöscht wird.
Public Class Form1 ' API-Deklaration Private Declare Function FindExecutable Lib "shell32.dll" _ Alias "FindExecutableA" ( _ ByVal lpFile As String, _ ByVal lpDirectory As String, _ ByVal lpResult As String) As Integer ... Public Function GetExecApp(ByVal sFile As String) As String ' verknüpfte Anwendung finden Dim AppExec As String = New String(" "c, 255) Dim RetVal As Long Dim SWriter As System.IO.StreamWriter Dim bExists As Boolean ' Falls Datei nicht existsiert, temporär erstellen bExists = System.IO.File.Exists(sFile) If Not bExists Then sFile = Application.StartupPath & "\temp" & sFile.Substring(sFile.LastIndexOf(".")) SWriter = System.IO.File.CreateText(sFile) SWriter.Write("") SWriter.Close() End If ' API Aufruf der überprüft welche EXE mit der Dateiendung assoziiert ist RetVal = FindExecutable(sFile, vbNullString, AppExec) AppExec = AppExec.Trim ' Falls Datei temporär erstellt wurde, jetzt wieder löschen If Not bExists Then Kill(sFile) ' Überprüfen ob Dateiassoziation vorhaden If RetVal <= 32 Or AppExec = String.Empty Then Return "" Else Return (AppExec) End If End Function End Class
Aufrufbeispiele:
Sie möchten wissen, ob für das Öffnen von PDF-Dateien eine entsprechende Anwendung vorhanden ist?
Dim sExecFile As String = GetExecApp("temp.pdf") If sExecFile.Length > 0 Then ...
Sie möchten wissen, ob der Internet-Explorer der Standard-Browser ist?
Dim sExecFile As String = GetExecApp("temp.htm") If sExecFile.Length > 0 Then If sExecFile.IndexOf("iexplore.exe") > 0 Then MsgBox("Standard-Browser = Internet Explorer!") End If End If