微信小程序中选中手机相册图片上传到服务器的方法

思路: 实现图片上传我们需要使用chooseImguploadFile 这两个api。
1. 微信小程序中的chooseImg是一个API,用于在用户相册或相机中选择图片上传。它可以让用户在小程序中选择上传图片,以便进行下一步操作,例如将其发送给朋友或将其上传到服务器。
2. 使用chooseImg API,您可以通过以下步骤实现在小程序中选择图片上传:

步骤:
1. 在wxml文件中添加一个按钮或其他可触摸元素,以触发选择图片的操作。

2. 在js文件中使用wx.chooseImage(options)函数来触发选择图片的操作。

3. 在options参数中,可以设置maximum选项以限制用户选择的图片数量,可以设置sizeType选项以限制图片的大小,可以设置sourceType选项以限制图片源(相册或相机)。

4. 选择完成后,可以使用wx.uploadFile(options)函数将图片上传到服务器。

代码:

1. wxml文件:

go 复制代码
<button bindtap="choose_UpImage">选择图片进行上传</button>

1. js文件:

go 复制代码
Page({

  choose_UpImage: function () {
	    wx.chooseImage({
	      count: 1, //count参数设置为1,表示选择一张图片
	     sizeType: ['original', 'compressed'],//表示选择原图和压缩图两种尺寸的图片。
	     sourceType: ['album', 'camera'],//album表示选择相册来源的图片、camera表示相机来源的图片
	      success: function (res) {
	      //通过res.tempFilePaths获取到选中图片的临时文件路径
	        var tempFilePaths = res.tempFilePaths 
	        wx.uploadFile({
	          url: 'https://网址.com/wave/upload/headImg',
	          //filePath参数设置为tempFilePaths[0],表示要上传的文件路径,使0用的是选中图片的临时文件路径。
	          filePath: tempFilePaths[0], 
	          //name参数设置为'file",表示在服务器接收到的文件的name参数的值为file
	          name: 'file',
	          //表示在服务器接收到的文件的formData参数设置为user:test,formData参数的值为user:test
	            formData: {
	              'user': 'test'
	            },
	          success: function (res) {
	             var fanhui_data = res.data 
// {"data":{"src":"statics/uploadfiles/1712036877769.jpg"},"code":0,"msg":""}
	              console.log('上传成功,返回的整体数据========'+fanhui_data)
	              //接受的数据  需要转化为json数据 
	              let JsonSrc =  JSON.parse(fanhui_data)
	              console.log("返回的整体数据进行json转换:",JsonSrc)
	              console.log("上传成功,返回图片的路径========"+JsonSrc.data.src)
	          },
	          fail: function (res) {
	            console.log('上传失败')
	          }
	        })
	      }
	    })
  },


})
相关推荐
七夜zippoe12 小时前
CANN Runtime任务描述序列化与持久化源码深度解码
大数据·运维·服务器·cann
盟接之桥12 小时前
盟接之桥说制造:引流品 × 利润品,全球电商平台高效产品组合策略(供讨论)
大数据·linux·服务器·网络·人工智能·制造
Fcy64814 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满14 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
主机哥哥14 小时前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
珠海西格电力科技15 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市
释怀不想释怀16 小时前
Linux环境变量
linux·运维·服务器
zzzsde16 小时前
【Linux】进程(4):进程优先级&&调度队列
linux·运维·服务器
qq_2975746716 小时前
Linux 服务器 Java 开发环境搭建保姆级教程
java·linux·服务器
神梦流17 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库