如何在 CycleJS 中从 POST 请求中获取文件
How get file from POST request in CycleJS
我写了一个Spring控制器,它在请求中接受json并响应pdf文件。
public ResponseEntity<byte[]> generateResp(...)
byte[] gMapRep = Files.readAllBytes(file.toPath());
HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.setContentType(MediaType.parseMediaType("application/pdf"));
httpHeaders.setContentDispositionFormData("content-disposition", "filename=report.pdf");
httpHeaders.setCacheControl("must-relative, post-check=0, pre-check=0");
return ResponseEntity
.ok()
.headers(httpHeaders)
.body(gMapRep);
它在邮递员上工作正常。在 POST 方法上是必要的,因为我需要发送一些参数。但是我如何从响应中获取/下载 CycleJS 中的 pdf 文件。我在前端尝试过:
const buttonRequest$ = actions.buttonClick$
.withLatestFrom(sources.arcgisDriver.onMapLoaded,
(ev, _)=> {
return {
url: myURL,
method: 'POST',
type: 'application/json',
send: data
}
});
sources.HTTP
.filter(response => {
return !response.error && response.request.url.includes(myURL)
})
.subscribe(resp => window.open("data:application/pdf;base64, " + resp.text, '', 'height=650,width=840'));
这是一个客户端循环.js使用 RxJS 示例从(模拟的)API 获取值,并在单击按钮时填充隐藏表单,然后将表单提交到服务器脚本,该脚本返回定向到新浏览器窗口或选项卡的 PDF 文档:
import Rx from 'rx';
import Cycle from '@cycle/core';
import {div, form, input, button, makeDOMDriver} from '@cycle/dom';
function makeFormDriver (formid, elemid) {
return function (post$) {
post$.subscribeOnNext(function (post) {
document.querySelector(elemid).value = post;
document.querySelector(formid).submit();
});
}
}
function main({DOM}) {
const buttonClick$ = DOM.select('button#pdf').events('click');
const api$ = Rx.Observable.of('test.pdf'); // mocked API
const post$ = buttonClick$.withLatestFrom(api$, (bclick, file) => file);
const vdom$ = Rx.Observable.of(
div([
form('#pdfform', {
method: 'post', action: 'http://localhost:3000/file',
target: '_blank', style: 'display: none;'
}, [input(#filename', {type: 'hidden', name: 'filename'})]),
button('#pdf', 'PDF')
])
);
return {
DOM: vdom$,
FORM: post$
};
}
Cycle.run(main, {
DOM: CycleDOM.makeDOMDriver('#app'),
FORM: makeFormDriver('#pdfform', '#filename')
});
下面是一个客户端周期.js使用 xstream 示例:
import xs from 'xstream';
import Cycle from '@cycle/xstream-run';
import {div, form, input, button, makeDOMDriver} from '@cycle/dom';
function makeFormDriver (formId, elemId) {
const form = document.querySelector(formId);
const elem = document.querySelector(elemId);
return function (post$) {
post$.addListener({
next: function (post) {
elem.value = post; // populate form data
form.submit(); // submit form
},
error: function () {},
complete: function () {}
});
}
}
function main(sources) {
const buttonclick$ = sources.DOM.select('#pdfbutton').events('click');
const api$ = xs.of('test.pdf'); // mocked API
const post$ = buttonclick$.map(bclick => api$).flatten(); // ~ withLatestFrom
let vtree$ = xs.of(
div('.pdf', [
form('#pdfform', {attrs: {
method: 'post', action: '/file',
target: '_blank', style: 'display: none;' // new tab and hide form
}}, [
input('#filename', {attrs: {name: 'filename', type: 'input'}}),
]),
button('#pdfbutton', 'view pdf')
])
)
return {
DOM: vtree$,
FORM: post$
};
}
Cycle.run(main, {
DOM: makeDOMDriver('.app-container'),
FORM: makeFormDriver('#pdfform', '#filename')
});
对于踢球,这里有一个服务器端循环.js和xstream示例使用Express接收POST数据并返回指定的文档:
import xs from 'xstream';
import Cycle from '@cycle/xstream-run';
import express from 'express';
import bodyParser from 'body-parser';
let server = express();
server.use(bodyParser.urlencoded({ extended: false }))
function makeDownloadDriver (effect) {
return function (postfile$) {
let file$ = postfile$.map(body => body.filename)
file$.addListener({
next: effect,
error: function () {},
complete: function () {}
})
}
}
server.use(function (req, res) {
let postfile$ = xs.of(req)
.filter(req => 'POST' === req.method && '/file' === req.url)
.map(req => req.body);
function main (sources) {
return {
postfile: postfile$
};
}
Cycle.run(main, {
postfile: makeDownloadDriver(file => res.sendFile(file, {root: __dirname})),
});
});
server.listen(3000);
要查看这些与页面路由器一起工作,请查看周期同构文件下载。
相关文章:
- D3 Json请求获取XmlHttpRequest错误:访问控制允许原点不允许原点为null
- 找不到Angular+Ionic Post请求获取404
- 如何从 ajax 请求获取数据响应
- 在Sencha touch 2.0中使用Ajax请求获取cookie
- 在 Python 中使用请求获取页面但不使用源代码,为什么?如何获取源代码
- 从javascript Http请求获取Java List
- Django View 无法使用请求获取文件.来自 ajax 表单的文件提交
- GiantBomb API 请求获取 HTML 而不是 JSON,Nodejs 请求模块
- 使用 ajax 请求获取上一个和下一个对象
- 从AJAX请求获取javascript变量的数字时遇到问题
- JQuery请求获取超过10个RSS提要
- XEP-0133:管理员请求获取所有在线用户列表
- 通过javascript通过ajax请求获取页面的完整html源代码
- NodeJS/Angular编辑请求获取400错误
- 从NodeJS请求获取主机
- 从http请求获取包信息
- 使用请求获取API结果,并集成到Hubot响应中
- 通过jQuery ajax请求获取数据
- Fcbkcomplete用ajax请求获取数据
- Node.js请求获取一个VAST标签