微信小程序上传图片功能(附后端代码)
家电修理 2023-07-16 19:16www.caominkang.com电器维修
几乎每个程序都需要用到图片,在小程序中我们可以通过image组件显示图片。
小程序也是可以上传图片的,微信小程序文档也写的很清楚。
上传图片
选择图片
通过x.chooseImage(OBJECT)实现
官方示例代码
x.chooseImage({ count: 1, // 默认9 sizeType: ['original', 'pressed'], // 可以指定是原图还是压缩图,默认二者都有 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有 suess: function (res) { // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片 var tempFilePaths = res.tempFilePaths } })
图片最多可以选择9张, 也可以通过拍摄照片实现,当选择完图片之后会获取到图片路径, 这个路径在本次启动期间有效。
如果需要保存就需要用x.saveFile(OBJECT)
上传图片
通过x.uploadFile(OBJECT) 可以将本地资源文件上传到服务器。
原理就是客户端发起一个 HTTPS POST 请求,其中 content-type为 multipart/form-data。
官方示例代码
x.chooseImage({ suess: function(res) { var tempFilePaths = res.tempFilePaths x.uploadFile({ url: 'http://example.eixin.qq./upload', //仅为示例,非真实的接口地址 filePath: tempFilePaths[0], name: 'file', formdata:{ 'user': 'test' }, suess: function(res){ var data = res.data //do something } }) } })
示例代码
看完了官方文档, 写一个上传图片就没有那么麻烦了,下面是真实场景的代码
import constant from '../../mon/constant'; Page({ data: { src: "../../image/photo.png", //绑定image组件的src //略... }, onLoad: function (options) { //略... }, uploadPhoto() { var that = this; x.chooseImage({ count: 1, // 默认9 sizeType: ['pressed'], // 可以指定是原图还是压缩图,默认二者都有 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有 suess: function (res) { // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片 var tempFilePaths = res.tempFilePaths; upload(that, tempFilePaths); } }) } }) function upload(page, path) { x.shoToast({ icon: "loading", title: "正在上传" }), x.uploadFile({ url: constant.SERVER_URL + "/FileUploadServlet", filePath: path[0], name: 'file', header: { "Content-Type": "multipart/form-data" }, formdata: { //和服务器约定的token, 一般也可以放在header中 'session_token': x.getStorageSync('session_token') }, suess: function (res) { console.log(res); if (res.statusCode != 200) { x.shoModal({ title: '提示', content: '上传失败', shoCancel: false }) return; } var data = res.data page.setData({ //上传成功修改显示头像 src: path[0] }) }, fail: function (e) { console.log(e); x.shoModal({ title: '提示', content: '上传失败', shoCancel: false }) }, plete: function () { x.hideToast(); //隐藏Toast } }) }
后端代码
后端是用java写的,一开始的时候,后端开始用了一些框架接收上传的图片,出现了各种问题,后来使用了纯粹的Servlet就没有了问题, 把代码贴出来省的以后麻烦了。
注意: 代码使用了公司内部的框架,建议修改后再使用
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) thros ServletException, IOException { JsonMessage
为大家推荐现在关注度比较高的微信小程序教程一篇《微信小程序开发教程》我为大家精心整理的,电脑维修网希望喜欢。
空调维修
- 温岭冰箱全国统一服务热线-全国统一人工【7X2
- 荆州速热热水器维修(荆州热水器维修)
- 昆山热水器故障码5ER-昆山热水器故障码26
- 温岭洗衣机24小时服务电话—(7X24小时)登记报
- 统帅热水器售后维修服务电话—— (7X24小时)登
- 阳江中央空调统一电话热线-阳江空调官方售后电
- 乌鲁木齐阳春燃气灶厂家服务热线
- 珠海许昌集成灶售后服务电话-全国统一人工【
- 乌鲁木齐中央空调维修服务专线-乌鲁木齐中央空
- 新沂热水器故障电话码维修-新沂热水器常见故障
- 诸城壁挂炉24小时服务热线电话
- 靖江空调24小时服务电话-——售后维修中心电话
- 空调室外滴水管维修(空调室外排水管维修)
- 九江壁挂炉400全国服务电话-(7X24小时)登记报修
- 热水器故障码f.22怎么解决-热水器f0故障解决方法
- 营口热水器售后维修服务电话—— 全国统一人工