1、问题描述:在页面上一些下载附件功能,点击触发执行下载操作时候,有些电脑的浏览器可以,有些电脑的浏览器下载不了,电脑打开弹出的下载框下载的不是一个文件,而是一个如jspx后缀名的页面,jspx后缀是访问的xhtml页面,显示的是一个代码返回的下载页面名称:

下图是返回的doc格式的,可以正常下载,下面是返回代码返回的下载页面名称:

jspx后缀是访问的xhtml页面,这种是不能正常下载的。

2、问题排查解决:大部分的电脑大部分的浏览器是可以正常下载的,可能涉及到到浏览器版本和其兼容性的问题,不同的内核或者不同的版本所支持的接口或者方法有所不同,内核及版本太多不去一一深究,排查优化代码,原来是在页面的js脚本对应方法中跳转到下载附件的这个页面地址,然后再调用后台实现的:

有时下载会是一个如jspx后缀名的页面,想着不通过这个中间页面直接实现下载,方法是页面js脚本方法中直接访问restful接口形式实现,如下:

这边的地址为一个后台的类注解加上方法注解的方式访问的一个restful接口:

这个接口返回的是二进制字节流文件,用OutputStream对象输出,附上下载附件的后台方法:

    @Path("/downloadDlwjBpb")
@GET
@Produces(MediaType.APPLICATION_OCTET_STREAM)
public StreamingOutput downloadDlwjBpb(@Context HttpServletResponse response, @Context HttpServletRequest request) {
String projectguid = request.getParameter("projectguid");
String licenseName = JsfHelper.getDeployWarPath() + "WEB-INF/classes/license.xml";
License license = new License();
try {
license.setLicense(licenseName);
BaseService service = new BaseService();
// 取数据的语句
String sql = "select * from audit_project where rowguid = '" + projectguid + "'";
String sql2 = "select * from audit_dlwj where projectguid='" + projectguid + "'";
//String sql3 = "select * from audit_dyfy_project_yyss where projectguid='" + projectguid + "'";
// 执行封装查询方法,返回实体类
AuditProject AuditProject = service.getSingleResultNative(sql, AuditProject.class);
AuditDlwj dlwj = service.getSingleResultNative(sql2, AuditDlwj.class);
if (dlwj == null) {
dlwj = new AuditDlwj();
}
// document对象结合word邮件合并域,代码给word域赋值
Document doc = new Document();
String filepathname = JsfHelper.getDeployWarPath() + "wsbsdt/PrintDocFlolder/dlwjsqb.doc";
doc = new Document(filepathname);
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
Map<Object, Object> map = new HashMap<Object, Object>();
// 取值赋值给word域
map.put("applyername", AuditProject.getApplyername());
map.put("contactperson", AuditProject.getContactperson());
map.put("contactphone", AuditProject.getContactphone());
map.put("address", AuditProject.getAddress());
map.put("kwdate", "开始时间:"+EpointDateUtil.convertDate2String(dlwj.getKwdateks(), EpointDateUtil.DATE_FORMAT)+"至结束时间:"+EpointDateUtil.convertDate2String(dlwj.getKwdatejs(), EpointDateUtil.DATE_FORMAT));
map.put("kwaddress", dlwj.getKwaddress());
map.put("applyreason", dlwj.getApplyreason());
if("1".equals(dlwj.getIsbystreetcar())){
map.put("isbystreetcar1", "");
map.put("isbystreetcar0", "□");
}else{
map.put("isbystreetcar1", "□");
map.put("isbystreetcar0", "");
}
if("1".equals(dlwj.getIsaboutgreen())){
map.put("isaboutgreen1", "");
map.put("isaboutgreen0", "□");
}else{
map.put("isaboutgreen1", "□");
map.put("isaboutgreen0", "");
} String tableid = String.valueOf("");
// 在通过mis平台处理通用的字段值
List<Object[]> objlist = getWordFieldAndValue(tableid, "", map);
String[] fieldNames = (String[]) objlist.get(0);// word域
Object[] values = objlist.get(1);// 域对应的值
// 2 替换域和表格并且生成word入库
doc.getMailMerge().execute(fieldNames, values);// 替换基本信息表word中的域
doc.getFirstSection().getPageSetup().setSectionStart(SectionStart.NEW_PAGE);
doc.save(outputStream, SaveFormat.DOC);
// 定义二进制流对象,用来接收数据返回outputstream对象
final byte[] in2b = outputStream.toByteArray();
//JsfHelper.sendRespose(in2b, URLEncoder.encode("道路挖掘申请表.doc"), ".doc");
String fileName = URLEncoder.encode("道路挖掘申请表.doc", "utf-8");
response.setContentLength(in2b.length);
//Content-Disposition不是标准版的http响应头,它是扩展header
response.setHeader("Content-Disposition", "attachment; filename=" + fileName + "");
return new StreamingOutput() { public void write(OutputStream output) throws IOException, WebApplicationException {
output.write(in2b);
output.flush();
}
};
}
catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} return null;
}

