先在后端创建文件上传的实体类uploadfile.java,包括文件名,上传日期,文件路径,上传人编号,然后创建uploadfileController,在其中写一个文件上传的api,然后在vue项目中的api文件夹下写一个uploadfile.js,用axios的方式调用后端的文件上传的api,名为upload_f,然后在vue项目的views文件夹下写一个uploadfile.vue,在uploadfile.vue里调用uploadfile.js中的upload_f实现文件上传

时间: 2023-05-31 14:05:59 浏览: 47
的功能。具体代码如下: 后端uploadfile.java: ``` @Entity @Table(name = "uploadfile") public class UploadFile { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "filename") private String fileName; @Column(name = "upload_date") private Date uploadDate; @Column(name = "file_path") private String filePath; @Column(name = "uploader_id") private Long uploaderId; // 省略getter和setter方法 } ``` uploadfileController.java: ``` @RestController @RequestMapping("/api") public class UploadFileController { @Autowired private UploadFileRepository uploadFileRepository; @PostMapping("/uploadfile") public ResponseEntity<?> uploadFile(@RequestParam("file") MultipartFile file, Principal principal) { UploadFile uploadFile = new UploadFile(); uploadFile.setFileName(file.getOriginalFilename()); uploadFile.setUploadDate(new Date()); uploadFile.setUploaderId(Long.parseLong(principal.getName())); try { // 获取文件在服务器上的保存路径 String filePath = "文件上传路径/" + file.getOriginalFilename(); uploadFile.setFilePath(filePath); // 保存文件到服务器本地 file.transferTo(new File(filePath)); // 将文件信息保存到数据库 uploadFileRepository.save(uploadFile); return ResponseEntity.ok().build(); } catch (IOException e) { e.printStackTrace(); return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build(); } } } ``` uploadfile.js: ``` import axios from 'axios'; const BASE_URL = 'http://localhost:8080/api'; export function upload_f(file) { const formData = new FormData(); formData.append('file', file); return axios.post(`${BASE_URL}/uploadfile`, formData, { headers: { 'Content-Type': 'multipart/form-data' } }); } ``` uploadfile.vue: ``` <template> <div> <input type="file" ref="fileInput" @change="uploadFile" /> </div> </template> <script> import { upload_f } from '@/api/uploadfile'; export default { name: 'UploadFile', methods: { uploadFile() { const file = this.$refs.fileInput.files[0]; upload_f(file) .then(() => { console.log('文件上传成功'); }) .catch(() => { console.log('文件上传失败'); }); } } } </script> ```

相关推荐

最新推荐

recommend-type

Django实现任意文件上传(最简单的方法)

第一步:在模板文件中,创建一个form表单,需要特别注意的是,在有文件上传的form表单中,method属性必须为post,而且必须指定它的enctype为”multipart/form-data”,表明不对字符进行编码,具体的代码如下: ...
recommend-type

在LayUI图片上传中,解决由跨域问题引起的请求接口错误的方法

今天小编就为大家分享一篇在LayUI图片上传中,解决由跨域问题引起的请求接口错误的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

基于Java的消息中间件java操作demo.zip

消息中间件java操作demo 提供activeMq的 java实现,和两种模式:点对点、发布和订阅 直接clone下来,导入maven项目启动test包下的 Client.java
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

如何用python编写api接口

在Python中编写API接口可以使用多种框架,其中比较流行的有Flask和Django。这里以Flask框架为例,简单介绍如何编写API接口。 1. 安装Flask框架 使用pip命令安装Flask框架: ``` pip install flask ``` 2. 编写API接口 创建一个Python文件,例如app.py,编写以下代码: ```python from flask import Flask, jsonify app = Flask(__name__) @app.route('/api/hello', methods=['GET']) def hello():
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这