最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

微信小程序实现上传图片功能

来源:懂视网 责编:小采 时间:2020-11-27 22:13:57
文档

微信小程序实现上传图片功能

微信小程序实现上传图片功能:微信小程序图片上传,供大家参考,具体内容如下 先来看一下微信小程序的api 来看一下页面效果 查看大图 wxml文件代码: <view class=weui-cell> <view class=weui-cell__bd> <view class=weui-
推荐度:
导读微信小程序实现上传图片功能:微信小程序图片上传,供大家参考,具体内容如下 先来看一下微信小程序的api 来看一下页面效果 查看大图 wxml文件代码: <view class=weui-cell> <view class=weui-cell__bd> <view class=weui-

微信小程序图片上传,供大家参考,具体内容如下

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

来看一下页面效果

查看大图

wxml文件代码:

<view class="weui-cell"> 
 <view class="weui-cell__bd"> 
 <view class="weui-uploader"> 
 <view class="weui-uploader__hd"> 
 <view class="weui-uploader__title">营业执照</view> 
 <view class="weui-uploader__info">{{imageList.length}}/{{count[countIndex]}}</view> 
 </view> 
 <view class="weui-uploader__bd"> 
 <view class="weui-uploader__files"> 
 <block wx:for="{{imageList}}" wx:for-item="image"> 
 <view class="weui-uploader__file"> 
 <image class="weui-uploader__img" src="{{image}}" data-src="{{image}}" bindtap="previewImage"></image> 
 </view> 
 </block> 
 </view> 
 <view class="weui-uploader__input-box"> 
 <view class="weui-uploader__input" 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里面根据要上传的数量循环上传。

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

微信小程序实现上传图片功能

微信小程序实现上传图片功能:微信小程序图片上传,供大家参考,具体内容如下 先来看一下微信小程序的api 来看一下页面效果 查看大图 wxml文件代码: <view class=weui-cell> <view class=weui-cell__bd> <view class=weui-
推荐度:
标签: 微信 图片 上传
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top