微信小程序之上传图片(含前后端代码例子)
此代码示例,能够让你成功将图片上传至后端,后端做相应的处理,然后返回成功码。
前端小程序代码
index.wxml:
- <view class='content'>
- <view class='img-box'>
- <view class='img-list'>
- <block wx:for="{{detailPics}}" wx:key="index">
- <view class='img-item'>
- <image src='{{item}}' bindlongpress="bindlongpressimg" data-id='{{index}}'></image>
- </view>
- </block>
- <view class='chooseimg' bindtap='uploadDetailImage'>
- <view class="weui-uploader__input-box"></view>
- </view>
- </view>
- <view class='tips'>长按对应的图片即可删除</view>
- </view>
- </view>
index.wxss:
- .content {
- width: %;
- background-color: #fff;
- }
- .img-list {
- display: flex;
- display: -webkit-flex;
- flex-direction: row;
- justify-content: flex-start;
- align-items: center;
- flex-wrap: wrap;
- }
- .img-item {
- width: %;
- text-align: left;
- margin-right: 20rpx;
- margin-bottom: 10rpx;
- }
- .img-item image {
- width: 180rpx;
- height: 180rpx;
- }
- .submit-btn {
- width: %;
- background-color: #fff;
- height: 80rpx;
- text-align: center;
- line-height: 80rpx;
- font-size: 30rpx;
- position: fixed;
- bottom: 100rpx;
- }
- .chooseimg {
- background-color: #fff;
- }
- .weui-uploader__input-box {
- float: left;
- position: relative;
- margin-right: 9px;
- margin-bottom: 9px;
- width: 180rpx;
- height: 180rpx;
- border: 1px solid #d9d9d9;
- }
- .weui-uploader__input-box:before {
- width: 2px;
- height: .5px;
- }
- .weui-uploader__input-box:after, .weui-uploader__input-box:before {
- content: " ";
- position: absolute;
- top: %;
- left: %;
- -webkit-transform: translate(-%, -%);
- transform: translate(-%, -%);
- background-color: #d9d9d9;
- }
- .weui-uploader__input-box:after {
- width: .5px;
- height: 2px;
- }
- .weui-uploader__input-box:after, .weui-uploader__input-box:before {
- content: " ";
- position: absolute;
- top: %;
- left: %;
- -webkit-transform: translate(-%, -%);
- transform: translate(-%, -%);
- background-color: #d9d9d9;
- }
- .tips {
- color: #;
- font-size: 24rpx;
- padding-bottom: 20rpx;
- }
- .img-box {
- width: %;
- margin: auto;
- padding-top: 20rpx;
- }
index.js:
- // component/uploadImages/index.js
- Component({
- /**
- * 组件的属性列表
- */
- properties: {
- count: { //最多选择图片的张数,默认9张
- type: Number,
- value:
- },
- uploadUrl: { //图片上传的服务器路径
- type: String,
- value: ''
- },
- showUrl: { //图片的拼接路径
- type: String,
- value: ''
- }
- },
- /**
- * 组件的初始数据
- */
- data: {
- detailPics: [], //上传的结果图片集合
- },
- ready: function () {
- console.log(this.data)
- },
- /**
- * 组件的方法列表
- */
- methods: {
- uploadDetailImage: function (e) { //这里是选取图片的方法
- var that = this;
- var pics = [];
- var detailPics = that.data.detailPics;
- if (detailPics.length >= that.data.count) {
- wx.showToast({
- title: '最多选择' + that.data.count + '张!',
- })
- return;
- }
- wx.chooseImage({
- count: that.data.count, // 最多可以选择的图片张数,默认9
- sizeType: ['original', 'compressed'], // original 原图,compressed 压缩图,默认二者都有
- sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
- success: function (res) {
- var imgs = res.tempFilePaths;
- for (var i = ; i < imgs.length; i++) {
- pics.push(imgs[i])
- }
- that.uploadimg({
- url: "http://www.test.com//test-api/wechat/applet/api/uploadUserAvatar", //这里是你图片上传的接口
- path: pics, //这里是选取的图片的地址数组
- });
- },
- })
- },
- //多张图片上传
- uploadimg: function (data) {
- wx.showLoading({
- title: '上传中...',
- mask: true,
- })
- var that = this,
- i = data.i ? data.i : ,
- success = data.success ? data.success : ,
- fail = data.fail ? data.fail : ;
- wx.uploadFile({
- url: data.url,
- filePath: data.path[i],
- name: 'file',
- formData: {"userId":""},
- success: (resp) => {
- wx.hideLoading();
- success++;
- var str = resp.data //返回的结果,可能不同项目结果不一样
- console.log(str);
- // var pic = JSON.parse(str);
- // var pic_name = that.data.showUrl + pic.Data;
- // var detailPics = that.data.detailPics;
- // detailPics.push(pic_name)
- // that.setData({
- // detailPics: detailPics
- // })
- },
- fail: (res) => {
- fail++;
- console.log('fail:' + i + "fail:" + fail);
- },
- complete: () => {
- i++;
- if (i == data.path.length) { //当图片传完时,停止调用
- console.log('执行完毕');
- console.log('成功:' + success + " 失败:" + fail);
- var myEventDetail = {
- picsList: that.data.detailPics
- } // detail对象,提供给事件监听函数
- var myEventOption = {} // 触发事件的选项
- that.triggerEvent('myevent', myEventDetail, myEventOption)//结果返回调用的页面
- } else { //若图片还没有传完,则继续调用函数
- data.i = i;
- data.success = success;
- data.fail = fail;
- that.uploadimg(data);//递归,回调自己
- }
- }
- });
- },
- }
- })
后端Java代码(这里我使用的是第三方存储,如腾讯云,如果读者朋友们是使用第三方存储替换是一件很容易的事情)
核心代码如下:
- @PostMapping("/uploadUserAvatar")
- @ApiOperation(value = "上传用户头像", notes = "上传用户头像")
- public JSONObject uploadUserAvatar(HttpServletRequest request) {
- JSONObject json = new JSONObject();
- try {
- String userId = request.getParameter("userId");
- COSClientUtil cosClientUtil = new COSClientUtil();
- MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
- // 获取上传的文件
- MultipartFile multiFile = multipartRequest.getFile("file");
- String name = cosClientUtil.uploadFileCos(multiFile);
- // 获取文件路径
- String fileUrl = cosClientUtil.getFileUrl(name);
- Console.log("fileUrl:"+fileUrl);
- // 对文件路径进行处理
- String dbFileUrl = fileUrl.substring(, fileUrl.indexOf("?"));
- Console.log("dbFileUrl:"+dbFileUrl);
- User user = new User();
- user.setId(Integer.parseInt(userId));
- user.setSmallAvatar(dbFileUrl);
- boolean isUploadUserAvatar = userService.updateById(user);
- if (isUploadUserAvatar) {
- json.put(ResponseUtils.CODE, ResponseUtils.SUCCESS_CODE);
- json.put(ResponseUtils.MSG, ResponseUtils.SUCCEESS_MSG);
- } else {
- json.put(ResponseUtils.CODE, ResponseUtils.ERROR_CODE);
- json.put(ResponseUtils.MSG, ResponseUtils.ERROR_MSG);
- }
- } catch (Exception e) {
- e.printStackTrace();
- json.put(ResponseUtils.CODE, ResponseUtils.ERROR_CODE);
- json.put(ResponseUtils.MSG, ResponseUtils.ERROR_MSG);
- }
- return json;
- }
微信小程序之上传图片(含前后端代码例子)的更多相关文章
- 微信小程序批量上传图片 All In One
微信小程序批量上传图片 All In One open-data https://developers.weixin.qq.com/miniprogram/dev/component/open-dat ...
- 微信小程序/网站 上传图片到腾讯云COS
COS简介: 腾讯云提供的一种对象存储服务,供开发者存储海量文件的分布式存储服务.可以将自己开发的应用的存储部分全部接入COS的存储桶中,有效减少应用服务器的带宽,请求等.个人也可以通过腾讯云账号免费 ...
- (干货)微信小程序之上传图片和图片预览
这几天一直负责做微信小程序这一块,也可以说是边做边学习吧,把自己做的微信小程序的一些功能分享出来,与大家探讨一下,相互学习相互进步. 先看下效果图 只写了一下效果样式的话希望大家不要太在意,下面马路杀 ...
- 微信小程序之上传图片和图片预览
这几天一直负责做微信小程序这一块,也可以说是边做边学习吧,把自己做的微信小程序的一些功能分享出来,与大家探讨一下,相互学习相互进步. 先看下效果图 只写了一下效果样式的话希望大家不要太在意,下面马路杀 ...
- 微信小程序左右滑动切换页面示例代码--转载
微信小程序——左右滑动切换页面事件 微信小程序的左右滑动触屏事件,主要有三个事件:touchstart,touchmove,touchend. 这三个事件最重要的属性是pageX和pageY,表示X, ...
- 微信小程序+php 授权登陆,完整代码
先上图 实现流程: 1.授权登陆按钮和正文信息放到了同一个页面,未授权的时候显示登陆按钮,已授权的时候隐藏登陆按钮,显示正文信息,当然也可以授权和正文分开成两个页面,在授权页面的onlo ...
- 微信小程序使用websocket通讯的demo,含前后端代码,亲测可用
目录 0.概述websocket 1.app.js写法 2.后台写法 0.概述websocket (1) 个人总结:后台设置了websocket地址,服务器开启后等待有人去连接它. 一个客户端一打开就 ...
- 小程序php支付,前后端分离
小程序端: xml: <button type="default" bindtap="payOrder">支付</button> js: ...
- 微信小程序token失效 自动请求后端,适用于自动登录
app.js // app.js App({ onLaunch() { let token = wx.getStorageSync('token') if (!token) { wx.login({ ...
随机推荐
- npm安装时-S -D作用及区别
-S 即--save(保存) 包名会被注册在package.json的dependencies里面,在生产环境下这个包的依赖依然存在 -D 即--dev(生产) 包名会被注册在package.json ...
- IDEA创建本地Spark程序,并本地运行
1 IDEA创建maven项目进行测试 v创建一个新项目,步骤如下: 选择“Enable Auto-Import”,加载完后:选择“Enable Auto-Import”,加载完后: 添加SDK依 ...
- mysql新加用户设置权限
1.开通操作权限和表权限 GRANT CREATE,ALTER,DROP,INSERT,UPDATE,DELETE,SELECT ON interface.* TO test1@'%' identif ...
- 【干货】gitlab-11.10.4版本汉化
目录 1.YUM安装gitlab-11.10.4 2.gitlab汉化技能 1.YUM安装gitlab-11.10.4 下载gitlab-ce的repo [root@localhost ~]# cur ...
- 蓝桥杯如何训练?(附VIP题库)
https://www.dotcpp.com/ 给大家介绍下蓝桥杯,是近几年可以说国内名气最大的程序设计类比赛了 相比国际赛事ACM,蓝桥杯入门简单.中文答题.拿奖率高,更适合国内大众化参加,近几年不 ...
- 纯数据结构Java实现(7/11)(SegmentTree)
欢迎访问我的自建博客: CH-YK Blog.
- sklearn---DBSCAN
参考文献: [1]用scikit-learn学习DBSCAN聚类
- C++类库开发详解(转)
前言:这是一篇总结性的文章,需要有一点C++和dll基本知识的基础,在网上查阅了很多资料感觉没有一篇详细.具体.全面的dll开发介绍,我这是根据最近项目和网上资料整理出来的,并附带实例的一个总结性的文 ...
- com.alibaba.fastjson.JSONException: exepct '[', but error, pos 1, json : %255B%257B%2522list%2522%253A%255B%257B%2522itemId%2522%253A1369331%252C%2522num%2522%253A2%257D%255D%257D%255
com.alibaba.fastjson.JSONException: exepct '[', but error, pos 1, json : %255B%257B%2522list%2522%25 ...
- 聊聊CMSIS-RTOS是什么东东
起因:发布自己翻译用的CMSIS_RTOS_Tutorial后,陆续收到网友关于“CMSIS-RTOS是干么的?”之类的问题,再次统一回复. 众所周知,实时操作系统是嵌入式领域的基石.而可选的嵌入式操 ...