word域实现动态填充信息附件下载的更多相关文章

  1. word域3

    WORD是文字处理软件,我们在日常处理一些文字时经常遇到一些问题,如:各种公式的录入,尽管Word都提供了"公式编辑器",但其插入的却是"对象",有时排版会感觉 ...

  2. 生成word附件和word域动态赋值

    生成word文档和word域动态赋值,很多时候需要生成这样的word文档供下载和打印,先制作一个包含了域的 word的模板附件,放在服务器端或者字节流存入数据库,以供需要的时候代码可以获取到,如: 其 ...

  3. [转载]Java动态填充word文档并上传到服务器

    一. 需求背景 在一些特殊应用场合,客户希望在服务器上生成文档的同时并填充数据,客户端的页面不显示打开文档,但是服务器上生成文档对服务器压力很大,目前服务器上生成文档第一种就是方式是jacob, 但是 ...

  4. [原创]Java动态填充word文档并上传到服务器

    一. 需求背景 在一些特殊应用场合,客户希望在服务器上生成文档的同时并填充数据,客户端的页面不显示打开文档,但是服务器上生成文档对服务器压力很大,目前服务器上生成文档第一种就是方式是jacob, 但是 ...

  5. C#动态生成Word文档并填充数据

    C#也能动态生成Word文档并填充数据 http://www.cnblogs.com/qyfan82/archive/2007/09/14/893293.html 引用http://blog.csdn ...

  6. javaweb-JSP action中附件下载的写法

     附件下载(包括图片,exl,word)在前台必须给出一个iframe 或者类似于window的窗口,另外,Java文件下载不能通过ajax进行请求,必须添加src属性首选,前台的链接拼接html如下 ...

  7. word域1

    Description: 域是WORD中的一种特殊命令,它由花括号.域名(域代码)及选项开关构成.域代码类似于公式,域选项并关是特殊指令,在域中可触发特定的操作.在用WORD处理文档时若能巧妙应用域, ...

  8. 解析:使用easyui的form提交表单,在IE下出现类似附件下载时提示是否保存的现象

    之前开发时遇到的一个问题,使用easyui的form提交表单,在Chrome下时没问题的,但是在IE下出现类似附件下载时提示是否保存的现象. 这里记录一下如何解决的.其实这个现象不光是easyui的f ...

  9. phonegap 附件下载及打开附件

    出处:http://my.oschina.net/u/1011854/blog/169434 再次 谢谢作者! 在开发web app并且使用phonegap的情况下,附件下载着实是一件令人头疼的事,什 ...

随机推荐

  1. javaSE面向对象编程

    面向对象编程 构造器 构造器就是和类名相同但无返回类型的方法. public class Person { //一个类即使什么都不写,它也会存在一个方法 //显示的定义构造器 String name; ...

  2. 如何让win10开机默认开启小键盘?

    如何让win10开机默认开启小键盘? windows10默认是关闭小键盘的.每次输入开机密码的时候都需要按一下小键盘开启键(numlock),才能按数字键 一.运行注册表编辑器,修改InitialKe ...

  3. Clickhouse Docker集群部署

    写在前面 抽空来更新一下大数据的玩意儿了,起初架构选型的时候有考虑Hadoop那一套做数仓,但是Hadoop要求的服务器数量有点高,集群至少6台或以上,所以选择了Clickhouse(后面简称CH). ...

  4. springboot2集成log4j2

    pom <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http:// ...

  5. pikachu RCE远程系统命令执行

    远程系统命令执行 一般出现这种漏洞,是因为应用系统从设计上需要给用户提供指定的远程命令操作的接口比如我们常见的路由器.防火墙.入侵检测等设备的web管理界面上一般会给用户提供一个ping操作的web界 ...

  6. shodan搜索

    扫描一切联网的设备 www.shodan.io 一.ip 直接搜索:123.123.123.123 二.搜索服务 http http country:"DE" 指定搜索德国 htt ...

  7. Linux 并发服务器编程(多进程)

    文章目录 说明 注意事项 server.c client.c 运行截图 说明 在Linux中通过流式套接字编程(TCP),实现一个并发服务器的访问回显,适合刚学完Linux套接字编程的朋友进行巩固训练 ...

  8. docker部署elasticsearch-+-Kibana(6-8)-+-SpringBoot-2-1-6

    elasticsearch快速开始 docker run -d --name elasticsearch --net somenetwork -p 9200:9200 -p 9300:9300 -e ...

  9. @ImportResource-SpringBoot使用xml配置Bean

    前言 SpringBoot推荐使用注解的方式去声明bean,但还是提供了xml的方式去加载bean 一.创建要声明为bean的实体类 WzqEntity.java package com; /** * ...

  10. MySql 文件导入导出

    1.将表输出到文件 select * FROM zhilianzhaopin4 INTO OUTFILE 'G:/test.csv'      --------输出位置 fields terminat ...