js向java发送文件_如何通过ajax实现文件上传-java文件传输

大噶好,今天我们先简单的来了解一个非常实用的功能,通过ajax上传文件。

技能:vue + axios + servlet

视图

vue.js

var vue = new Vue({

el: "#app",

data:{

pimage:""

}

},

methods:{

uploadPimage:function (event) {

//通过ajax 上传文件

var formData = new FormData();

formData.append("pimage",event.target.files[0]);

axios({

url:"https://www.shangyouw.cn${ pageContext.request.contextPath }/AdminProductServlet?method=uploadPimage",

method: 'post',

headers:{

'Content-Type': 'multipart/form-data'

},

data:formData

}).then(function (resp) {

//将服务器的图片地址 赋给 product.pimage

vue.pimage = resp.data;

})

}

}

})

核心的知识就是通过 FormData对象模拟一个form表单数据,我们知道表单提交必须设置表单属性enctype="multipart/form-data",并且提交方式为post。所以我们在通过axios提交数据时,需要设置请求头'Content-Type': 'multipart/form-data'。

Servlet代码public String uploadPimage(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {

Part uploadPart = request.getPart("pimage");

//获取文件名(来自于请求头 Content-Disposition: form-data; name="upload"; filename="big.jpg")

String contentDisposition = uploadPart.getHeader("Content-Disposition");

int beginIndex = contentDisposition.indexOf("filename=\"") + 10;

String fileName = contentDisposition.substring(beginIndex).replaceAll("\"", "");

if (!fileName.isEmpty()) {

fileName = "products/1/" + UuidUtils.getUUID() + fileName;

String filePath = request.getServletContext().getRealPath("/") + fileName;

//获取字节流

InputStream inputStream = uploadPart.getInputStream();

OutputStream outputStream = new FileOutputStream(filePath);

//保存文件

IOUtils.copy(inputStream, outputStream);

}

//向前端响应 文件名

return fileName;

}

好,搞定。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
简单的利用javajs实现文件上传 package com.fendou.myString; import java.io.File; import java.io.IOException; import java.io.PrintWriter; import java.util.Iterator; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileItemFactory; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; public class FileUpload extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { boolean a=ServletFileUpload.isMultipartContent(request); if(a){ FileItemFactory factory=new DiskFileItemFactory(); ServletFileUpload upload=new ServletFileUpload (factory); Iterator items; try{ items=upload.parseRequest (request).iterator(); while(items.hasNext()){ FileItem item=(FileItem) items.next(); if(!item.isFormField()){ String name=item.getName (); String fileName=name.substring(name.lastIndexOf("\\")+1, name.length()); String path=request.getRealPath("file")+File.pathSeparatorChar+fileName; File uploadFile=new File (path); request.getSession ().setAttribute("file", uploadFile); item.write(uploadFile); response.setContentType ("text/html"); response.setCharacterEncoding("utf-8"); PrintWriter out=response.getWriter(); // out.print("<font size='2'> 上传的文件为:"+name+"<br>"); // out.print("保存在服务器上 的地址为:"+path+"</font>"); } } }catch(Exception e){ e.printStackTrace(); } } response.sendRedirect("smartupload.jsp"); } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值