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. 自学linux——16.LAMP项目上线流程

    LAMP项目上线流程 一.编译安装与卸载Nginx(web服务器软件,类似于Apache) 1.安装nginx ①    下载nginx 网页下载https://nginx.org/en/downlo ...

  2. jadx的使用

    使用jadx之前必须安装配置java环境才能正常打开运行 https://www.cnblogs.com/yhoil/p/14808648.html 一.前言 今天介绍一个非常好用的反编译的工具 ja ...

  3. django有什么CMS比较好用?哪个好?

    这个网站有目前在电子商务领域流行的django cms的横向对比表格,可以看看 https://djangopackages.org/grids/g/ecommerce/ 从结果上来看,django- ...

  4. SpringBoot开发十七-事务管理

    需求介绍 熟悉事务管理. 什么是事务 事务是由N步数据库操作序列组成的逻辑执行单元,这系列操作要么全执行,要么全放弃执行. 事务的特性(ACID) 原子性(Atomicity):事务是应用中不可再分的 ...

  5. unserialize反序列化 安鸾 Writeup

    关于php反序列化漏洞原理什么,可以看看前辈的文章: https://xz.aliyun.com/t/3674 https://chybeta.github.io/2017/06/17/浅谈php反序 ...

  6. python3 Redis利用脚本

    ### Redis weakpassword # 获取password def passwd_dict(dict): with open(str(password_dict), 'r', encodi ...

  7. Pikachu-Unsafe Fileupload模块

    一.概述 文件上传功能在web应用系统很常见,比如很多网站注册的时候需要上传头像.上传附件等等.当用户点击上传按钮后,后台会对上传的文件进行判断 比如是否是指定的类型.后缀名.大小等等,然后将其按照设 ...

  8. Pytest+Allure 示例

    0. 前言 简介 Allure 框架是一个灵活的.轻量级的.支持多语言的测试报告工具,它不仅以 Web 的方式展示了简介的测试结果,而且允许参与开发过程的每个人可以从日常执行的测试中,最大限度地提取有 ...

  9. MySQL——分表,分库操作

    说明 大数据量并且访问频繁的表,将其分为若干个表.如果不分的话,进行一次查询就会将表锁住,导致不能进行其他操作,故分表.表分割垂直分割应用场景:热数据放一个表里,冷数据放一个表里.冷数据使用MyIsa ...

  10. ASP.NET Core:ASP.NET Core程序使用Docker部署

    一.前言 这篇文章介绍如何将一个ASP.NET Core应用程序在Docker中进行部署.开发工具使用的是Visual Studio 2019和VS Code. 二.使用Docker部署 我们选择新建 ...