当前位置: 首页 > news >正文

外贸自己做网站好不好万能浏览器破解版

外贸自己做网站好不好,万能浏览器破解版,什么网站可以找免费模板,清新区住房和城乡建设部网站文章目录 使用版本文件上传服务端客户端(前端)方式一方式二 文件下载服务端客户端(前端) 代码仓库地址 使用版本 后端 spring-boot 3.3.0jdk17 前端 vue “^3.3.11”vite “^5.0.8”axios “^1.7.2” 文件上传 上传文件比较…

文章目录

  • 使用版本
  • 文件上传
    • 服务端
    • 客户端(前端)
      • 方式一
      • 方式二
  • 文件下载
    • 服务端
    • 客户端(前端)
  • 代码仓库地址

使用版本

后端

  • spring-boot 3.3.0
  • jdk17

前端

  • vue “^3.3.11”
  • vite “^5.0.8”
  • axios “^1.7.2”

文件上传

上传文件比较简单。一般前端传文件流(二进制)到后端,后端处理文件流保存到目标位置即可!

服务端

MultipartFile是SpringMVC提供简化上传操作的工具类。
主要是使用 MultipartFile 的 transferTo 方法。

这里使用了MultipartFile[] 表示支持多文件上传

@PostMapping(path = {"/upload"})
public void getMs(@RequestPart("file") MultipartFile[] files) throws IOException {for (MultipartFile file : files){String fileName = file.getOriginalFilename();File dest = new File("/Users/cyq/Downloads/" + fileName);file.transferTo(dest);}
}

客户端(前端)

方式一

使用原生上传

需要注意的是

  • 用formData去保存文件信息,
  • 设置类型’Content-Type’: ‘multipart/form-data’

formData可以存储二进制文件、blob等类型,

<script setup>
import { ref } from 'vue'
import axios from 'axios'function sendRequest(file) {const formData = new FormData();formData.append('file', file[0]);formData.append('file', file[1]);axios.post('/api/ceel/hi', formData,{headers: {'Content-Type': 'multipart/form-data'}}).then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});
}function getFile(event){const files =  event.target.filesconsole.log(files);sendRequest(files)
}
</script><template><input v-on:change="getFile" multiple="multiple" type="file" />
</template>

方式二

就很简单了,直接使用elment-plus的上传组件。
使用这种方式多文件上传时- 其实是一个一个的上传的。并不是一下子上传。

<script setup>
import { ref } from 'vue'
const fileList = ref([])
</script><template>
<el-upload multipleaction="/api/ceel/hi"v-model:file-list="fileList"
><el-button type="primary">上传文件</el-button>
</el-upload>
</template>

文件下载

下载文件一般都是处理文件流。
通常使用一个byte数组(字节数组)来存放文件流中的数据,每次存取byte数组的长度个数据。然后放到输出流中。
重复以上动作,直到文件流处理完成!

就像是个搬运工,每次搬运指定字节的数据,从输入流到输出流直到搬完。

服务端

@GetMapping("/download")
public void download(String fileName, HttpServletResponse response) throws IOException {String _u = "/Users/cyq/Downloads/";String filePath = _u + fileName + ".xlsx";File file = new File(filePath);response.setContentType("application/octet-stream");// 告知浏览器文件大小response.addHeader("Content-Length", "" + file.length()); response.setHeader("content-disposition","attachment;fileName="+ URLEncoder.encode(file.getName(), "UTF-8"));FileInputStream inputStream = new FileInputStream(file);ServletOutputStream outputStream = response.getOutputStream();try (inputStream; outputStream){byte[] buffer = new byte[1024];int len;while ((len = inputStream.read(buffer)) > 0){outputStream.write(buffer, 0, len);}}
}

客户端(前端)

发起请求,需要明确返回数据的类型是 blob,添加responseType: ‘blob’
拿到返回流后,通过URL.createObjectURL处理文件流,生成一个url,供a标签进行下载!
下载完成后需要移除。

function sendRequest() {axios.get('/api/ceel/download?fileName=模板-财源系统', {responseType: 'blob'}).then(function (response) {const url = window.URL.createObjectURL(new Blob([response.data]));const link = document.createElement('a');link.href = url;link.setAttribute('download', '模板-财源系统.xlsx');document.body.appendChild(link);link.click();document.body.removeChild(link);}).catch(function (error) {console.log(error);});
}

代码仓库地址

  • 后端代码 https://github.com/Mrceel/java-demo.git

路径为

package com.example.practicejava.file;
http://www.yayakq.cn/news/667558/

相关文章:

  • 西安做网站找哪家公司好卓博人才网东莞招聘网
  • 网站优化北京多少钱沈阳人流
  • 凡科快图电脑版seo推广系统
  • 网站做中英文切换学院网站建设 好处
  • 做个外贸的网站不懂英语咋做武昌手机网站
  • 做暧暧免费网站wordpress 红酒
  • 个人备案怎么做旅游网站cms 官网
  • wordpress后台汉语青岛seo网络推广
  • 陕西广告公司网站建设平阳住房和城乡建设厅网站
  • 部队织梦网站模板免费下载wordpress去版权 合法
  • 网站建设要学哪些软件有哪些大学生网页设计个人主页
  • 网站关键词搜索工商查名字能不能注册
  • xx旅行社网站建设方案 企网站技术解决方案为申请虚拟主机优惠券怎做网站
  • 深圳自助网站建设网站建设.国风网络
  • 什么二手车网站做最好学做网站和推广要多久
  • 怎么制作动态的网站网站建设的总体需求是什么
  • 网站推广好难专业网站设计方案公司
  • 企业logo设计网站金华网络推广公司
  • 东莞网站建设制作哪家好推广引流方法与渠道
  • 商城类网站和o2o网站如何安装字体wordpress
  • 制作公司的网站上海物流公司网站建设
  • 淘宝是什么语言做的网站湖州网站网站建设
  • 社区工作者有编制吗宿迁做网站优化
  • 做网站遇到的困难总结买个app需要多少钱
  • 网站开发选题申请理由网络推广工作好吗
  • 网站如何做触屏滑动效果网站流量用什么表示
  • 海门网站定制php网站建设 关键技术
  • 江阴网站建设公司可以做哪些有趣的网站
  • 湘西吉首市建设局网站网址短码生成器
  • 在线视频下载网站如何做logo素材网站有哪些