小編給大家分享一下使用微信小程序做出圖片上傳的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

先來(lái)看一下微信小程序的api

來(lái)看一下頁(yè)面效果



查看大圖

wxml文件代碼:
<view class="weui-cell">
<view class="weui-cellbd">
<view class="weui-uploader">
<view class="weui-uploaderhd">
<view class="weui-uploadertitle">營(yíng)業(yè)執(zhí)照</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('成功加載動(dòng)畫');
}
})
console.log(res)
that.setData({
imageList: res.tempFilePaths
})
//獲取第一張圖片地址
var filep = res.tempFilePaths[0]
//向服務(wù)器端上傳圖片
// getApp().data.servsers,這是在app.js文件里定義的后端服務(wù)器地址
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 后端代碼:
//獲取當(dāng)前日期時(shí)間的string類型用于文件名防重復(fù)
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("進(jìn)入get方法!");
//獲取從前臺(tái)傳過(guò)來(lái)得圖片
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());
//根據(jù)獲取到的文件類型截取出圖片后綴
String type=houzhu.substring((one+1),houzhu.length());
System.out.println(multipartFile.getContentType());
String filename;
// request.getRealPath獲取我們項(xiàng)目的根地址在加上我們要保存的地址
String realPath = request.getRealPath("/upload/wximg/");
try {
File dir = new File(realPath);
if (!dir.exists()) {
dir.mkdir();
}
//獲取到當(dāng)前的日期時(shí)間用戶生成文件名防止文件名重復(fù)
String filedata=this.dates();
//生成一個(gè)隨機(jī)數(shù)來(lái)防止文件名重復(fù)
int x=(int)(Math.random()*1000);
filename="zhongshang"+x+filedata;
System.out.println(x);
將文件的地址和生成的文件名拼在一起
File file = new File(realPath,filename+"."+type);
multipartFile.transferTo(file);
//將圖片在項(xiàng)目中的地址和isok狀態(tài)儲(chǔ)存為json格式返回給前臺(tái),由于公司項(xiàng)目中沒(méi)有fastjson只能用這個(gè)
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();
}
}來(lái)看一下之前在前端js輸出的內(nèi)容:

打開(kāi)瀏覽器用我們的服務(wù)器的地址加上后臺(tái)返回json的dizhi字段去訪問(wèn)這張圖片

我們可以看到圖片已經(jīng)填入我們的服務(wù)器端里了,然后在打開(kāi)我們服務(wù)器端項(xiàng)目根地址下面的/upload/wximg

以上是“使用微信小程序做出圖片上傳的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站欄目:使用微信小程序做出圖片上傳的方法-創(chuàng)新互聯(lián)
文章URL:http://chinadenli.net/article6/digpig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)、電子商務(wù)、網(wǎng)站設(shè)計(jì)公司、響應(yīng)式網(wǎng)站、品牌網(wǎng)站建設(shè)、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容