微信小程序填坑:上传头像;wx.chooseImage,wx.uploadFile

2023-12-18 22:38

本文主要是介绍微信小程序填坑:上传头像;wx.chooseImage,wx.uploadFile,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

因为wx.chooseImage,wx.uploadFile的组合十分常见,并且极其容易遇到坑;请作者来检查一下是否有问题,因为我看到原文底下有一堆不明代码。。。

上传头像, 使用wx.chooseImage({})后 在使用wx.uploadFile({})结合起来使用.

http://www.wxapp-union.com/portal.php?mod=view&aid=907

http://www.wxapp-union.com/forum.php?mod=viewthread&tid=3454

wx.uploadFile(上传文件)相关问题

示例代码:


Page({data: {src: "../../image/photo.png",  //绑定image组件的src//略...
  },onLoad: function (options) {//略... 
  },uploadPhoto() {var that = this; wx.chooseImage({count: 1, // 默认9sizeType: ['compressed'], // 可以指定是原图还是压缩图,默认二者都有sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有success: function (res) {// 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片var tempFilePaths = res.tempFilePaths;upload(that, tempFilePaths);}})}
})function upload(page, path) {wx.showToast({icon: "loading",title: "正在上传"}),wx.uploadFile({url: constant.SERVER_URL + "/FileUploadServlet",filePath: path[0], name: 'file',header: { "Content-Type": "multipart/form-data" },formData: {//和服务器约定的token, 一般也可以放在header中'session_token': wx.getStorageSync('session_token')},success: function (res) {console.log(res);if (res.statusCode != 200) { wx.showModal({title: '提示',content: '上传失败',showCancel: false})return;}var data = res.datapage.setData({  //上传成功修改显示头像src: path[0]})},fail: function (e) {console.log(e);wx.showModal({title: '提示',content: '上传失败',showCancel: false})},complete: function () {wx.hideToast();  //隐藏Toast
      }})
}

后端代码


public class FileUploadServlet extends HttpServlet {private static final long serialVersionUID = 1L;private static Logger logger = LoggerFactory.getLogger(FileUploadServlet.class);public FileUploadServlet() {super();}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {JsonMessage<Object> message = new JsonMessage<Object>();EOSResponse eosResponse = null;String sessionToken = null;FileItem file = null;InputStream in = null;ByteArrayOutputStream swapStream1 = null;try {request.setCharacterEncoding("UTF-8"); //1、创建一个DiskFileItemFactory工厂  DiskFileItemFactory factory = new DiskFileItemFactory();  //2、创建一个文件上传解析器  ServletFileUpload upload = new ServletFileUpload(factory);//解决上传文件名的中文乱码  upload.setHeaderEncoding("UTF-8");   // 1. 得到 FileItem 的集合 items  List<FileItem> items = upload.parseRequest(request);logger.info("items:{}", items.size());// 2. 遍历 items:  for (FileItem item : items) {  String name = item.getFieldName();  logger.info("fieldName:{}", name);// 若是一个一般的表单域, 打印信息  if (item.isFormField()) {  String value = item.getString("utf-8");  if("session_token".equals(name)){sessionToken = value;}}else {if("file".equals(name)){file = item;}}  }//session校验if(StringUtils.isEmpty(sessionToken)){message.setStatus(StatusCodeConstant.SESSION_TOKEN_TIME_OUT);message.setErrorMsg(StatusCodeConstant.SESSION_TOKEN_TIME_OUT_MSG);}String userId = RedisUtils.hget(sessionToken,"userId");logger.info("userId:{}", userId);if(StringUtils.isEmpty(userId)){message.setStatus(StatusCodeConstant.SESSION_TOKEN_TIME_OUT);message.setErrorMsg(StatusCodeConstant.SESSION_TOKEN_TIME_OUT_MSG);}//上传文件if(file == null){}else{swapStream1 = new ByteArrayOutputStream();in = file.getInputStream();byte[] buff = new byte[1024];int rc = 0;while ((rc = in.read(buff)) > 0) {swapStream1.write(buff, 0, rc);}Usr usr = new Usr();usr.setObjectId(Integer.parseInt(userId));final byte[] bytes = swapStream1.toByteArray();eosResponse= ServerProxy.getSharedInstance().saveHeadPortrait(usr, new RequestOperation() {@Overridepublic void addValueToRequest(EOSRequest request) {request.addMedia("head_icon_media", new EOSMediaData(EOSMediaData.MEDIA_TYPE_IMAGE_JPEG, bytes));}});// 请求成功的场合if (eosResponse.getCode() == 0) {message.setStatus(ConstantUnit.SUCCESS);} else {message.setStatus(String.valueOf(eosResponse.getCode()));}}} catch (Exception e) {e.printStackTrace();} finally{try {if(swapStream1 != null){swapStream1.close();}} catch (IOException e) {e.printStackTrace();}try {if(in != null){in.close();}} catch (IOException e) {e.printStackTrace();}}PrintWriter out = response.getWriter();  out.write(JSONObject.toJSONString(message));  }protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doGet(request, response);}}





这篇关于微信小程序填坑:上传头像;wx.chooseImage,wx.uploadFile的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/510002

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

C#控制台程序同步调用WebApi实现方式

《C#控制台程序同步调用WebApi实现方式》控制台程序作为Job时,需同步调用WebApi以确保获取返回结果后执行后续操作,否则会引发TaskCanceledException异常,同步处理可避免异... 目录同步调用WebApi方法Cls001类里面的写法总结控制台程序一般当作Job使用,有时候需要控制

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker