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. Crash course statistics

    Crash course statistics 01什么是统计学 描述性统计(Descriptive statistics) 推理统计可以得出之外的,基于"样本"的推论统计学来估计 ...

  2. cas5.3.1 从搭建到连接mysql(简而优美)

    前言: cas是单点登录服务框架,为单点登录业务提供了便捷服务,它分为client,server端,client端要聚合到我们自己的项目. server端要单独构建运行,本篇文章主要讲解一下cas5. ...

  3. LinuxDHCP配置

    目录 一.DHCP服务 1.1.了解DHCP服务 1.2.使用DHCP的好处 1.3.DHCP的分配方式 1.4.DHCP的租约过程 客户机请求IP地址 重新登录 更新租约 1.5.使用DHCP动态配 ...

  4. Vue系列-01-基础语法

    vue.js文件 # https://blog-static.cnblogs.com/files/lichengguo/vue.js # 下载该文件,保存的路径为代码同级目录 js/vue.js 文件 ...

  5. ubuntu与主机ping不通的解决办法(主机检测不到虚拟网卡)

    文章目录 一.问题的出现与思路的转变 二.Ubuntu的网络适配器的俩种模式 1.桥接模式( Bridged) 2.NAT模式 三.桥接模式下的网卡配置出现问题 四.解决问题的步骤(一次通过) 集线器 ...

  6. STM32—DMA存储器到外设

    DMA目录 DMA简介 DMA框图 DMA传输数据分析 1.传输的方向 2.传输的数量 3.传输的模式 代码部分 DMA初始化结构体 USART配置函数 DMA配置函数 主函数 DMA简介 DMA(D ...

  7. SQL 练习1

    查询" 01 "课程比" 02 "课程成绩高的学生的信息及课程分数 SELECT sname,sage,class1,class2 from Student, ...

  8. WinForm嵌入Web网页的解决方案

    企业级信息化系统绝大部分采用BS架构实现,如门户网站.OA系统.电商网站等,通过浏览器输入Web网址即可访问,对于使用者来说非常便捷,对于开发维护者来说也非常方便,程序维护只需更新服务器即可,使用者无 ...

  9. 题解 [JXOI2012]奇怪的道路

    考场上我坚持认为这是个组合数题... 看到\(k\leq8\)我想状压来着,但是不知道怎么压 实际上,对于点i和点j的连边(\(j\in[i-k, i-1]\))只有连或不连两种状态 而如果i与比j编 ...

  10. cad转换成png,svg

    1.设置仓库可以在setting.xml中设置(也可以在pom中设置,设置项即可) <mirror> <id>AsposeJavaAPI</id> <name ...