React Native端

使用react-native-image-picker 做出选择图片的操作,选择完成后,直接将图片Post至服务器,保存在服务器的某个地方(保存图片的路径需要公开显示),并返回图片的URL地址,Android应用中,只保存图片的URL地址。

component中代码

_chooseImage() {
ImagePicker.showImagePicker(options, (response) => {
console.log('Response = ', response); if (response.didCancel) {
console.log('用户取消了选择!');
}
else if (response.error) {
alert("ImagePicker发生错误:" + response.error);
}
else if (response.customButton) {
alert("自定义按钮点击:" + response.customButton);
}
else {
// let source = { uri: response.uri };
try { console.log(response); uploadImage(response.uri, response.fileName, this.state.userEntity.token).then((imageUrl) => {
console.log(imageUrl);
//http://f11.baidu.com/it/u=3806443343,4236894804&fm=72
// You can also display the image using data:
let source = { uri: 'data:image/jpeg;base64,' + response.data };
let oldselectIssueData = this.state.selectIssueData;
oldselectIssueData.IssueImageList.push({ uri: imageUrl }); console.log('设置后')
this.setState({
selectIssueData: oldselectIssueData
}); }).catch((err) => {
throw err;
}) } catch (error) {
Alert.alert('选择图片错误', error.message);
}
}
});
}

公共方法 uploadFile.js

import { default_API_url } from '../config/index';

export function uploadImage(imageUri, imageName, token) {
return new Promise((resolve, reject) => {
let data = new FormData()
if (imageUri) {
data.append('image', { uri: imageUri, name: imageName, type: 'image/jpg' })//加入图片
}
const config = {
method: 'POST',
headers: {
'Accept': 'application/json',
'Content-Type': 'multipart/form-data',
// 'Content-Language': React.NativeModules.RNI18n.locale,
'Authorization': token,
},
body: data,
}
fetch(default_API_url + '/fittingImage', config)
.then(function (response) {
return response.json();
}).then((responseData) => {
console.log('responseData', responseData);
if (responseData.resultType == 'SUCCESS') {
return resolve(default_API_url + '/' + responseData.results.imageName);//返回的是文件名,这里将它加入服务器的名称
} else {
return reject(responseData.resultMsg || 'Unknow Error');
}
}).catch((error) => {
return reject(error);
});
});
} export default uploadImage;

Nodejs端,后端使用multer作为上传文件中间件,参考地址:http://cnodejs.org/topic/564f32631986c7df7e92b0dbhttps://dzone.com/articles/upload-files-or-images-to-server-using-nodejs

service.js中,增加

app.use(express.static(config.fittingImagePath));//公开某个文件夹

router中的方法:

exports.UploadFittingImage = (req, res) => {
try { upload(req, res, function (err) {
if (err) {
return res.json({ url: err.message })
}
logger.info('req.files---------------------', req.files[0].filename)//因为支持的是多文件上传,这里我返回的是第一个文件名
return res.status(200).json(responseFormat(null, { imageName: req.files[0].filename }));
});
}
catch (error) {
return res.status(400).json(responseFormat(error, null));
}
};

公共方法fileUpload.js

import multer from 'multer';
import Config from 'config-lite';
let config = Config(__dirname); let Storage = multer.diskStorage({
destination: function (req, file, callback) {//文件保存位置,我这里是配置的
callback(null, "./" + config.fittingImagePath);
},
filename: function (req, file, callback) {//重命名文件
callback(null, file.fieldname + "_" + Date.now() + "_" + file.originalname);
}
}); let upload = multer({
storage: Storage
}).array("image", 1); //Field name and max count
//导出对象
module.exports = upload;

整体的流程

react native android 上传文件,Nodejs服务端获取上传的文件的更多相关文章

  1. springboot 服务端获取前端传过来的参数7种方式

    下面为7种服务端获取前端传过来的参数的方法  1.直接把表单的参数写在Controller相应的方法的形参中,适用于GET 和 POST请求方式 这种方式不会校验请求里是否带参数,即下面的userna ...

  2. React Native Android启动白屏的一种解决方案上

    我们用RN去开发Android应用的时候,我们会发现一个很明显的问题,这个问题就是启动时每次都会有1~3秒的白屏时间,直到项目加载出来 为什么会出现这个问题? RN开发的应用在启动时,首先会将js b ...

  3. Node.js:上传文件,服务端如何获取文件上传进度

    内容概述 multer是常用的Express文件上传中间件.服务端如何获取文件上传的进度,是使用的过程中,很常见的一个问题.在SF上也有同学问了类似问题<nodejs multer有没有查看文件 ...

  4. Wince 6.0适用 .NET 使用HttpRequest的Post上传文件,服务端的Web API接收Post上传上来的文件 代码

    //调用的示例 private string fileName = "InStorageData.csv"; string filePath = parentPath + Comm ...

  5. react-native —— 在Mac上配置React Native Android开发环境排坑总结

    配置React Native Android开发环境总结 1.卸载Android Studio,在终端(terminal)执行以下命令: rm -Rf /Applications/Android\ S ...

  6. MVC文件上传04-使用客户端jQuery-File-Upload插件和服务端Backload组件实现多文件异步上传

    本篇使用客户端jQuery-File-Upload插件和服务端Badkload组件实现多文件异步上传.MVC文件上传相关兄弟篇: MVC文件上传01-使用jquery异步上传并客户端验证类型和大小  ...

  7. MIME类型-服务端验证上传文件的类型

    MIME的作用 : 使客户端软件,区分不同种类的数据,例如web浏览器就是通过MIME类型来判断文件是GIF图片,还是可打印的PostScript文件. web服务器使用MIME来说明发送数据的种类, ...

  8. 【2017-05-30】WebForm文件上传。从服务端删除文件

    用 FileUpload控件进行上传文件. <asp:FileUpload ID="FileUpload1"  runat="server" /> ...

  9. asp.net上传Excel文件到服务端进行读取

    1.我们IIS是使用7.5,由于在网站中上传Excel文件到服务端进行数据读取时候出现读取失败情况.一开始以为是没有按照office软件问题,其实不然,因为server是64位操作系统,如果我们要使用 ...

随机推荐

  1. 【Tools】Windows下Github的配置和使用

    1.在网址:http://windows.github.com/下载git软件,具体的安装步骤可以参见:Windows 系统下Git安装图解 2.同样根据上面的教程生成SSH key: 3.将publ ...

  2. linux sh脚本异常:/bin/sh^M:bad interpreter: No such file or directory

    在Linux中执行.sh脚本,异常/bin/sh^M: bad interpreter: No such file or directory.这是不同系统编码格式引起的:在windows系统中编辑的. ...

  3. 【POJ】1222 EXTENDED LIGHTS OUT

    [算法]高斯消元 [题解] 高斯消元经典题型:异或方程组 poj 1222 高斯消元详解 异或相当于相加后mod2 异或方程组就是把加减消元全部改为异或. 异或性质:00 11为假,01 10为真.与 ...

  4. Winform MD5

    1:MD5 http://www.cmd5.com/ 字节数组----字符串 //将字节数组中每个元素按照指定的编码格式解析成字符串//直接将数组ToString()//将字节数组中的每个元素ToSt ...

  5. vue router mode 设置"hash"与"history"的区别

    router官网的说明如下: ********************************************我是官网说明分隔符--开始**************************** ...

  6. mybatis 显示 sql日志

    #项目日志logging.level.com.zhang.com=debug #mybatis sql相关日志显示logging.level.org.mybatis.spring=DEBUGloggi ...

  7. javascript性能

    1.js文件放在底部 js文件具有阻塞机制,放在头部,需要等待js下载解析完毕之后才能下载渲染页面,因此需要放在底部

  8. 2017-2018-1 20179205《Linux内核原理与设计》第四周作业

    <Linux内核原理与分析> 视频学习及实验操作 Linux内核源代码 视频中提到了三个我们要重点专注的目录下的代码,一个是arch目录下的x86,支持不同cpu体系架构的源代码:第二个是 ...

  9. POJ1014(多重背包)

    Dividing Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 65044   Accepted: 16884 Descri ...

  10. unbutu下Io language的解释器安装

    今晚看Io,然后要安装解释器,然后就记录下来了... 首先去官网下载 http://iolanguage.com 在页面下方的binaries那里找到自己系统对应的版本,我的是x64deb的,本来是下 ...