VUE axios上传图片到七牛的实例代码

网友投稿 445 2023-04-24


VUE axios上传图片到七牛的实例代码

浏览器上传图片到服务端,我用过两种方法:

1.本地图片转换成base64,然后通过普通的post请求发送到服务端。

操作简单,适合小图,以及如果想兼容低版本的ie没办法用此方法

2.通过form表单提交。

form表单提交图片会刷新页面,也可以时form绑定到一个隐藏的iframe上,可以实现无刷新提交数据。但是如果想传输多条form表单数据,需要写很多dom,同时还要写iframe,太麻烦。

目前感觉比较干净的办法就是通过axios的post请求,发送form数据到后台。

html部分,至于界面优化,可以把input file的opacity设置为0,点击其父容器,即触发file

复制代码 代码如下:

axios的post请求,发送form数据部分,这样就可以无刷新的提交form数据到后台

update(e){

let file = e.target.files[0];

let param = new FormData(); //创建form对象

param.append('file',file,file.name);//通过append向form对象添加数据

param.append('chunk','0');//添加form表单中其他数据

console.log(param.get('file')); //Forhttp://mData私有类对象,访问不到,可以通过get判断值是否传进去

let config = {

headers:{'Content-Type':'multipart/form-data'}

}; //添加请求头

this.axios.post('http://upload.qiniu.com/',param,config)

.then(response=>{

console.log(response.data);

})

}

以下部分是扩展

vue开发环境下,上传图片到七牛

最近着手的约能人项目,需要上传图片到七牛,但是感觉只是简单的上传图片还需要引七牛的js,太麻烦了,就自己一切从简。实现逻辑:获取后台返回的七牛token,然后axios的post请求,发送form数据到七牛。

七牛的token是其平台封装好的,直接在自己服务器配置就能获取到 在其官网上可以找到直接能用的代码  ,在七牛平台获取到后,返回给前台直接拿就好了

以下是直接上传图片到七牛,不需要安装七牛乱七八糟的js,只需要通过七牛的form表单上传就行了。

update(e){

let file = e.target.files[0];

let d = new Date();

let type = file.name.split('.');

let tokenParem = {

'putPolicy':'{\"name\":\"$(fname)\",\"size\":\"$(http://fsize)\",\"w\":\"$(imageInfo.width)\",\"h\":\"$(imageInfo.height)\",\"hash\":\"$(etag)\"}',

'key':'orderReview/'+d.getFullYear()+'/'+(d.getMonth()+1)+'/'+d.getDate()+'/'+d.valueOf()+'.'+type[type.length-1],

'bucket':this.domain,//七牛的地址,这个是你自己配置的(变量)

};

let param = new FormData(); //创建form对象

param.append('chunk','0');//断点传输

param.append('chunks','1');

param.append('file',file,file.name)

console.log(param.get('file'))aEhkakZqIa; //FormData私有类对象,访问不到,可以通过get判断值是否传进去

let config = {

headers:{'Content-Type':'multipart/form-data'}

};

//先从自己的服务端拿到token

this.axios.post(api.uploadToken,qs.stringify(tokenParem))

.then(response=>{

this.token = response.data.uploadToken;

param.append('token',this.token);

if(this.images.length>8){

alert('不能超过9张');

return;

}

this.uploading(param,config,file.name);//然后将参数上传七牛

return;

})

},

uploading(param,config,pathName){

this.axios.post('http://upload.qiniu.com/',param,config)

.then(response=>{

console.log(response.data);

let localArr = this.images.map((val,index,arr)=>{

return arr[index].localSrc;

})

if(!~localArr.indexOf(pathName)){

this.images.push({'src':this.showUrl+response.data.key,'localSrc':pathName});

}else{

alert('已上传该图片');

}

})

},


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序对接七牛云存储的方法
下一篇:解决springboot 获取form
相关文章

 发表评论

暂时没有评论,来抢沙发吧~