900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > 如何使用微信小程序做出图片上传

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

时间:2022-06-19 10:03:16

相关推荐

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

微信小程序|小程序开发

小程序,图片,做出

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

php源码哪个好,ubuntu上装的qt,tomcat被淘汰了没,豆瓣租房 爬虫,贷款 漏洞 php,佛山关键词seo推广哪家好lzw

手机赚钱源码,vscode作为终端命令,ubuntu产生镜像,tomcat开机启动报错,allmovie爬虫,phpexcel.php,射阳seo优化哪家便宜,动态网站代码,免费asp模板大全lzw

来看一下页面效果

物业管理源码下载,vscode进node断点,如何安装+ubuntu,联想tomcat配置域名,剑鱼爬虫,php 补位,seo公司优化的流程,自适应宽度网站 源程序,手机网站模板更换方法lzw

查看大图

wxml文件代码:

营业执照 {{imageList.length}}/{{count[countIndex]}}

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: est},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里面根据要上传的数量循环上传。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。