Salut tout le monde
Je me demande est-ce-qu'il y a un moyen pour récupérer le lien direct avec le nom du fichier (RogueKiller_setup.exe) de cette URL afin de le télécharger par Autoit ?
L'URL en question : http://download.adlice.com/api/?action= ... type=setup
Merci !
La connaissance s'acquiert par l'expérience, tout le reste n'est que de l'information. Albert Einstein
Le savoir est la seule matière qui s'accroît quand on la partage. Socrate
Salut
Mon but est de faire une commande externe que je vais l'utiliser en ligne de commande ou bien dans un script batch avec une barre de progression, donc ce que je cherche pour télécharger le fichier en question est d'obtenir son lien diect càd qui a une extension à la fin de l'URL .exe ou bien .zip ou bien .rar etc ...
mais dans cette dernière URL je n'ai aucune information sur l'obtention de tel lien direct ? j'espére que vous me comprenez ce que je veux dire ?
Donc, ma question est-ce-qu'il y a un moyen de le retrouver par une regexp ou autre astuce ?
Voilà le code source du Downloader.au3
@echo off Mode 70,3& color 0A Title Download with Progress Bar using Autoit by Hackoo 2018 echo( echo Please Wait a While...The download is in progress ... Set"URL=https://downloads.malwarebytes.com/file/mb3/" Call Download "%URL%" for/f "delims="%%ain('Dir /b "%~dp0*.exe" ^| find /I "setup"')do( Start """%%a" ) Exit
La connaissance s'acquiert par l'expérience, tout le reste n'est que de l'information. Albert Einstein
Le savoir est la seule matière qui s'accroît quand on la partage. Socrate
Bonjour.
De plus en plus de site utilisent des pages php qui ne permet pas de connaitre l'adresse d'origine, du coup impossible d'avoir dans certains cas cette adresse.
Pour le cas de Malwarebytes, vous pouvez utiliser votre navigateur pour télécharger l'installateur et sur l'historique des téléchargement extraire le lien d'origine.
Ce qui donne pour malwarebyes : https://data-cdn.mbamupdates.com/web/mb ... 0.4478.exe
Après sur certains sites, il est possible de connaitre le nom de l'exécutable à télécharger en fouillant l'historique des versions, mais cela ne fonctionne pas tout le temps.
Si vous arrivez à surveiller les échanges entre le logiciel concerné et le site de l'éditeur, vous pouvez aussi arriver à connaitre le lien de contrôle du numéro de version, mais là encore, rien de fiable à 100%.
C'est pareil sur ce forum, avec les avatars ; l'emplacement où est stocké l'image n'est pas indiqué dans l'URL. Par exemple, quand je télécharge le fichier download/file.php?avatar=4404_1331030491.jpg dans un logiciel de téléchargement, le nom du fichier qui sera enregistré est 4404.jpg. Ce nom de fichier est apparemment indiqué dans les en-têtes HTTP.
Option Explicit If AppPrevInstance()Then MsgBox"The script is already launching"& vbCrlf &_ CommandLineLike(WScript.ScriptName),VbExclamation,"The script is already launching" WScript.Quit Else Const Copyright =" by Hackoo 2018" Dim Title : Title ="Get Header Location and download file"& Copyright Const WHR_EnableRedirects =6 Dim Default_Link,Base_Link,Dynamic_Link,Flag,Question,DirectLink,Save2File Dim fso,ws,Temp,WaitingMsg,oExec Default_Link ="https://download.toolslib.net/download/file/1/1388" Set fso = CreateObject("Scripting.FileSystemObject") Set ws = CreateObject("WScript.Shell") Temp = ws.ExpandEnvironmentStrings("%Temp%") ' "https://downloads.malwarebytes.com/file/mb3/" 'Tested OK ==> Malwarebytes v3.4.4 ' "https://download.toolslib.net/download/file/1/1388" 'Tested OK ==> Adwcleaner v7.0.8.0 ' "https://autoitscript.fr/forum/download/file.php?avatar=10_1293979860.png" 'Tested OK ==> Avatar Tlem ' "https://autoitscript.fr/forum/download/file.php?avatar=4404_1331030491.jpg" 'Tested OK ==> Avatar Hackoo ' "https://autoitscript.fr/forum/download/file.php?avatar=4001_1422642041.gif" 'Tested OK ==> Avatar walkson ' "https://autoitscript.fr/forum/download/file.php?avatar=1520_1467716891.png" 'Tested OK ==> Avatar orax ' "https://www.google.tn/images/branding/googlelogo/1x/googlelogo_color_272x92dp.png" Tested OK ==> a direct link example '"https://www.developpez.net/forums/avatars/312790-hackoofr.gif" Tested OK ==> a direct link example Base_Link =InputBox("Copy and paste your link here to get the response header",Title,Default_Link) If CheckDirectLink(Base_Link)=TrueAnd Instr(Base_Link,"php")=0Then'Check if it is a direct link Save2File = GetFileNamefromDirectLink(Base_Link) WaitingMsg = "Please wait ... The download of : <font color=Yellow>"& DblQuote(Save2File) & "</font> is in progress ..." Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar Call LaunchProgressBar()'Launch of the Waiting Bar Call Download(Base_Link,Save2File) pause(3) Call CloseProgressBar() MsgBox "The download of the file : "& Save2File & vbCrlf &_ "is Completed !",vbInformation,Title wscript.Quit() End If Call GetHeaderLocation(Base_Link) If Flag = True And CheckDirectLink(GetHeaderLocation(Base_Link)) = True Then 'Checking for a direct link of Malwarebytes Save2File = GetFileNamefromDirectLink(GetHeaderLocation(Base_Link)) DirectLink = GetHeaderLocation(Base_Link) 'wscript.echo DirectLink & vbCrlf & Save2File Question = MsgBox("Did you want to download this file ?" & vbCrlf &_ Save2File,vbQuestion+vbYesNo,Title) If Question = vbYes Then WaitingMsg = "Please wait ... The download of : <font color=Yellow>"& DblQuote(Save2File) & "</font> is in progress ..." Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar Call LaunchProgressBar()'Launch of the Waiting Bar Call Download(DirectLink,Save2File) Call CloseProgressBar() MsgBox "The download of the file : "& Save2File & vbCrlf &_ "is Completed !",vbInformation,Title Wscript.Quit() End If ElseIf Instr(Base_Link,"toolslib") <> 0 And Flag = True Then 'for Adwcleaner Dynamic_Link = Extract_Dynamic_Link(GetDataFromURL(Base_Link,"Get","")) Save2File = GetFileName(GetHeaderLocation(Dynamic_Link)) Question =MsgBox("The Dynamic Link is = "& Dynamic_Link & vbcrlf & vbcrlf &_ "Response of The Dynamic Link is : "& vbcrlf & GetHeaderLocation(Dynamic_Link)& vbCrlf & vbCrlf &_ "Extracted FileName is = "& Save2File,vbYesNo+vbQuestion,Title) If Question = vbYes Then WaitingMsg ="Please wait ... The download of : <font color=Yellow>"& DblQuote(Save2File)&"</font> is in progress ..." Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar Call LaunchProgressBar() 'Launch of the Waiting Bar Call Download(Dynamic_Link,Save2File) Call CloseProgressBar() MsgBox"The download of the file : "& Save2File & vbCrlf &_ "is Completed !",vbInformation,Title Else Wscript.Quit() End If ElseIf Instr(Base_Link,"php")>0And Flag =FalseThen Save2File = GetFileName(GetHeaderLocation(Base_Link))' for site of autoitscript.fr Question = MsgBox("Did you want to download this file ?" & vbCrlf &_ Save2File,vbQuestion+vbYesNo,Title) If Question = vbYes Then WaitingMsg = "Please wait ... The download of : <font color=Yellow>"& DblQuote(Save2File) & "</font> is in progress ..." Call CreateProgressBar(Title,WaitingMsg)'Creation of Waiting Bar Call LaunchProgressBar()'Launch of the Waiting Bar Call Download(Base_Link,Save2File) pause(3) Call CloseProgressBar() MsgBox "The download of the file : "& Save2File & vbCrlf &_ "is Completed !",vbInformation,Title Else Wscript.Quit() End If End If End If '------------------------------------------------ Function GetHeaderLocation(URL) On Error Resume Next Dim h,GetLocation Set h = CreateObject("WinHttp.WinHttpRequest.5.1") h.Option(WHR_EnableRedirects)=False h.Open"HEAD", URL ,False h.Send() GetLocation = h.GetResponseHeader("Location") If Err =0Then Flag =True GetHeaderLocation = GetLocation Else Flag =False GetHeaderLocation = h.GetResponseHeader("Content-Disposition") End If End Function '--------------------------------------------- Function GetFileName(Data) Dim regEx, Match, Matches,FileName Set regEx = New RegExp regEx.Pattern = "\x27{2}(\w.*)" regEx.IgnoreCase = True regEx.Global = True If regEx.Test(Data) Then Set Matches = regEx.Execute(Data) For Each Match in Matches FileName = Match.subMatches(0) Next Else Set regEx = New RegExp regEx.Pattern = "\x22(\w.*)\x22" regEx.IgnoreCase = True regEx.Global = True Set Matches = regEx.Execute(Data) For Each Match in Matches FileName = Match.subMatches(0) Next End If GetFileName = FileName End Function '--------------------------------------------- Function Extract_Dynamic_Link(Data) Dim regEx, Match, Matches,Dynamic_Link Set regEx = New RegExp regEx.Pattern= Base_Link &"\?s=[^""]*" regEx.IgnoreCase=True regEx.Global=True Set Matches = regEx.Execute(Data) For Each Match in Matches Dynamic_Link = Match.Value Next Extract_Dynamic_Link = Dynamic_Link End Function '------------------------------------------------ Function GetDataFromURL(strURL, strMethod, strPostData) Dim lngTimeout Dim strUserAgentString Dim intSslErrorIgnoreFlags Dim blnEnableRedirects Dim blnEnableHttpsToHttpRedirects Dim strHostOverride Dim strLogin Dim strPassword Dim strResponseText Dim objWinHttp lngTimeout = 59000 strUserAgentString = "http_requester/0.1" intSslErrorIgnoreFlags = 13056 '13056: ignore all err,0: accept no err blnEnableRedirects =True blnEnableHttpsToHttpRedirects =True strHostOverride ="" strLogin ="" strPassword ="" Set objWinHttp = CreateObject("WinHttp.WinHttpRequest.5.1") objWinHttp.SetTimeouts lngTimeout, lngTimeout, lngTimeout, lngTimeout objWinHttp.Open strMethod, strURL If strMethod ="POST"Then objWinHttp.setRequestHeader"Content-type", _ "application/x-www-form-urlencoded" End If If strHostOverride <>""Then objWinHttp.SetRequestHeader"Host", strHostOverride End If objWinHttp.Option(0)= strUserAgentString objWinHttp.Option(4)= intSslErrorIgnoreFlags objWinHttp.Option(6)= blnEnableRedirects objWinHttp.Option(12)= blnEnableHttpsToHttpRedirects If(strLogin <>"")And(strPassword <>"")Then objWinHttp.SetCredentials strLogin, strPassword,0 End If On Error Resume Next objWinHttp.Send(strPostData) If Err.Number=0Then If objWinHttp.Status="200"Then GetDataFromURL = objWinHttp.ResponseText Else GetDataFromURL ="HTTP "& objWinHttp.Status&" "& _ objWinHttp.StatusText End If Else GetDataFromURL ="Error "& Err.Number&" "& Err.Source&" "& _ Err.Description End If On Error GoTo 0 Set objWinHttp = Nothing End Function '------------------------------------------------ Sub Download(URL,Save2File) Dim File,Line,BS,ws On Error Resume Next Set File = CreateObject("WinHttp.WinHttpRequest.5.1") File.Open "GET",URL, False File.Send() If err.number <> 0 then Line = Line & vbcrlf & "Error Getting File" Line = Line & vbcrlf & "Error " & err.number & "(0x" & hex(err.number) & ") " & vbcrlf &_ err.description Line = Line & vbcrlf & "Source " & err.source MsgBox Line,vbCritical,"Error getting file" Err.clear wscript.quit End If If File.Status = 200 Then ' File exists and it is ready to be downloaded Set BS = CreateObject("ADODB.Stream") Set ws = CreateObject("wscript.Shell") BS.type=1 BS.open BS.Write File.ResponseBody BS.SaveToFile Save2File,2 ElseIf File.Status=404Then MsgBox"File Not found : "& File.Status,vbCritical,"Error File Not Found" Else MsgBox"Unknown Error : "& File.Status,vbCritical,"Error getting file" End If End Sub '------------------------------------------------ Function GetFileNamefromDirectLink(URL) Dim ArrFile,FileName ArrFile = Split(URL,"/") FileName = ArrFile(UBound(ArrFile)) GetFileNamefromDirectLink = FileName End Function '------------------------------------------------ Function CheckDirectLink(URL) Dim regEx Set regEx = New RegExp regEx.Pattern="(.exe|.zip|.rar|.msi|.vbs|.bat|.hta|.txt|.log|.doc"& _ "|.docx|.xls|.xlsx|.pdf|.mp3|.mp4|.avi|.png|.jpg|.jpeg|.bmp|.gif)" regEx.IgnoreCase=True regEx.Global=False If regEx.Test(URL)Then CheckDirectLink =True End If End Function '------------------------------------------------ '********************************************************************************************** Sub CreateProgressBar(Title,WaitingMsg) Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec Set ws = CreateObject("wscript.Shell") Set fso = CreateObject("Scripting.FileSystemObject") Temp = WS.ExpandEnvironmentStrings("%Temp%") PathOutPutHTML = Temp &"\Barre.hta" Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True) fhta.WriteLine"<HTML>" fhta.WriteLine"<HEAD>" fhta.WriteLine"<Title> "& Title &"</Title>" fhta.WriteLine"<HTA:APPLICATION" fhta.WriteLine"ICON = ""magnify.exe"" " fhta.WriteLine"BORDER=""THIN"" " fhta.WriteLine"INNERBORDER=""NO"" " fhta.WriteLine"MAXIMIZEBUTTON=""NO"" " fhta.WriteLine"MINIMIZEBUTTON=""NO"" " fhta.WriteLine"SCROLL=""NO"" " fhta.WriteLine"SYSMENU=""NO"" " fhta.WriteLine"SELECTION=""NO"" " fhta.WriteLine"SINGLEINSTANCE=""YES"">" fhta.WriteLine"</HEAD>" fhta.WriteLine"<BODY text=""white""><CENTER>" fhta.WriteLine"<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">"& WaitingMsg &"</font></marquee>" fhta.WriteLine"<img src="""" />" fhta.WriteLine"</CENTER></BODY></HTML>" fhta.WriteLine"<SCRIPT LANGUAGE=""VBScript""> " fhta.WriteLine"Set ws = CreateObject(""wscript.Shell"")" fhta.WriteLine"Temp = WS.ExpandEnvironmentStrings(""%Temp%"")" fhta.WriteLine"Sub window_onload()" fhta.WriteLine" CenterWindow 490,110" fhta.WriteLine" Self.document.bgColor = ""DarkOrange"" " fhta.WriteLine" End Sub" fhta.WriteLine" Sub CenterWindow(x,y)" fhta.WriteLine" Dim iLeft,itop" fhta.WriteLine" window.resizeTo x,y" fhta.WriteLine" iLeft = window.screen.availWidth/2 - x/2" fhta.WriteLine" itop = window.screen.availHeight/2 - y/2" fhta.WriteLine" window.moveTo ileft,itop" fhta.WriteLine"End Sub" fhta.WriteLine"</script>" fhta.close End Sub '********************************************************************************************** Sub LaunchProgressBar() Set oExec = Ws.Exec("mshta.exe " & Temp & "\Barre.hta") End Sub '********************************************************************************************** Sub CloseProgressBar() oExec.Terminate End Sub '********************************************************************************************** Function DblQuote(Str) DblQuote = Chr(34) & Str & Chr(34) End Function '********************************************************************************************** Sub Pause(Secs) Wscript.Sleep(Secs *1000) End Sub '********************************************************************************************** Function AppPrevInstance() With GetObject("winmgmts:" & "{impersonationLevel=impersonate}!\\.\root\cimv2") With .ExecQuery("SELECT * FROM Win32_Process WHERE CommandLine LIKE " & CommandLineLike(WScript.ScriptFullName) & _ " AND CommandLine LIKE '%WScript%' OR CommandLine LIKE '%cscript%'") AppPrevInstance = (.Count > 1) End With End With End Function '********************************************************************************************* Function CommandLineLike(ProcessPath) ProcessPath = Replace(ProcessPath,"\","\\") CommandLineLike ="'%"& ProcessPath &"%'" End Function '*********************************************************************************************
Donc, il me reste juste quelqu'un parmi vous m'aide a le traduire en Autoit
Multi-Downloader.vbs pour télécharger des fichiers avec des liens directs ou dynamiques
(7.55 Kio) Téléchargé 151 fois
La connaissance s'acquiert par l'expérience, tout le reste n'est que de l'information. Albert Einstein
Le savoir est la seule matière qui s'accroît quand on la partage. Socrate