全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解微信小程序 wx.uploadFile 的编码坑

编写微信小程序时,用到 wx.uploadFile,用来上传图片+文本信息.然而在编写过程中,由于官方的 demo 和文档描述很少,在几个坑上耗费了不少时间.

这里分享一个和编码有关的坑,主要是由于真机预览时 formData 中的非字母、数字的 ASCII 编码的字符如中文、泰文传输到服务端将不会自动进行转码码,并会会产生乱码及溢出,从而导致错误。

微信的 uploadFile 类似与 html 中的form带文件上传的表单 ( enctype=”multipart/form-data” ), 这样 post 上传的表单,可以包含文件,同时包含其它的键值数据。微信小程序用 uploadFile 实现类似的操作. 我的微信小程序端的uploadFile 代码如下 :

wx.uploadFile({
      url: 'https://<upload_domain>/save',
      filePath:photoPath, //待上传的图片,由 chooseImage获得
      name:'food_image',
      formData: {
       latitude:0.0,
       longitude:0.0,
       restaurant_id:0,
       city:'北京',
       name:'beijing' // 名称
      }, // HTTP 请求中其他额外的 form data
      success: function(res){
       console.log("addfood success",res);
      },
      fail: function(res) {
       console.log("addfood fail",res);
      },
     })
},

服务端我用的 php 编写,这里接受文件的接口为 save ,我将 POST和_FILES 里的数据直接输出到info.log 文件中用来进行调试.代码如下:

public function save(Request $request)
{
  error_log("FILES:" . json_encode($_FILES) . "\r\n", 3, "./logs/info.log");
  error_log("POST: " . json_encode($_POST) . "\r\n", 3, "./logs/info.log");
  error_log("city: " . $_POST["city"] . "\r\n", 3, "./logs/info.log");
  error_log("name: " . $_POST["name"] . "\r\n", 3, "./logs/info.log");
  error_log("latitude: " . $_POST["latitude"] . "\r\n", 3, "./logs/info.log");
  error_log("longitude: " . $_POST["longitude"] . "\r\n", 3, "./logs/info.log");
  error_log("restaurant_id: " . $_POST["restaurant_id"] . "\r\n", 3, "./logs/info.log");
  error_log("tags: " . $_POST["city"] . "\r\n", 3, "./logs/info.log");
  echo 'success';
} 

在小程序开发工具中运行小程序,选择好图片后进行上传操作,服务器端成功接收到数据,info.log输出的数据信息如下:

FILES:{"food_image":{"name":"store_265332457o6zAJszC4WsrwhUy55eh7iKJt7EQ1480318543139.jpg","type":"image\/jpeg","tmp_name":"\/tmp\/phpe3zGok","error":0,"size":845941}}
POST: {"latitude":"0","longitude":"0","restaurant_id":"0","tags":"","city":"\u5317\u4eac","name":"\u0e1b\u0e31\u0e01\u0e01\u0e34\u0e48\u0e07"}
city: 北京
name: ปักกิ่ง
latitude: 0
longitude: 0
restaurant_id: 0

( ps:php 中,FILES 里有 tmp_name 为收到了文件,将临时文件从该路径中移动到指定目录便可保存文件,这里看到有 /tmp/phpe3zGok 临时文件,说明成功收到了文件) 将小程序预览到手机上,点击上传,但却出现了问题,如下所示:


POST 数据为空, FILES 成功收到,而单独输出的$_POST数据出现乱码(中文和泰文部分),出现了溢出.

可以看到,非英文,数字的数据是乱码,而其它数据没有问题,显然是编码出现了问题,POST 数据输出为空,由于乱码导致了溢出使得格式错乱.

编码有问题,那么就尝试改变它的编码进行传输, uploadFile 的参数中加入

header{“chartset”:”utf-8”}
//或者 
header{"content-type":'application/x-www-form-urlencoded'}

但是都没有什么效果,依然是在微信小程序工具中有效,而手机真机预览的时候出现乱码.在看到这篇帖子 【新手跳坑指南《三十九》wx.uploadFile】 才知道header 里的数据在真机预览的时候是无效的,需要改到 formData 中,受到了启发,尝试将编码数据加入formData 中,但仅仅传输了数据,并没有改变编码.依然是小程序开发工具中调试成功,而真机预览出了问题,这个估计要微信团队来回答了。

知道 header 是个bug , 那么编码的操作暂时只能手动进行了,于是我将小程序段的数据都进行编码. 在 javascript 中,字符串编码函数是 encodeURI, 在小程序中尝试,也有该函数,所以我将小程序代码改为如下

wx.uploadFile({
      url: 'https://<upload_domain>/save',
      filePath:photoPath, //待上传的图片,由 chooseImage获得
      name:'food_image',
      formData: {
       latitude:encodeURI(0.0),
       longitude:encodeURI(0.0),
       restaurant_id:encodeURI(0),
       city:encodeURI('北京'),
       name:encodeURI('beijing') // 名称
      }, // HTTP 请求中其他额外的 form data
      success: function(res){
       console.log("addfood success",res);
      },
      fail: function(res) {
       console.log("addfood fail",res);
      },
     })
},

