vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Mails senden, abrufen und decodieren - ganz easy ;-)  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück
Rubrik: HTML/Internet/Netzwerk · WebBrowser   |   VB-Versionen: VB626.06.09
Download aus dem WebBrowser ohne Microsoft-Dialog

Hier wird gezeigt, wie man beim Klick auf eine Download-Datei im WebBrowser-Control diese sofort downloaden und in einen vorgegebenen Ordnern speichern kann, ohne dass der Microsoft Dialog vorher ercheint.

Autor:   Dieter OtterBewertung:     [ Jetzt bewerten ]Views:  18.060 
www.tools4vb.deSystem:  Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Mit nachfolgendem Code zeigen wir eine Möglichkeit auf, mit der sich Dateien beim Klick auf einen Download-Link im WebBrowser-Control sofort speichern lassen, ohne dass vorher der Microsoft Dialog erscheint.

Der Speicherort der Datei lässt sich somit ebenfalls individuell festlegen. Auch kann man festlegen, dass nur bestimmte Dateien, bspw. EXE- und ZIP-Files, sofort gespeichert werden.

' benötigte API-Deklarationen
Private Declare Function URLDownloadToFile Lib "urlmon" _
  Alias "URLDownloadToFileA" ( _
  ByVal pCaller As Long, _
  ByVal szURL As String, _
  ByVal szFileName As String, _
  ByVal dwReserved As Long, _
  ByVal lpfnCB As Long) As Long

Beim Klick auf einen Download-Link wird vom WebBrowser-Control das BeforeNavigate2-Ereignis ausgelöst. Hier kann man dann gezielt den Dateityp abfragen und den Download selbst vornehmen.

Private Sub WebBrowser1_BeforeNavigate2(ByVal pDisp As Object, _
  URL As Variant, Flags As Variant, TargetFrameName As Variant, _
  PostData As Variant, Headers As Variant, Cancel As Boolean)
 
  Dim sExt As String
 
  ' Datei-Extension ermitteln
  If InStr(URL, ".") > 0 Then
    sExt = LCase$(Mid$(URL, InStrRev(URL, ".")))
  End If
 
  ' Je nach Dateityp verschiedene Aktionen ausführen
  Select Case sExt
    Case ".zip", ".exe"
      ' Datei autom. downloaden
      Cancel = True
 
      ' Datei ins Anwendungsverzeichnis speichern
      Dim sLocalFile As String
      sLocalFile = App.Path & "\" & Mid$(URL, InStrRev(URL, "/") + 1)
 
      ' Download starten und warten, bis beendet
      If URLDownloadToFile(0, URL, sLocalFile, 0, 0) = 0 Then
        MsgBox "Download erfolgreich!"
      End If
 
    Case Else
      ' alle anderen Links direkt ausführen
  End Select
End Sub

Dieser Tipp wurde bereits 18.060 mal aufgerufen.

Voriger Tipp   |   Zufälliger Tipp   |   Nächster Tipp

Über diesen Tipp im Forum diskutieren
Haben Sie Fragen oder Anregungen zu diesem Tipp, können Sie gerne mit anderen darüber in unserem Forum diskutieren.

Aktuelle Diskussion anzeigen (1 Beitrag)

nach obenzurück


Anzeige

Kauftipp Unser Dauerbrenner!Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv  Vol.6
(einschl. Beispielprojekt!)

Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv!
- nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten
- Symbol-Galerie mit mehr als 3.200 Icons im modernen Look
Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m.
 
   

Druckansicht Druckansicht Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel