java jquery 文件下载_java-如何使用Jquery从httpServlet下载文件?

在我的应用程序中,在客户端创建了一个json对象.该对象被发布到HttpServlet,后者基于POST数据创建pdf文件.

该文件将发送回用户.调用成功函数,并记录流数据.但是,我想要下载该文件.

如何实现呢?

我的客户端代码:

$(document).ready(function() {

// when the print button is clicked

$('#exportButton').click(function() {

var tableIdx = performanceDetailTableController.getTableIdx();

var allData = {

"shipTable1":{

"rows":[

{ "latitude":"12323","longitude":"213213"},

{ "latitude":"213213","longitude":"543543"}

]},

"shipTable2":{

"rows":[

{ "latitude":"12323", "longitude":"213213"},

{ "latitude":"213213","longitude":"543543"}

]}

}

var postData = JSON.stringify(allData);

$.ajax({

type : "POST",

url : 'pdfServlet',

contentType: "application/json; charset=utf-8",

data : postData,

async : false,

success : function(data) {

alert("got some data");

console.log(data);

},

});

});

});

然后servlet创建文件:

@Override

public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {

// get the json content

StringBuffer jsonContent = getPostedContent(request);

log.info(jsonContent.toString());

// convert json to pojo's

Tables tables = getTablesFromString(jsonContent);

// create a xml stream

ByteArrayOutputStream xml = new XmlConverter().getXMLSource(tables);

// put the xml on the request

request = setXmlOnRequest(request, xml);

// create pdf data of the pdf-able xml content

ByteArrayOutputStream pdf = new PdfHandler().createPdfDataStream(request);

// response = createResponseheaders(response, request);

response.setContentType("application/pdf");

response.setContentLength(pdf.size());

response.setHeader("Content-disposition", "attachment; filename=test.pdf");

response.setCharacterEncoding("utf-8");

response.getOutputStream().write(pdf.toByteArray());

//close the streams

pdf.close();

response.getOutputStream().close();

}

日志中的输出:

%PDF-1.4

%

4 0 obj

<<

/Producer (Apache FOP Version SVN branches/fop-0_95)

/CreationDate (D:20130725162007+02'00')

>>

endobj

5 0 obj

<<

/N 3

/Length 11 0 R

/Filter /FlateDecode

>>

stream

xwTS?7PhRHH.*1 J

*我的解决方案:*

我创建了一个带有一个隐藏字段的表单:

export

比我将我的jquery post数据控制器更改为:

$('#exportButton').click(function() {

var tableIdx = performanceDetailTableController.getTableIdx();

var allData = {

"shipTable1":{

"rows":[

{ "latitude":"12323","longitude":"213213"},

{ "latitude":"213213","longitude":"543543"}

]},

"shipTable2":{

"rows":[

{ "latitude":"12323", "longitude":"213213"},

{ "latitude":"213213","longitude":"543543"}

]}

}

var postData = JSON.stringify(allData);

// put the data on the hidden form field in the export form

$('#pdf_data').val(postData);

// and submit the form

$('#exportForm').submit();

});

所以现在当我单击“导出”按钮时,表单中的隐藏字段获取要发布的数据,并且数据以www-form编码形式发布.

这样,servlet可以处理请求并将文件下载到客户端.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. jQuery实现文件上传功能: HTML代码: ``` <form action="upload.php" method="post" enctype="multipart/form-data"> <input type="file" name="file" id="file"> <input type="button" value="上传" id="upload"> </form> <div id="message"></div> ``` JavaScript代码: ``` $(document).ready(function(){ $('#upload').click(function(){ var file_data = $('#file').prop('files')[0]; var form_data = new FormData(); form_data.append('file', file_data); $.ajax({ url: 'upload.php', dataType: 'text', cache: false, contentType: false, processData: false, data: form_data, type: 'post', success: function(response){ $('#message').html(response); }, error: function(response){ $('#message').html('上传失败'); } }); }); }); ``` 2. Java实现文件上传功能: HTML代码: ``` <form action="upload.jsp" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上传"> </form> ``` Java代码: ``` import java.io.File; import java.io.IOException; import java.io.PrintWriter; import java.util.Iterator; import java.util.List; 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.FileUploadException; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; public class UploadServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); boolean isMultipart = ServletFileUpload.isMultipartContent(request); if (!isMultipart) { out.println("<html><head><title>文件上传</title></head><body>"); out.println("<p>请上传文件</p>"); out.println("</body></html>"); return; } DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(1024 * 1024); File tempDir = new File("d:/temp"); tempDir.mkdirs(); factory.setRepository(tempDir); ServletFileUpload upload = new ServletFileUpload(factory); upload.setHeaderEncoding("UTF-8"); upload.setSizeMax(1024 * 1024 * 10); try { List<FileItem> items = upload.parseRequest(request); Iterator<FileItem> iter = items.iterator(); while (iter.hasNext()) { FileItem item = iter.next(); if (!item.isFormField()) { String fileName = item.getName(); String filePath = "d:/upload/" + fileName; File uploadedFile = new File(filePath); item.write(uploadedFile); } } out.println("<html><head><title>文件上传</title></head><body>"); out.println("<p>上传成功</p>"); out.println("</body></html>"); } catch (FileUploadException e) { out.println("<html><head><title>文件上传</title></head><body>"); out.println("<p>上传失败</p>"); out.println("</body></html>"); } catch (Exception e) { out.println("<html><head><title>文件上传</title></head><body>"); out.println("<p>上传失败</p>"); out.println("</body></html>"); } out.close(); } } ``` 注意:使用Java实现文件上传功能需要引入Apache Commons FileUpload库。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值