이 글에서는 Node.js가 fs.renameSync를 호출할 때 보고되는 오류(오류: EXDEV, 크로스 디바이스 링크가 허용되지 않음)를 주로 소개합니다. 도움이 필요한 친구들이 참고할 수 있습니다.
파일 업로드 시 참고하세요. 함수, fs.renameSync 메서드 호출 시 오류가 발생했습니다
오류 코드는 다음과 같습니다.
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(); }); }
대략 분석한 결과, 디스크 파티션 간 파일 이동이나 운영 시 권한 문제가 있는 것으로 추정됩니다.
아래 두 가지 솔루션이 제공됩니다.
방법 1:
fs의 createReadStream, createWriteSream 및 unlinkSync 메서드를 주로 사용합니다
구체적인 코드는 다음과 같습니다.
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(); }); }
PS: 제가 사용하는 노드 버전은 다음과 같습니다. 0.10.69, 0.6 이하 버전을 사용하는 경우 util.pump
를 사용할 수 있습니다. 해당 코드는 위 코드의 readStream.on을 다음과 같이 변경하면 됩니다. (util 모듈 소개 참고)
util.pump(readStream,writeStream, function() { fs.unlinkSync('files.upload.path'); });
방법 2:
이 방법은 훨씬 간단합니다
form.uploadDir='tmp'만 추가하면 됩니다(임시 경로 작성)
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(); }); }
위 내용은 모두에게 도움이 되기를 바랍니다. 앞으로도 다들.
관련 기사:
JavaScript를 사용하여 추측 게임을 구현하는 방법(자세한 튜토리얼)
Three.js를 사용하여 WeChat Jump 게임 구현 방법
위 내용은 Node.js에서 fs.renameSync를 호출하면 오류가 발생합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!