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

锟鹏建设招聘网站小程序制作119

锟鹏建设招聘网站,小程序制作119,wordpress 鼠标点击特效,互联网行业有哪些公司上传文件#xff1a; 前端#xff1a; 整个过程#xff0c;就是在使用FormData 添加 上File#xff08;这个Blob#xff09;#xff0c;并且key要和后台的名字对应上在点击上传按钮开始上传之前#xff0c;使用了URL.createObjectURL(File)创建blobUrl#xff0c;给了…上传文件 前端 整个过程就是在使用FormData 添加 上File这个Blob并且key要和后台的名字对应上在点击上传按钮开始上传之前使用了URL.createObjectURL(File)创建blobUrl给了img标签作图片预览上传完毕后将input file的value置为空。若将input file置为空则此时不能再从input file中获取file了得等下次再选择图片才能获得file将它置为空的目的是为了下次选择同样的图片也能触发input file的change事件 后端 后台仅仅就是用MultipartFile声明接收即可可以使用RequestParam注解 或 RequestPart注解调用MultipartFile#transferTo保存文件可以从MultipartFile#getInputStream中获取流比如上传到OSS。 前端代码 templatediv选择文件: input typefile reffileInputRef changeselectFile multiple !-- 使用multiple属性,可选择多个文件 --br/img v-ifimgUrl :srcimgUrl alt stylewidth:54px;height:54px;el-button v-ifimgUrl typeprimary clickuploadFile上传/el-buttonhr//div /templatescript import axiosInstance from /utils/request.js import axios from axios export default {name: File,data() {return {imgUrl:}},methods: {selectFile() {let file this.$refs[fileInputRef].files[0]console.log(file)// 上传前, 可以预览该图片let blobUrl URL.createObjectURL(file)this.imgUrl blobUrl},uploadFile() {// 因为可能选择多个文件, 所以这里是个数组let file this.$refs[fileInputRef].files[0]let formData new FormData()formData.append(mfile, file) // 必须和后端的参数名相同。我们看到了, 其实就是把blob文件给了formData的一个keyformData.append(type, avatar)// 可以有下面2种方式, 来上传文件/* axiosInstance.post(http://127.0.0.1:8083/file/uploadFile,formData, {headers: {a:b}}).then(res {console.log(响应回来: ,res);}) */axiosInstance({ // 这种传参方式, 在axios的index.d.ts中可以看到url:http://127.0.0.1:8083/file/uploadFile,method:post,data: formData, // 直接将FormData作为data传输headers: {a:b // 可携带自定义响应头}}).then(res {console.log(响应回来: ,res);})console.log(this.$refs[fileInputRef].value); // C:\fakepath\cfa86972-07a1-4527-8b8a-1991715ebbfe.png// 上传完文件后, 将value置为空, 以避免下次选择同样的图片而不会触发input file的change事件。// (注意清空value后将不能再从input file中获取file而原先的file仍然能够使用)this.$refs[fileInputRef].value }} } /scriptstyle/style后端代码 PostMapping(uploadFile) public Object uploadFile(RequestPart(mfile)MultipartFile multipartFile,RequestPart(type) String type) throws IOException {System.out.println(multipartFile.getClass());System.out.println(type);// 源文件名String originalFilename multipartFile.getOriginalFilename();// 内容类型String contentType multipartFile.getContentType();// 文件是否为空无内容boolean empty multipartFile.isEmpty();// 文件大小long size multipartFile.getSize();// 文件的字节数据byte[] bytes multipartFile.getBytes();// 获取文件的字节输入流InputStream inputStream multipartFile.getInputStream();// 将文件保存到指定路径下multipartFile.transferTo(new File(d:/Projects/practice/test-springboot/src/main/resources/file/ originalFilename));System.out.println(originalFilename);System.out.println(contentType);System.out.println(empty);System.out.println(size);System.out.println(bytes.length);HashMapString, Object data new HashMap();data.put(data, ok);return data; }动态a标签下载 前端代码 只需要动态创建a标签添加到body然后手动调用js触发a标签的click事件触发下载下载完成之后将a标签移除整个过程a标签的样式都是display:none templatedivel-button typesuccess clickdownloadFile下载文件/el-button/div /templatescript import axiosInstance from /utils/request.js import axios from axios export default {name: File,data() {return {}},methods: {downloadFile() {let a document.createElement(a)a.href http://127.0.0.1:8083/file/downloadFile?filename头像a.pngdocument.body.appendChild(a)a.style.display nonea.click()document.body.removeChild(a)}} } /scriptstyle/style后端代码 GetMapping(downloadFile) public void downloadFile(RequestParam(filename) String filename) throws Exception {// 告知浏览器这是一个字节流浏览器处理字节流的默认方式就是下载// 意思是未知的应用程序文件浏览器一般不会自动执行或询问执行。浏览器会像对待// 设置了HTTP头Content-Disposition值为attachment的文件一样来对待这类文件即浏览器会触发下载行为response.setHeader(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_OCTET_STREAM_VALUE);// ,该响应头指示回复的内容该以何种形式展示是以内联的形式即网页或者网页的一部分还是以附件的形式下载并保存到本地。response.setHeader(HttpHeaders.CONTENT_DISPOSITION,attachment;fileName URLEncoder.encode(filename, UTF-8));File file new File(d:/Projects/practice/test-springboot/src/main/resources/file/ filename);ServletOutputStream ros response.getOutputStream();FileInputStream fis new FileInputStream(file);byte[] bytes new byte[2 * 1024];int len 0;while ((len fis.read(bytes)) ! -1) {ros.write(bytes, 0, len);}ros.flush();ros.close();fis.close()}预览文件 前端代码 templatediva hrefhttp://127.0.0.1:8083/file/previewFile?filename头像a.png头像a.png/a/div /templatescript import axios from axios export default {name: File,data() {return {}},methods: {} } /scriptstyle/style后端代码 GetMapping(previewFile)public void previewFile(RequestParam(filename) String filename) throws Exception {// 可使用ServletContext 通过文件名获取 媒体资源类型response.setHeader(HttpHeaders.CONTENT_TYPE, MediaType.IMAGE_PNG_VALUE);File file new File(d:/Projects/practice/test-springboot/src/main/resources/file/ filename);ServletOutputStream ros response.getOutputStream();// 可参考: StreamUtilsFileInputStream fis new FileInputStream(file);byte[] bytes new byte[4 * 1024];int len 0;while ((len fis.read(bytes)) ! -1) {ros.write(bytes, 0, len);}ros.flush();ros.close();fis.close() }
http://www.huolong8.cn/news/13321/

相关文章:

  • 做网站接口多少钱扬州恒通建设网站
  • 做网站图片多大网站建设要学
  • 佛山网站设计建设做设计及免费素材网站有哪些
  • 河北省和城乡建设厅网站首页手机百度如何发布广告
  • 网站创建的基本流程创业项目的网站
  • 怎么建立一个网站当站长更新wordpress需要ftp
  • 软件学校网站模板下载vr成品网站源码
  • 站长之家最新网站google adsense wordpress 插件
  • 一个考试网站怎么做鸟人高端网站建设
  • 在线网站你们会回来感谢我的平面设计网上接单
  • 做正版电子书下载网站成都网站设计排名的公司价格
  • 企业网站建设需要许可证吗高水平的网站建设
  • 网站后台不能审核删除天津seo培训哪家好
  • 网站广东省备案系统手机端网站做app
  • 无锡企业网站制作公司有哪些appstore下载免费软件
  • wordpress会务网站模版做购物网站如何推广
  • 音乐网站的设计与开发提升学历正规渠道
  • php网站开发cms网站建设成本包括什么
  • 网站开发 项目章程视频软件下载大全免费
  • 莆田网站格在哪里做建筑八大员报名网站
  • 网站建设怎么改首页的标题上海网站备案公司
  • 做视频网站为什么费钱设计公司起名字寓意好的字
  • 成都网站快照优化公司深圳全网营销网站
  • 阿里 设计网站建设wordpress注册相关
  • 郑州市精神文明建设 网站河南中原建设公司网站
  • 商丘做网站多少钱网站推广的公司
  • 东莞网站优化公司哪家好免费一键生成详情页
  • 怎么建设卡盟网站做网页的兼职平台
  • 10个网站做站群网上注册公司流程图文
  • 个个大公司网站wordpress 侧边栏 修改字体大小