springboot+vue實現文件上傳

https://blog.csdn.net/mqingo/article/details/84869841前端

技術:vue

後端:springbootjava

前端框架:vuemysql

數據庫:mysqlios

pom.xml:web

<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.3</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
controller:spring

@RestController
@RequestMapping("/yfjs")
@CrossOrigin
public class YFJSController {

@Autowired
private YFJSService yfjsService;
@Autowired
private FJSCService fjscService;

private String url;

@RequestMapping(value="/file",produces="application/json;charset=UTF-8")
@ResponseBody
public JSONObject uploadFile(@RequestParam("file") MultipartFile file,@RequestParam("yundanhao")String yundanhao,@RequestParam("jiyunxiang_Id")String jiyunxiang_Id) {
JSONObject rst = new JSONObject();
rst.put("yundanhao",yundanhao);
rst.put("id",jiyunxiang_Id);
System.out.print("上傳文件==="+"\n");
//判斷文件是否爲空
if (file.isEmpty()) {
rst.put("msg","文件爲空");
return rst;
}
// 獲取文件名
String fileName = file.getOriginalFilename();
// System.out.print("上傳的文件名爲: "+fileName+"\n");

fileName = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + "_" + fileName;
System.out.print("(加個時間戳,儘可能避免文件名稱重複)保存的文件名爲: "+fileName+"\n");
//加個時間戳,儘可能避免文件名稱重複
//String path = "/opt/apache-tomcat-8.0.50/webapps/img/" +fileName;
//String path = "/opt/apache-tomcat-8.0.50/webapps/img/" +fileName;
String path = "/opt/tomcat/apache-tomcat-8.0.50/webapps/img/" +fileName;
//String path = "E:/fileUpload/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + "_" + fileName;
//文件絕對路徑
System.out.print("保存文件絕對路徑"+path+"\n");
//建立文件路徑
File dest = new File(path);
//判斷文件是否已經存在
if (dest.exists()) {
rst.put("msg","文件已經存在");
return rst;
}

try {
//上傳文件
file.transferTo(dest); //保存文件
System.out.print("保存文件路徑"+path+"\n");
//url="http://你本身的域名/項目名/images/"+fileName;//正式項目
url="http://測試服務器:tomcat端口號/img/"+fileName;//本地運行項目
//url="http://正式服務器2:tomcat端口號/img/"+fileName;//本地運行項目
JSONObject param = new JSONObject();
param.put("name", fileName);
param.put("url", url);
param.put("yundanhao", yundanhao);
param.put("jiyunxiang_Id", jiyunxiang_Id);
JSONObject param1 = new JSONObject();
param1.put("name", fileName);
param1.put("yundanhao", yundanhao);
param1.put("jiyunxiang_Id", jiyunxiang_Id);
System.out.print("插入結果"+yundanhao+jiyunxiang_Id+"\n");
fjscService.deleteFJSC(param1);
System.out.print("插入結果"+yundanhao+jiyunxiang_Id+"\n");
int jieguo= fjscService.insertUrl(param);
System.out.print("插入結果"+jieguo+"\n");
System.out.print("保存的完整url===="+url+"\n");

} catch (IOException e) {
rst.put("msg","上傳失敗");
return rst;
}
rst.put("msg","上傳成功");
return rst;
}
}
 service:
 sql

package com.heeexy.example.service;

import com.alibaba.fastjson.JSONObject;

public interface FJSCService {

public int insertUrl(JSONObject jsonObject);


JSONObject deleteFJSC(JSONObject jsonObject);


}
serviceImpl:數據庫

package com.heeexy.example.service.impl;

import java.util.ArrayList;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.alibaba.fastjson.JSONObject;
import com.heeexy.example.dao.FJSCDao;
import com.heeexy.example.service.FJSCService;
import com.heeexy.example.util.CommonUtil;
@Service
public class FJSCServiceImpl implements FJSCService{

@Autowired
private FJSCDao fjscDao;

@Override
public int insertUrl(JSONObject jsonObject) {
System.out.println(jsonObject.get("yundanhao").toString()+"----------------"+jsonObject.get("jiyunxiang_Id").toString());
String[] yundan = jsonObject.get("yundanhao").toString().split(",");
String[] id = jsonObject.get("jiyunxiang_Id").toString().split(",");
int res = 0;
for(int i = 0 ; i < id.length;i++){
System.out.println(id[i]+"----------------"+yundan[i]);
jsonObject.put("jiyunxiang_Id",id[i]);
jsonObject.put("yundanhao",yundan[i]);
res=fjscDao.insertUrl(jsonObject);
}
return res;
}



@Override
public JSONObject deleteFJSC(JSONObject jsonObject) {
String[] yundan = jsonObject.get("yundanhao").toString().split(",");
String[] id = jsonObject.get("jiyunxiang_Id").toString().split(",");
String[] name = jsonObject.get("name").toString().split(",");
int rst = 0 ;
for(int i = 0 ; i < id.length;i++){
jsonObject.put("jiyunxiang_Id",id[i]);
jsonObject.put("yundanhao",yundan[i]);
jsonObject.put("name",name[i]);
rst = fjscDao.deleteFJSC(jsonObject);
if(rst==0){
jsonObject.put("msg", "刪除失敗");
break;
}
}
if(rst>0){
jsonObject.put("msg", "刪除成功");

}
return jsonObject;

}

public List<String> getList(String id) {
List<String> list = new ArrayList<String>();

String[] str = id.split(",");
for (int i = 0; i < str.length; i++) {
list.add(str[i]);
}
return list;

}




}
dao:
 apache

package com.heeexy.example.dao;

import java.util.List;

import com.alibaba.fastjson.JSONObject;
import com.heeexy.example.bean.FJSC;

