begin process at 2012 02 10 02:57:42
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Application

 > ENVOI (SAUVEGARDE) D'UN FICHIER BINAIRE SUR UN SITE DISTANT (ASP CLASSIQUE)

ENVOI (SAUVEGARDE) D'UN FICHIER BINAIRE SUR UN SITE DISTANT (ASP CLASSIQUE)


 Information sur la source

 Description

Permet de sauver des base de données sur un site distant, sans composant payant.
Le principe est le suivant: on utilise le composant Microsoft.XMLHTTP pour envoyer en POST (tel qu'un formulaire) un fichier par l'intermédiaire de l'objet ADO.Stream. Le récepteur utilise aussi l'objet ADO.Stream pour sauver le fichier transmis.

Source

  • Fichier envoi.asp
  • <%@LANGUAGE="VBSCRIPT" CODEPAGE="1252"%>
  • <%
  • strImagePath = Server.MapPath("./" & Request.QueryString("f")) ' nom du fichier à transmettre
  • Set objADOStream = server.createobject("ADODB.Stream")
  • objADOStream.Open
  • objADOStream.Type = 1
  • objADOStream.LoadFromFile strImagePath
  • Response.Write("sending " & strImagePath & " ...<br>")
  • URLString = "http://www.votresite.ch/scripts/recois.asp?f=" & Request.QueryString("f")
  • Set objXMLHTTP = Server.CreateObject ("Microsoft.XMLHTTP")
  • objXMLHTTP.Open "POST", URLString, False
  • objXMLHTTP.setRequestHeader "Content-Type", "application/x-www-form-urlencoded"
  • objXMLHTTP.setRequestHeader "charset", "ISO-8859-1"
  • objXMLHTTP.send objADOStream.Read(-1)
  • reqstatus = objXMLHTTP.status
  • txtResult = objXMLHTTP.responseText ' ou ResponseBody !
  • Set objXMLHTTP = nothing
  • Response.Write("reqstatus = '" & reqstatus & "'<br>")
  • Response.Write("txtResult = '" & txtResult & "'<br>")
  • objADOStream.Close
  • Set objADOStream=Nothing
  • %>
  • Fichier recois.asp
  • <%@LANGUAGE="VBSCRIPT" CODEPAGE="1252"%>
  • <%
  • dim file
  • file = Request.QueryString("f") ' on demande le nom du fichier à sauver
  • Set adoStream = Server.CreateObject("ADODB.Stream")
  • adoStream.Type = 1 ' binary
  • adoStream.Open
  • adoStream.Write Request.BinaryRead(Request.TotalBytes) ' on intercepte les données émises
  • adoStream.SaveToFile Server.mapPath("./backup/" & file), 2 ' on sauve le fichier
  • adoStream.Close
  • Set adoStream = Nothing
  • Response.Write("fichier '" & file & "' correctement reçu !")
  • %>
Fichier envoi.asp
<%@LANGUAGE="VBSCRIPT" CODEPAGE="1252"%>
<%
strImagePath = Server.MapPath("./" & Request.QueryString("f"))    ' nom du fichier à transmettre
Set objADOStream = server.createobject("ADODB.Stream")
objADOStream.Open
objADOStream.Type = 1
objADOStream.LoadFromFile strImagePath

Response.Write("sending " & strImagePath & " ...<br>")

URLString = "http://www.votresite.ch/scripts/recois.asp?f=" & Request.QueryString("f")
Set objXMLHTTP = Server.CreateObject ("Microsoft.XMLHTTP")
objXMLHTTP.Open "POST", URLString, False
objXMLHTTP.setRequestHeader "Content-Type", "application/x-www-form-urlencoded"
objXMLHTTP.setRequestHeader "charset", "ISO-8859-1"
objXMLHTTP.send objADOStream.Read(-1)
reqstatus = objXMLHTTP.status
txtResult = objXMLHTTP.responseText		' ou ResponseBody !
Set objXMLHTTP = nothing

Response.Write("reqstatus = '" & reqstatus & "'<br>")
Response.Write("txtResult = '" & txtResult & "'<br>")

objADOStream.Close
Set objADOStream=Nothing 
%>


Fichier recois.asp
<%@LANGUAGE="VBSCRIPT" CODEPAGE="1252"%>
<%
dim file

file = Request.QueryString("f")            ' on demande le nom du fichier à sauver

Set adoStream = Server.CreateObject("ADODB.Stream")
adoStream.Type = 1	' binary
adoStream.Open
adoStream.Write Request.BinaryRead(Request.TotalBytes)		' on intercepte les données émises
adoStream.SaveToFile Server.mapPath("./backup/" & file), 2	' on sauve le fichier
adoStream.Close
Set adoStream = Nothing

Response.Write("fichier '" & file & "' correctement reçu !")
%>

 Conclusion

- Uploader envoi.asp sur le premier serveur
- Uploader recois.asp sur le deuxième serveur (de sauvegarde)
- Lancer envoi.asp?f=maBase.mdb sur le premier serveur

Le deuxième serveur sauve le fichier dans le répertoire "backup" et répond au script du premier serveur.


 Sources du même auteur

LOG DES ROBOTS QUI PASSENT SUR LE SITE

 Sources de la même categorie

Source avec Zip Source .NET (Dotnet) GESTION DE QUIZ par ysfhor
Source avec Zip Source avec une capture UPLOAD FILES WITH A PROGRESSBAR ( ASPUPLOAD ) par chunait
Source avec Zip GESTION PLANNING par Cpustack
Source avec Zip MINI MESSAGERIE par Simo_TSSI
Source avec Zip Source avec une capture TCHAT ASP COMPLET par jolauje

 Sources en rapport avec celle ci

Source .NET (Dotnet) SHAREPOINT 2007 - OBTERNIR LA LISTE DES FEATURES D'UN SITE par fabrice69
CHERCHER ET REMPLACER UN MOT DANS UN FICHIER TEXTE par roro59650
Source avec Zip Source avec une capture Source .NET (Dotnet) [VB 8][.NET 2][ATLAS]EXPLORATEUR (WINDOWS LIKE) DE FICHIER S... par FREMYCOMPANY
UPLOAD D'IMAGES VIA ADODB.STREAM ET SQL SERVER par Nicolas_kojack
TUTORIAL ASPSMARTUPLOAD (POUR AIDER CEUX QUI COMME MOI N'ONT... par ranouf

Commentaires et avis

Commentaire de Nicolas_kojack le 02/11/2007 17:54:38

Dans le même style :

enfin me semble t'il...

<!--METADATA TYPE="typelib"
      UUID="00000205-0000-0010-8000-00AA006D2EA4"
     NAME="ADODB Type Library"
-->
<%
Set objXMLHTTP = CreateObject("Microsoft.XMLHTTP")
objXMLHTTP.open "GET", "url du fichier", false

objXMLHTTP.send(null)

Set Stream = server.CreateObject("ADODB.Stream")

Stream.Type = adTypeBinary
Stream.Open

Stream.write objXMLHTTP.responseBody

Stream.SaveToFile "emplacement souhaité avec extension", adSaveCreateOverWrite
%>

En tous cas ca fonctionne au moins avec des fichiers MP3 et JPG pas essayé avec d'autres :p

Commentaire de Chrigou le 05/11/2007 08:24:13

Bonjour Nicolas,

Oui, ça fonctionne mais... il n'est pas possible de recevoir une base de données par exemple car elle est protégée en lecture directe. Il faut donc que l'émetteur prenne la décision de l'envoyer, d'ou mon code.
Merci quand même pour ton code.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Ecrire un fichier binaire [ par yoyo2 ] Bonjour à tous,Je voudrais savoir s'il y a un équivalent à CreateTextFile pour les fichiers binaires.En PHP on peut le faire mais en ASP je n'ai rien Problème sur UPLOADER UN FICHIER SANS COMPOSANT ! {NOUVELLE METHODE} [ par TORIUKE ] Bonjour,J'utilise la source de nix pour uploader des documents. En test sur mon PC (winn 2000), tout fonctionne très bien;... mais en application sur UPLOADER UN FICHIER SANS COMPOSANT V2.0 [ par netjl ] Salut Nix, j'utilise ton script UPLOADER UN FICHIER SANS COMPOSANT V2.0 je tente de laisser un message ici aussi, j'ai mis ton script sur un serveu upload d'un fichier sans composant ni formulaire [ par Jarodnet ] Hello !je recherche le moyen d'uploader un fichier en ASP (VBScript).Dans mon code, dans un premier temps, je parcours le répertoire partagé donné par composant mysmartupload : err "Subscript out of range" [ par did_28 ] Bonjour et merci à l'avance de votre aideJ'ai (a priori) installé le composant mysmartupload pour télécharger des photos sur mon site en asp.net, mais upload sans composant erreur [ par Florynth ] Bonjour, je me sers du upload sans composant de nix pour envoyer un fichier sur le serveur... Ça marche bien mais pas si le fichier et plus gros (et fichier temporaire [ par garnier54 ] Bonjour J’ai un programme développé en vb.net application web qui est obligé de stocké un fichier temporaire (une image en l’occurrence), la sauvegar Lire un fichier binaire [ par dan ] je voudrais lire le contenu d un fichier binaire, mais je ne trouve que la fonction OpenFileText pour lire le contenu du fichier, et evidemment j ai t UPLOADER UN FICHIER SANS COMPOSANT de NIX [ par BigDan ] Je suis en train de tester le Upload de Nix,j'ai toujours ce message d'erreurMicrosoft VBScript runtime error '800a000d' Type mismatch /infotab/test/c le fichier global.asa n'est pas lu lors de l'exécution. [ par fdnet ] Hello,J'ai installé PWS avec W98, et j'ai l'inpression que mon fichier global.asa n'est pas lu par le serveur au moment de l'exécution car le programm


Nos sponsors


Sondage...

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

Photothèque

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 3,042 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales