react native实现往服务器上传网络图片的实例


Posted in Javascript onAugust 07, 2017

如下所示:

let common_url = 'http://192.168.1.1:8080/'; //服务器地址
let token = '';  //用户登陆后返回的token
/** 
 * 使用fetch实现图片上传
 * @param {string} url 接口地址
 * @param {JSON} params body的请求参数
 * @return 返回Promise 
 */
function uploadImage(url,params){
  return new Promise(function (resolve, reject) {
    let formData = new FormData();
    for (var key in params){
      formData.append(key, params[key]);
    }
    let file = {uri: params.path, type: 'application/octet-stream', name: 'image.jpg'};
    formData.append("file", file);
    fetch(common_url + url, {
      method: 'POST',
      headers: {
        'Content-Type': 'multipart/form-data;charset=utf-8',
        "x-access-token": token,
      },
      body: formData,
    }).then((response) => response.json())
      .then((responseData)=> {
        console.log('uploadImage', responseData);
        resolve(responseData);
      })
      .catch((err)=> {
        console.log('err', err);
        reject(err);
      });
  });

使用方法

let params = {
  userId:'abc12345',  //用户id
  path:'file:///storage/emulated/0/Pictures/image.jpg'  //本地文件地址
}
uploadImage('app/uploadFile',params )
  .then( res=>{
    //请求成功
    if(res.header.statusCode == 'success'){
      //这里设定服务器返回的header中statusCode为success时数据返回成功
      upLoadImgUrl = res.body.imgurl; //服务器返回的地址
    }else{
       //服务器返回异常,设定服务器返回的异常信息保存在 header.msgArray[0].desc
      console.log(res.header.msgArray[0].desc);
    }
  }).catch( err=>{ 
     //请求失败
  })

注意点

let file = {uri: params.path, type: 'application/octet-stream', name: 'image.jpg'}中的type也可能是multipart/form-data
formData.append("file", file)中的的file字段也可能是images

普通网络请求参数是JSON对象

图片上传的请求参数使用的是formData对象

总结:

React Native中虽然也内置了XMLHttpRequest 网络请求API(也就是俗称的ajax),但XMLHttpRequest 是一个设计粗糙的 API,不符合职责分离的原则,配置和调用方式非常混乱,而且基于事件的异步模型写起来也没有现代的 Promise 友好。而Fetch 的出现就是为了解决 XHR 的问题,所以react Native官方推荐使用Fetch API。

fetch请求示例如下:

return fetch('http://facebook.github.io/react-native/movies.json')
  .then((response) => response.json())
  .then((responseJson) => {
   return responseJson.movies;
  })
  .catch((error) => {
   console.error(error);
  });

使用Promise封装fetch请求

let common_url = 'http://192.168.1.1:8080/'; //服务器地址
let token = '';  
/**
 * @param {string} url 接口地址
 * @param {string} method 请求方法:GET、POST,只能大写
 * @param {JSON} [params=''] body的请求参数,默认为空
 * @return 返回Promise
 */
function fetchRequest(url, method, params = ''){
  let header = {
    "Content-Type": "application/json;charset=UTF-8",
    "accesstoken":token //用户登陆后返回的token,某些涉及用户数据的接口需要在header中加上token
  };
  console.log('request url:',url,params); //打印请求参数
  if(params == ''){  //如果网络请求中没有参数
    return new Promise(function (resolve, reject) {
      fetch(common_url + url, {
        method: method,
        headers: header
      }).then((response) => response.json())
        .then((responseData) => {
          console.log('res:',url,responseData); //网络请求成功返回的数据
          resolve(responseData);
        })
        .catch( (err) => {
          console.log('err:',url, err);   //网络请求失败返回的数据    
          reject(err);
        });
    });
  }else{  //如果网络请求中带有参数
    return new Promise(function (resolve, reject) {
      fetch(common_url + url, {
        method: method,
        headers: header,
        body:JSON.stringify(params)  //body参数,通常需要转换成字符串后服务器才能解析
      }).then((response) => response.json())
        .then((responseData) => {
          console.log('res:',url, responseData);  //网络请求成功返回的数据
          resolve(responseData);
        })
        .catch( (err) => {
          console.log('err:',url, err);  //网络请求失败返回的数据 
          reject(err);
        });
    });
  }
}

使用fetch请求,如果服务器返回的中文出现了乱码,则可以在服务器端设置如下代码解决:

produces="text/html;charset=UTF-8"

fetchRequest使用如下:
GET请求:
fetchRequest('app/book','GET')
  .then( res=>{
    //请求成功
    if(res.header.statusCode == 'success'){
      //这里设定服务器返回的header中statusCode为success时数据返回成功

    }else{
      //服务器返回异常,设定服务器返回的异常信息保存在 header.msgArray[0].desc
      console.log(res.header.msgArray[0].desc);
    }
  }).catch( err=>{ 
    //请求失败
  })

POST请求:

let params = {
  username:'admin',
  password:'123456'
}
fetchRequest('app/signin','POST',params)
  .then( res=>{
    //请求成功
    if(res.header.statusCode == 'success'){
      //这里设定服务器返回的header中statusCode为success时数据返回成功

    }else{
      //服务器返回异常,设定服务器返回的异常信息保存在 header.msgArray[0].desc 
      console.log(res.header.msgArray[0].desc);
    }
  }).catch( err=>{ 
    //请求失败
  })

fetch超时处理

由于原生的Fetch API 并不支持timeout属性,如果项目中需要控制fetch请求的超时时间,可以对fetch请求进一步封装实现timeout功能,代码如下:

fetchRequest超时处理封装

/**
 * 让fetch也可以timeout
 * timeout不是请求连接超时的含义,它表示请求的response时间,包括请求的连接、服务器处理及服务器响应回来的时间
 * fetch的timeout即使超时发生了,本次请求也不会被abort丢弃掉,它在后台仍然会发送到服务器端,只是本次请求的响应内容被丢弃而已
 * @param {Promise} fetch_promise  fetch请求返回的Promise
 * @param {number} [timeout=10000]  单位:毫秒,这里设置默认超时时间为10秒
 * @return 返回Promise
 */
function timeout_fetch(fetch_promise,timeout = 10000) {
  let timeout_fn = null; 

  //这是一个可以被reject的promise
  let timeout_promise = new Promise(function(resolve, reject) {
    timeout_fn = function() {
      reject('timeout promise');
    };
  });

  //这里使用Promise.race,以最快 resolve 或 reject 的结果来传入后续绑定的回调
  let abortable_promise = Promise.race([
    fetch_promise,
    timeout_promise
  ]);

  setTimeout(function() {
    timeout_fn();
  }, timeout);

  return abortable_promise ;
}

let common_url = 'http://192.168.1.1:8080/'; //服务器地址
let token = '';  
/**
 * @param {string} url 接口地址
 * @param {string} method 请求方法:GET、POST,只能大写
 * @param {JSON} [params=''] body的请求参数,默认为空
 * @return 返回Promise
 */
function fetchRequest(url, method, params = ''){
  let header = {
    "Content-Type": "application/json;charset=UTF-8",
    "accesstoken":token //用户登陆后返回的token,某些涉及用户数据的接口需要在header中加上token
  };
  console.log('request url:',url,params); //打印请求参数
  if(params == ''){  //如果网络请求中没有参数
    return new Promise(function (resolve, reject) {
      timeout_fetch(fetch(common_url + url, {
        method: method,
        headers: header
      })).then((response) => response.json())
        .then((responseData) => {
          console.log('res:',url,responseData); //网络请求成功返回的数据
          resolve(responseData);
        })
        .catch( (err) => {
          console.log('err:',url, err);   //网络请求失败返回的数据    
          reject(err);
        });
    });
  }else{  //如果网络请求中带有参数
    return new Promise(function (resolve, reject) {
      timeout_fetch(fetch(common_url + url, {
        method: method,
        headers: header,
        body:JSON.stringify(params)  //body参数,通常需要转换成字符串后服务器才能解析
      })).then((response) => response.json())
        .then((responseData) => {
          console.log('res:',url, responseData);  //网络请求成功返回的数据
          resolve(responseData);
        })
        .catch( (err) => {
          console.log('err:',url, err);  //网络请求失败返回的数据 
          reject(err);
        });
    });
  }
}

以上这篇react native实现往服务器上传网络图片的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
原始XMLHttpRequest方法详情回顾
Nov 28 Javascript
浅谈JavaScript实现面向对象中的类
Dec 09 Javascript
JavaScript小技巧整理
Dec 30 Javascript
js实现文字截断功能
Sep 14 Javascript
JS弹性运动实现方法分析
Dec 15 Javascript
BootStrap select2 动态改变值的方法
Feb 10 Javascript
简单实现jQuery弹窗效果
Oct 30 jQuery
jquery获取select选中值的文本,并赋值给另一个输入框的方法
Aug 21 jQuery
微信小程序使用canvas的画图操作示例
Jan 18 Javascript
浅谈Node框架接入ELK实践总结
Feb 22 Javascript
mpvue小程序循环动画开启暂停的实现方法
May 15 Javascript
微信小程序实现页面监听自定义组件的触发事件
Nov 01 Javascript
使用Node.js实现简易MVC框架的方法
Aug 07 #Javascript
ES6新增的math,Number方法
Aug 06 #Javascript
ComboBox(下拉列表框)通过url加载调用远程数据的方法
Aug 06 #Javascript
JS解析url查询参数的简单代码
Aug 06 #Javascript
使用bootstraptable插件实现表格记录的查询、分页、排序操作
Aug 06 #Javascript
JS中定位 position 的使用实例代码
Aug 06 #Javascript
Node.js 基础教程之全局对象
Aug 06 #Javascript
You might like
二十行语句实现从Excel到mysql的转化
2006/10/09 PHP
PHP写杨辉三角实例代码
2011/07/17 PHP
php中将网址转换为超链接的函数
2011/09/02 PHP
飞鱼(shqlsl) javascript作品集
2006/12/16 Javascript
javascript 关于# 和 void的区别分析
2009/10/26 Javascript
jquery三个关闭弹出层的小示例
2013/11/05 Javascript
JavaScript中this关键词的使用技巧、工作原理以及注意事项
2014/05/20 Javascript
超漂亮的Bootstrap 富文本编辑器summernote
2016/04/05 Javascript
深入浅析Extjs中store分组功能的使用方法
2016/04/20 Javascript
JavaScript操作 url 中 search 部分方法函数
2016/06/15 Javascript
全面了解javascript中的错误处理机制
2016/07/18 Javascript
vue watch监听对象及对应值的变化详解
2018/02/24 Javascript
JS使用正则表达式获取小括号、中括号及花括号内容的方法示例
2018/06/01 Javascript
JavaScript设计模式之建造者模式实例教程
2018/07/02 Javascript
JavaScript类的继承操作实例总结
2018/12/20 Javascript
[05:28]刀塔密之一:团结则存
2014/07/03 DOTA
[01:02]DOTA2上海特锦赛SHOWOPEN
2016/03/25 DOTA
Python遍历文件夹和读写文件的实现代码
2016/08/28 Python
python使用turtle库绘制时钟
2020/03/25 Python
TensorFlow实现模型评估
2018/09/07 Python
Django框架的中的setting.py文件说明详解
2018/10/15 Python
python 计算一个字符串中所有数字的和实例
2019/06/11 Python
Python with语句用法原理详解
2020/07/03 Python
python线程里哪种模块比较适合
2020/08/02 Python
如何用Python 加密文件
2020/09/10 Python
Python操作dict时避免出现KeyError的几种解决方法
2020/09/20 Python
公司财务自我评价分享
2013/12/17 职场文书
高中自我鉴定
2013/12/20 职场文书
汽车专业学生自我评价
2014/01/19 职场文书
订货会主持词
2015/07/01 职场文书
2016领导干部廉洁自律心得体会
2016/01/13 职场文书
检讨书格式
2019/04/25 职场文书
创业计划书详解
2019/07/19 职场文书
关于党风廉政建设宣传教育月的活动总结!
2019/08/08 职场文书
centos8安装nginx1.9.1的详细过程
2021/08/02 Servers
redis 解决库存并发问题实现数量控制
2022/04/08 Redis