public interface FJSCDao {


public int insertUrl(JSONObject param);


int deleteFJSC(JSONObject jsonObject);




}
mapper:
 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd" >

<mapper namespace="com.heeexy.example.dao.FJSCDao">

<resultMap type="com.heeexy.example.bean.FJSC" id="FJSCMap">
<id column="id" property="id"/>
<result column="url" property="url"/>
<result column="name" property="name"/>
<result column="yundanhao" property="yundanhao"/>
<result column="jiyunxiang_Id" property="jiyunxiang_Id"/>
<result column="dr" property="dr"/>

</resultMap>

<insert id="insertUrl" parameterType="com.alibaba.fastjson.JSONObject">
insert into fjsc (name,url,yundanhao,jiyunxiang_Id) values (#{name},#{url},#{yundanhao},#{jiyunxiang_Id})
</insert>



<delete id="deleteFJSC" parameterType="com.alibaba.fastjson.JSONObject">
delete from fjsc where yundanhao = #{yundanhao} and jiyunxiang_Id = #{jiyunxiang_Id} and name=#{name}
</delete>

</mapper>
vue:

<el-button type="primary" icon="plus" @click="queren(sels)" :disabled="this.sels.length === 0" v-if="hasPerm('yfjs:querens')">文件上傳</el-button>

import qs from "qs";
import axios from 'axios';



export default {
data() {
return {
res:"",
file: '',
excelfile: '',
sels: [], //選中的值顯示
tableList: [],
listXX:[],
listFJ:[],
total: 0,
start: 0,
size: 10,

totalCount: 0, //分頁組件--數據總條數
list: [], //表格的數據
listLoading: false, //數據加載等待動畫
listQuery: {
pageNum: 1, //頁碼
pageRow: 20, //每頁條數
bancihao: "",
yundan:"",
biduizhuangtai: "",
userId1:this.$store.getters.userId,
rolue:"",
},
rolesname: this.$store.getters.role,
dialogStatu: "queren",
dialogFormVisibles: false,
textMaps: {
queren: "確認"
},

dialogFormVisible: false,


qrxx: {
yundan:"",
id: "",
huming: "",
kaihuyinhang: "",
zhanghao: "",
shuiwudengjihao: "",
userId: "",
deleteflag: "",
yundanhao:"",
jiyunxiang_id:"",
yundanhao:""
},
editObj:{
id:'',
}

};
},

methods: {
getFile: function (event) {

this.file = event.target.files[0];

},
getexcelFile: function (event) {

this.excelfile = event.target.files[0];

},
excelFilesubmit: function (event) {

if (this.excelfile == null || this.excelfile == '') {
alert("文件爲空,請選擇文件進行導入");
return;
}
//阻止元素髮生默認的行爲
event.preventDefault();
let formData = new FormData();
formData.append("file", this.excelfile);
var url = this.HOST + "/ysjhqr/upload";
axios.post(url, formData)
.then(function (response) {
alert(response.data);
console.log(response);
window.location.reload();
}).catch(function (error) {
alert("比對數據失敗,請覈對excel表格數據");
console.log(error);
});
},
getfujianList: function (yundanhao,id){
this.api({
url: "/yfjs/selectFJSC",
method: "post",
params: {
yundanhao:yundanhao,
id:id,
}
}).then((data) => {
this.$set(this.listFJ = data.list);
this.listLoading = false;
console.log(data);
}).catch((aa) => {
console.log(aa)
});

},
fujianshangchuan: function (event) {
if (this.file == null || this.file == '') {
alert("文件爲空,請選擇文件進行導入");
return;
}
//阻止元素髮生默認的行爲
event.preventDefault();
let formData = new FormData();
var yundan = this.qrxx.yundan;
var id = this.qrxx.id;
formData.append("file", this.file);
formData.append("yundanhao",yundan);
formData.append("jiyunxiang_Id",id);

var url = this.HOST + "/yfjs/file";
this.$axios.post(url, formData)
.then(data => {
console.log(data);
this.getfujianList(data.data.yundanhao,data.data.id);

})
.catch(function (error) {
alert("上傳失敗");
console.log(error);
alert(error);

});

},


getLists() {
//查詢列表
if (!this.hasPerm("yfjs:lists")) {
return;
}

this.listLoading = true;
this.listQuery.rolue = this.$store.getters.role
this.api({
url: "/yfjs/listYFJSS",
method: "get",
params: this.listQuery
}).then(data => {
this.listLoading = false;
this.list = data.list;
this.totalCount = data.totalCount;
console.log(data);
});

},
handleSizeChange(val) {
//改變每頁數量
this.listQuery.pageRow = val;
this.handleFilter();
},
handleFilter() {
//查詢事件
this.listQuery.pageNum = 1;
this.getLists();
},
handleCurrentChange(val) {
//改變頁碼
this.listQuery.pageNum = val;
this.getLists();
},
getIndex($index) {
// alert($index);
//表格序號
return (this.listQuery.pageNum - 1) * this.listQuery.pageRow + $index + 1;
},
queren(sels) {
//顯示新增對話框

var ids = [];
sels.forEach(element => {
ids.push(element.id);
});

this.qrxx.id = ids.join(",");
var yundans = [];
sels.forEach(element => {
yundans.push(element.yundanhao);
});

this.qrxx.yundan = yundans.join(",");
this.qrxx.huming = "";
this.qrxx.kaihuyinhang = "";
this.qrxx.zhanghao = "";
this.qrxx.shuiwudengjihao = "",
this.qrxx.userId = this.$store.getters.userId;
this.qrxx.deleteflag = 0;
this.dialogStatu = "queren";
this.dialogFormVisibles = true;
},

selsChange(sels) {
this.sels = sels;
},


}
};
</script>
 

數據庫:

相關文章
相關標籤/搜索