Cet article présente principalement l'erreur signalée lorsque Node.js appelle fs.renameSync (Erreur : EXDEV, lien multi-appareils non autorisé). Il est d'une grande valeur pratique. Les amis qui en ont besoin peuvent s'y référer
<.> avant d'en écrire un Lors de l'utilisation de la fonction de téléchargement de fichiers, il y a une erreur lors de l'appel de la méthode fs.renameSync Le code d'erreur est le suivant :function upload(response,request){ console.log("upload called"); var form = new formidable.IncomingForm(); console.log("about to parse"); form.parse(request, function(error, fields, files) { console.log("parsing done"); fs.renameSync(files.upload.path, "./tmp/test.jpg"); response.writeHead(200, {"Content-Type": "text/html"}); response.write("received image:<br/>"); response.write("<img src='/show' />"); response.end(); }); }
Deux solutions sont proposées ci-dessous :
Méthode 1 :
Utiliser principalement les méthodes createReadStream, createWriteSream et unlinkSync de fs Le code spécifique est le suivant :function upload(response,request){ console.log("upload called"); var form = new formidable.IncomingForm(); console.log("about to parse"); form.parse(request, function(error, fields, files) { console.log("parsing done"); // fs.renameSync(files.upload.path, "./tmp/test.jpg"); var readStream=fs.createReadStream(files.upload.path); var writeStream=fs.createWriteStream("./tmp/test.jpg"); readStream.pipe(writeStream); readStream.on('end',function(){ fs.unlinkSync(files.upload.path); }); response.writeHead(200, {"Content-Type": "text/html"}); response.write("received image:<br/>"); response.write("<img src='/show' />"); response.end(); }); }
Le code correspondant n'a besoin que de changer le readStream.on dans le code ci-dessus en : (notez l'introduction du module util)
util.pump(readStream,writeStream, function() { fs.unlinkSync('files.upload.path'); });
De cette façon, c'est beaucoup plus simple
Ajoutez simplement form.uploadDir='tmp' (écrivez un chemin temporaire)
Ce qui précède est ce que j'ai compilé pour tout le monde, j'espère. cela sera utile à tout le monde à l’avenir.function upload(response,request){ console.log("upload called"); var form = new formidable.IncomingForm(); form.uploadDir='tmp'; console.log("about to parse"); form.parse(request, function(error, fields, files) { console.log("parsing done"); fs.renameSync(files.upload.path, "./tmp/test.jpg"); response.writeHead(, {"Content-Type": "text/html"}); response.write("received image:<br/>"); response.write("<img src='/show' />"); response.end(); }); }
Articles associés :
Comment implémenter diverses méthodes de tri à l'aide de jsComment implémenter un jeu de devinettes en utilisant JavaScript (tutoriel détaillé) Comment utiliser le module de nœud et l'outil de gestion de packages npmComment utiliser JS pour implémenter la fonction de recherche d'entrée Comment implémenter WeChat Jump Game à l'aide de Three.jsCe qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!