如何使用微信小程序做出图片上传

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

如何使用微信小程序做出图片上传

这次给大家带来如何使用微信小程序做出图片上传,使用微信小程序做出图片上传的注意事项有哪些,下面就是实战案例,一起来看一下。

先来看一下微信小程序的api

来看一下页面效果

查看大图

wxml文件代码:

<view class="weui-cell">     <view class="weui-cellbd">      <view class="weui-uploader">       <view class="weui-uploaderhd">        <view class="weui-uploadertitle">营业执照</view>        <view class="weui-uploaderinfo">{{imageList.length}}/{{count[countIndex]}}</view>       </view>       <view class="weui-uploaderbd">        <view class="weui-uploaderfiles">         <block wx:for="{{imageList}}" wx:for-item="image">          <view class="weui-uploaderfile">           <image class="weui-uploaderimg" src="{{image}}" src="{{image}}" bindtap="previewImage"></image>          </view>         </block>        </view>        <view class="weui-uploaderinput-box">         <view class="weui-uploaderinput" bindtap="chooseImage"></view>        </view>       </view>      </view>   </view> </view>
登录后复制

js文件代码

chooseImage: function () {   var that = this;   console.log('aaaaaaaaaaaaaaaaaaaa')     wx.chooseImage({    count: this.data.count[this.data.countIndex],    success: function (res) {     console.log('ssssssssssssssssssssssssss')     //缓存下     wx.showToast({      title: '正在上传...',      icon: 'loading',      mask: true,      duration: 2000,      success: function (ress) {       console.log('成功加载动画');      }     })      console.log(res)     that.setData({      imageList: res.tempFilePaths     })     //获取第一张图片地址     var filep = res.tempFilePaths[0]     //向服务器端上传图片     // getApp().data.servsers,这是在app.js文件里定义的后端服务器地址     wx.uploadFile({      url: getApp().data.servsers + '/weixin/wx_upload.do',      filePath: filep,      name: 'file',      formData: {       'user': 'test'      },      success: function (res) {       console.log(res)       console.log(res.data)       var sss= JSON.parse(res.data)       var dizhi = sss.dizhi;       //输出图片地址       console.log(dizhi);       that.setData({        "dizhi": dizhi       })        //do something       }, fail: function (err) {       console.log(err)      }        });    }   })  },  previewImage: function (e) {   var current = e.target.dataset.src    wx.previewImage({     current: current,    urls: this.data.imageList   })  }
登录后复制

java 后端代码:

//获取当前日期时间的string类型用于文件名防重复   public String dates(){      Date currentTime = new Date();      SimpleDateFormat formatter = new SimpleDateFormat("yyyyMMddHHmmss");      String dateString = formatter.format(currentTime);      return dateString;   }   @RequestMapping("wx_upload.do")   public void uploadPicture(HttpServletRequest request, HttpServletResponse response,PrintWriter writer) throws Exception {     System.out.println("进入get方法!");   //获取从前台传过来得图片     MultipartHttpServletRequest req =(MultipartHttpServletRequest)request;     MultipartFile multipartFile = req.getFile("file");   //获取图片的文件类型     String houzhu=multipartFile.getContentType();     int one = houzhu.lastIndexOf("/");     System.out.println(houzhu.substring((one+1),houzhu.length()));     System.out.println(multipartFile.getName());   //根据获取到的文件类型截取出图片后缀     String type=houzhu.substring((one+1),houzhu.length());     System.out.println(multipartFile.getContentType());      String filename;   // request.getRealPath获取我们项目的根地址在加上我们要保存的地址     String realPath = request.getRealPath("/upload/wximg/");     try {       File dir = new File(realPath);       if (!dir.exists()) {         dir.mkdir();       }       //获取到当前的日期时间用户生成文件名防止文件名重复       String filedata=this.dates();     //生成一个随机数来防止文件名重复       int x=(int)(Math.random()*1000);       filename="zhongshang"+x+filedata;       System.out.println(x);     将文件的地址和生成的文件名拼在一起       File file = new File(realPath,filename+"."+type);       multipartFile.transferTo(file);     //将图片在项目中的地址和isok状态储存为json格式返回给前台,由于公司项目中没有fastjson只能用这个       JSONObject jsonObject=new JSONObject();       jsonObject.put("isok",1);       jsonObject.put("dizhi","/upload/wximg/"+filename+"."+type);        writer.write(jsonObject.toString());     } catch (IOException e) {       e.printStackTrace();     } catch (IllegalStateException e) {       e.printStackTrace();     } }
登录后复制

来看一下之前在前端js输出的内容:

打开浏览器用我们的服务器的地址加上后台返回json的dizhi字段去访问这张图片

我们可以看到图片已经填入我们的服务器端里了,然后在打开我们服务器端项目根地址下面的/upload/wximg

到这里就大功告成了如果是多张图片上传可以在js里面根据要上传的数量循环上传。

相信看了本文案例你已经掌握了方法,更多精彩请关注9543建站博客其它相关文章!

推荐阅读:

关于js的三种使用方式案例详解(附代码)

JS加载方式使用汇总

以上就是如何使用微信小程序做出图片上传的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。

作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:php如何去除路径后缀
下一篇:已是最新文章

发表评论

关闭广告
关闭广告