服务器端, php 进行 url 解码的函数是 urldecode

public function save(Request $request)
{
  error_log("FILES:" . json_encode($_FILES) . "\r\n", 3, "./logs/info.log");
  error_log("POST: " . json_encode($_POST) . "\r\n", 3, "./logs/info.log");
  error_log("city: " . urldecode($_POST["city"]) . "\r\n", 3, "./logs/info.log");
  error_log("name: " . urldecode($_POST["name"]) . "\r\n", 3, "./logs/info.log");
  error_log("latitude: " . urldecode($_POST["latitude"]) . "\r\n", 3, "./logs/info.log");
  error_log("longitude: " . urldecode($_POST["longitude"]) . "\r\n", 3, "./logs/info.log");
  error_log("restaurant_id: " . urldecode($_POST["restaurant_id"]) . "\r\n", 3, "./logs/info.log");
  error_log("tags: " . urldecode($_POST["city"]) . "\r\n", 3, "./logs/info.log");
  echo 'success';
}

再次测试,真机预览测试输出如下:

ILES:{"food_image":{"name":"jpeg","type":"image\/jpeg","tmp_name":"\/tmp\/php1svqDs","error":0,"size":9561}}
POST: {"restaurant_id":"0","tags":"","longitude":"0","latitude":"0","city":"%E5%8C%97%E4%BA%AC","name":"%E0%B8%9B%E0%B8%B1%E0%B8%81%E0%B8%81%E0%B8%B4%E0%B9%88%E0%B8%87"}
city: 北京
name: ปักกิ่ง
latitude: 0
longitude: 0
restaurant_id: 0

可以看到,所有数据都正常输出,其中POST 数据中 city 和 name未解码前是 urlencode 编码形式的数据,解码后正常输出.
至此,我想使用小程序上传带文件信息到服务器端算是调通了, 希望这个方法能对出现同样问题的同学有一定帮助。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# 微信小程序  # wx.uploadFile  # 微信小程序uploadfile  # 小程序  # uploadfile  # 微信小程序wx.uploadfile 本地文件转base64的实现代码  # 微信小程序 wx.uploadFile无法上传解决办法  # 微信小程序 wx.uploadFile在安卓手机上面the same task is working  # 微信小程序uploadFile接口实现文件上传  # 上传  # 北京  # 我将  # 出现了  # 可以看到  # 收到了  # 表单  # 开发工具  # 服务端  # 为空  # 临时文件  # 有什么  # 我想  # 几个  # 出现乱码  # 是个  # 是在  # 也有  # 出了  # 都没 


相关文章: 常州企业建站如何选择最佳模板?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  文字头像制作网站推荐软件,醒图能自动配文字吗?  平台云上自主建站:模板化设计与智能工具打造高效网站  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  成都网站制作报价公司,成都工业用气开户费用?  婚礼视频制作网站,学习*后期制作的网站有哪些?  宝塔新建站点为何无法访问?如何排查?  如何在自有机房高效搭建专业网站?  如何通过多用户协作模板快速搭建高效企业网站?  网站制作公司,橙子建站是合法的吗?  广德云建站网站建设方案与建站流程优化指南  如何通过VPS建站无需域名直接访问?  代刷网站制作软件,别人代刷火车票靠谱吗?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建  实现虚拟支付需哪些建站技术支撑?  无锡营销型网站制作公司,无锡网选车牌流程?  建设网站制作价格,怎样建立自己的公司网站?  建站之星备案是否影响网站上线时间?  制作网页的网站有哪些,电脑上怎么做网页?  制作企业网站建设方案,怎样建设一个公司网站?  如何在香港服务器上快速搭建免备案网站?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  建站之星展会模板:智能建站与自助搭建高效解决方案  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  如何设计高效校园网站?  如何高效完成自助建站业务培训?  学校为何禁止电信移动建设网站?  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  制作国外网站的软件,国外有哪些比较优质的网站推荐?  高端企业智能建站程序:SEO优化与响应式模板定制开发  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  网站制作话术技巧,网站推广做的好怎么话术?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  Python路径拼接规范_跨平台处理说明【指导】  如何选购建站域名与空间?自助平台全解析  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  如何在阿里云部署织梦网站?  海南网站制作公司有哪些,海口网是哪家的?  如何高效完成独享虚拟主机建站?  如何在万网开始建站?分步指南解析  家具网站制作软件,家具厂怎么跑业务?  如何选择最佳自助建站系统?快速指南解析优劣  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  用v-html解决Vue.js渲染中html标签不被解析的问题  宝塔面板如何快速创建新站点?  制作网站的模板软件,网站怎么建设?  湖北网站制作公司有哪些,湖北清能集团官网? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。