- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在我的 JAX-RS 服务中使用 apache-poi 生成 Exel,并将 application/vnd.ms-excel 响应发送到 angularJs 应用程序。文件下载成功,但里面的数据被编码。
@POST
@Path("getExelStreamDocDB")
@Produces("application/vnd.ms-excel")
public Response getExelStreamDoc(String req) {
File file = new File("Excel.xls");
Workbook workbook = new XSSFWorkbook();
Sheet sheet = workbook.createSheet("report");
for (int i = 0; i < 6; i++) {
Row newRow = sheet.createRow(i);
for (int j = 0; j < 1; j++) {
newRow.createCell(j).setCellValue("Ankush");
}
}
for(int i = 0; i < 1; i++) {
sheet.autoSizeColumn(i);
}
FileOutputStream fos=null;
try {
fos = new FileOutputStream(file);
workbook.write(fos);
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
ResponseBuilder response = Response.ok((Object)file);
response.header("Content-Disposition","attachment; filename=poi-generated-file.xlsx");
return response.build();
}
AngularJS
$scope.downloadExcel = function() {
exelService.getExcel({}).then(function(data) {
console.log(data);
var blob = new Blob([data], {type: "application/vnd.ms-excel"});
var objectUrl = URL.createObjectURL(blob);
window.open(objectUrl);
})
在使用 SOAP UI 测试服务时,我得到以下响应
<data contentType="application/vnd.ms-excel" contentLength="3368">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</data>
最佳答案
你能试试这个……吗?
$scope.downloadExcel = function() {
exelService.getExcel({}).then(function(data) {
var data = window.atob(data);
var buf = new ArrayBuffer(data.length * 2);
var bufView = new Uint8Array(buf);
var file;
for (var i = 0, strLen = data.length; i < strLen; i++) {
bufView[i] = data.charCodeAt(i);
}
file = new Blob([buf], { type: 'application/vnd.ms-excel' });
this.fileURL = URL.createObjectURL(file);
window.open(this.fileURL);
})
关于javascript - 将 Exel 响应从 JAX-RS 发送到 AngularJS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53717873/
Apache CXF 可以完成任务。但我想在没有任何 spring 依赖的情况下组合它。提前谢谢你! 最佳答案 JAX-WS 和 JAX-RS 都是 Java EE 6 的一部分.因此,您可以在不使用
Apache CXF 可以完成任务。但我想在没有任何 spring 依赖的情况下组合它。提前谢谢你! 最佳答案 JAX-WS 和 JAX-RS 都是 Java EE 6 的一部分.因此,您可以在不使用
所以我的意思是你有一个分类特征 $X$(假设你已经把它变成了整数)并说你想使用特征 $A$ 将它嵌入到某个维度中,其中 $A$ 是 arity x n_embed . 通常的做法是什么?使用 for
所以我的意思是你有一个分类特征 $X$(假设你已经把它变成了整数)并说你想使用特征 $A$ 将它嵌入到某个维度中,其中 $A$ 是 arity x n_embed . 通常的做法是什么?使用 for
我知道网上有很多文档主要描述技术差异。 但是我很想知道您更喜欢一种特定类型而不是其他类型的常见用例是什么? 这些偏好是因为集成模式/产品支持特定类型吗? 最佳答案 谢谢你的回答。然而实际用例差异以及何
我想将 CXF 与 Google Guice 集成。我已经在我的项目中使用 Guice,并且我想避免添加额外的依赖项。 CXF 是我的选择,因为要求之一是能够向服务用户提供 XML、JSON、JSON
来自 JSR-339: For simplicity, JAX-RS implementations are NOT REQUIRED to support processing groups oth
我开始使用 JAX WS 研究 Java Web 服务。我正在阅读的书的第一章展示了如何仅使用 java SE 构建和部署简单的 jax ws web 服务。特别是,Web 服务是通过 Endpoin
在 JAX 的快速入门教程中,我发现可以使用以下代码行为可微函数 fun 高效地计算 Hessian 矩阵: from jax import jacfwd, jacrev def hessian(fu
JAX-RS 提供了 StreamingOutput 接口(interface),我们可以实现它来对我们的响应主体进行原始流处理。 public interface StreamingOutput {
有没有办法获得java.lang.reflect.Method为给定的 @Path 调用的方法(用 HttpServletRequest 注释) ? 这是我的用例:我在 Java EE 中 Filte
我接到了一家公司的任务,该任务向我发送了一台已完成所有设置的虚拟机。任务是我必须创建一个 API 来从数据库中检索人员详细信息并显示它。 问题是,当我运行应用程序时,服务器返回一个包含 hello w
我有一个 POST 方法调用,它接受很少的表单参数。我希望 JAX-RS 能够处理不存在特定表单参数的情况。 示例: @POST @Produces (MediaType.APPLICATION_JS
我有 JAX-RS 网络应用程序,我想记录从获取请求到响应的时间量。在带有 servlet 过滤器的 Spring Boot 中很容易。但是我的应用程序中的过滤器无法正常工作: @Provider p
使用以下网址。 http://doma.in/context/resource/some/.../undefined 我想获取 ../resource 之后的路径名,即 /some/.../undef
我编写了 2 个 Web 服务,一个使用 Jax-WS,一个使用 Jax-RPC。他们只是返回一个字符串。 我使用 jMeter 进行了压力测试,奇怪的是,Jax-RPC 速度更快。 我什么时候才能在
我花了几个小时在嵌入式 Jetty 9.1.0.v20131115 和 RESTEasy 3.0.5.Final 中安装自定义登录服务。我的登录服务将在数据库中查找用户并为他们分配角色。它看起来像这样
有没有办法操纵jaxws中使用的编码器。 我喜欢发送一个在网络服务请求中提交的 cdata,为此我想在这里尝试类似描述的东西:http://odedpeer.blogspot.de/2010/07/j
我想从 java 服务器 (Restful Jax-rs) 发送图像。我的客户是安卓。 @GET public Response getUserImage() { byte[] image =new
我对网络服务很陌生。我找不到 JAX-WS 和 CXF 之间的区别。 据我了解,JAX-WS是java提供的规范,CXF是实现。 如果我错了,请纠正我。 最佳答案 是的,你是对的。 JAX-WS 是基
我是一名优秀的程序员,十分优秀!