React express项目中 upload image或file


一开始遇到这个问题时,我是这样定位它的:node.js upload image

一番搜索后我得到这样的解决办法,引入express multer中间件

注:Multer是一个nodejs中间件,用来处理http提交multipart/form-data,也就是文件上传。它是在busboy的基础上开发的。

<form method='post' action='/upload' enctype='multipart/form-data' >
    <input type="file" name='file1'/>
    <input type="submit" value="add"/>
</form>

enctype是用来规定将form发送到服务器之前如何进行编码的,有以下三种值:

  • application/x-www-form-urlencoded:(默认)发送前将空格变为+,特殊字符转换为 ASCII 十六进制值
  • multipart/form-data:不进行编码
  • text/plain:只把空格变为+,不不编码特殊字符
var multer = require('multer');
var upload = multer({dest: 'public/images/'});

router.post('/upload',upload.any(),function (req,res,next) {
    res.send(req.files);
})

上面的代码发送post请求后,在后台这样处理,req.files就是接受到的文件,此方法会将文件上传到dest指向的路径中去。

BUT!!!当我将上述代码引入到一个react项目中时,这种做法是行不通的

我搜索:react express multer,得到的大多是一些没有意义的解答,于是我开始重新定位这个问题,搜索:express react upload image,搜索到很多中方法,但归根结底都是为type="file"input输入框绑定一个onChange事件,然后e.target.files[0]就可以取到这个文件,类型为Object,然后将这个Object类型的东西发送给服务器。
那么问题来了,我想要上传一个文件到项目里,显然,现在发送回来的东西并不能直接上传!

app.put("/upload", function(req, res){  
    req.busboy.on("file", function(fieldName, file){
        console.log(fieldName, file);
        res.send(path);
    }); 
    req.pipe(req.busboy);
});

在控制台打印file时,发现它的类型是fileStream,那么,我当前要做的,一定是将stream转换为file本身,于是我搜索:node.js stream to file
直到找到fs.createReadStream可以解决这个问题:

于是,我改写了自己的代码:

app.put("/upload", function(req, res){  
    req.busboy.on("file", function(fieldName, file){
        const path = __dirname + "/public/" + 'test.jpg';
        var writeStream = require('fs').createWriteStream(path)

        file.on('data', function(data) {
            writeStream.write(data)
        });

        file.on('end', function() {
            writeStream.end();
        });

        file.on('error', function(err) {
            console.log('something is wrong :( ');
            writeStream.close();
        });

        res.send(path);
    }); 
    req.pipe(req.busboy);
});

接下来,这个demo调试成功我将它引入我的项目中,就在我以为大功告成的时候,新的bug站起来了,明明demo里可以跑通的代码,拿到项目里就挂!!!

request.put("/upload")    
    .attach("image-file", this.state.image, this.state.image.name)
    .end(function(res){
        console.log(res);
    });

我在服务器端sendpath,返回给页面后,前端打印了res,但是demo里可以成功打印接受到的东西,项目里打印的一直是null
于是我在服务器端返回res.send('success!'),打印的依然是null,接着我查看network,发现``HeadersRequest URLhttp://localhost:4000/uploadresponse的确成功返回了路径信息,也就是说我的后台部分没有问题,问题出现在前端部分,且出现在request.put部分。<br/>因为const request = require("superagent");`所以我搜索:superagent,得到以下结果:

  • superagent 是一个轻量的,渐进式的ajax api,可读性好,学习曲线低,内部依赖nodejs原生的请求api,适用于nodejs环境下.
    另外关于end方法的参数,我发现有两个版本:
  1. 两年前的版本:
 .end(function(res){
     if (res.ok) {
       alert('yay got ' + JSON.stringify(res.body));
     } else {
       alert('Oh no! error ' + res.text);
     }
  1. 最新的:
.end(function(err, res){
     if (err || !res.ok) {
       alert('Oh no! error');
     } else {
       alert('yay got ' + JSON.stringify(res.body));
     }

对比两个版本,我的猜想是:由于我代码中是一个参数,所以;它默认res第一个参数err,因为请求和响应是成功的,所以打印的err一直是null,然后我做了以下验证:

.end(function(err, res){
    console.log(err);
    console.log(res);

果然,打印的结果为:null ,Response {req: Request, xhr: XMLHttpRequest, text: "/home/cyr/holiday-workspace/reactjs-image-upload/public/test.jpg", ......},猜想正确!!恩,总结完毕,碎觉觉哈哈!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容