Maison > interface Web > js tutoriel > le corps du texte

Téléchargement de fichiers du navigateur de simulation Node.js, compétences example_javascript

WBOY
Libérer: 2016-05-16 16:54:25
original
1314 Les gens l'ont consulté

Je l'ai posté sur OSChina, celui-là est le mien aussi, maintenant je le mets ici, haha ​​​​

Ce code ne peut télécharger qu'un seul fichier à la fois~~

Copiez le code Le code est le suivant :

var path=require("path"); fs");
var http=require("http");

//post value payload
var getfield=function(field, value) {
return 'Content-Disposition : form-data; name="' field '"rnrn' value 'rn';
}

//Charge utile du fichier
var getfieldHead=function (champ, nom de fichier) {
var fileFieldHead ='Content-Disposition: form- data; name="' field '"; filename="' filename '"rn' 'Content-Type: ' getMime(filename) 'rnrn'; }
//Get Mime
var getMime=function (nom de fichier) {
var mimes = {
'.png' : 'image/png',
'.gif' : 'image /gif',
' .jpg' : 'image/jpeg',
'.jpeg' : 'image/jpeg',
'.js' : 'application/json',
' .torrent' : 'application/octet -stream'
};
var ext = path.extname(filename);
var mime = mimes[ext]; :'application/octet-stream' ;
return mime;
}
//Obtenir la chaîne aléatoire de vérification des limites
var getBoundary=function() {
var max = 9007199254740992; >var dec = Math.random() * max;
var hex = dec.toString(36);
var border = hex;
return border;
var getBoundaryBorder=function (boundary ) {
return '--'border 'rn';
}
//Formatage du champ
function fieldPayload(opts) {
var payload= [];
for( var id dans opts.field){
payload.push(getfield(id,opts.field[id]));
}
payload.push("") ;
return payload.join (getBoundaryBorder(opts.boundary));
}

//post data
function postRequest (opts) {
filereadstream(opts,function (buffer ) {
var options= require('url').parse(opts.url);
var Header={}
var h=getBoundaryBorder(opts.boundary); fieldPayload(opts);
var a=getfieldHead(opts.param,opts.file);
var d="rn" h
Header["Content-Length"]=Buffer.byteLength(h e a d; ) buffer.length;
Header["Content-Type"]='multipart/form-data; opts.boundary;
options.headers=Header; ;
var req=http .request(options,function(res){
var data='';
res.on('data', function (chunk) {
data =chunk;
});
res.on('end', function () {
console.log(res.statusCode)
console.log(data);
}); >});
req .write(h e a);log.diy(h e a buffer d);
req.write(buffer);
req.end(d); 🎜>
}
//Lire le fichier
function filereadstream(opts, fn) {
var readstream = fs.createReadStream(opts.file,{flags:'r',encoding:null}) ;
var chunks= [];
var length = 0;
readstream.on('data', function(chunk) {
length = chunk.length;
chunks.push( chunk);
} );
readstream.on('end', function() {
var buffer = new Buffer(length);
for(var i = 0, pos = 0, size = chunks.length; i < size; i ) {
chunks[i].copy(buffer, pos);
pos = chunks[i].length; buffer);
} );
}

//Divers paramètres
var opt={
"url": http://xxxx.xx",//url
"file" :"00.jpg",//Emplacement du fichier
"param":"file",//Nom du champ de téléchargement du fichier
"field":{//Autres champs de publication
"client": "1",
"titre": "ok"
},
"boundary": ----WebKitFormBoundary" getBoundary()
}

postRequest(opt);
/*
------WebKitFormBoundaryuzKmkAovUuYsQ1Dtrn

Content-Disposition : form-data; nom="fichier" nom de fichier="00.jpg"rn
Content-Type : application /octet-stream
rn
rn filern

------WebKitFormBoundaryuzKmkAovUuYsQ1Dtrn

Content-Disposition : form-data name="fieldName; "
rn
rn valuern

------WebKitFormBoundaryuzKmkAovUuYsQ1Dt--
*/


Le dernier commentaire est au format standard" n" représente la chaîne réelle. Afin de paraître confortable, elle est également ajustée visuellement.
Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!