从Koa中的POST请求下载文件

时间:2016-09-25 12:14:42

标签: javascript node.js download koa koa-router

我尝试使用koa-router从Koa中的POST请求处理程序触发下载。基本上,我试图做这样的事情:

app.js

const Koa = require('koa')
const router = require('./router')

const app = new Koa()

app.use(router.routes())
app.use(router.allowedMethods())

app.listen(3000)

router.js

const fs = require('fs')
const Router = require('koa-router')

const router = new Router()

router.post('/generate', function * () {
  const path = `${__dirname}/test.txt`
  this.body = fs.createReadStream(path)
  this.set('Content-disposition', 'attachment; filename= test.txt')
})

module.exports = router

client.js

const { fetch } = window;

const request = {
  method: 'POST',
  body: JSON.stringify({ fake: 'data' })
}

// Make the POST request
fetch('/generate', request)

但是,发送POST请求时,没有任何反应。我也没有在服务器控制台或浏览器控制台中收到任何错误。任何帮助将不胜感激!

3 个答案:

答案 0 :(得分:5)

您可以尝试使用https://github.com/koajs/send

router.post('/generate', function * (next) {
    yield send(this, 'file.txt');
});

在客户端,您需要在通过邮寄请求接收文件内容时创建并触发下载。将此代码放入请求回调

fetch('/generate', request)
  .then(res => { return res.text() })
  .then(content => {

    uriContent = "data:application/octet-stream," + encodeURIComponent(content);

    newWindow = window.open(uriContent, 'somefile');

  });

答案 1 :(得分:4)

您应该在正文中设置文件流,并使用该文件名将Content-disposition发送到附件。使用以下代码

const Router = require('koa-router');
const router = new Router();

router.post('/generate', function * () {
  const path = `${__dirname}/file.txt`;
  this.body = fs.createReadStream(path);
  this.set('Content-disposition', 'attachment; filename= file.txt');
});

module.exports = router;

更新:完整的工作代码:

var app = require('koa')();
var router = require('koa-router')();
const fs = require('fs');
router.post('/generate', function () {
  const path = `${__dirname}/file.txt`;
  this.body = fs.createReadStream(path);
  this.set('Content-disposition', 'attachment; filename= file.txt');
});

app
  .use(router.routes())
  .use(router.allowedMethods());

  app.listen(3000);

<强>客户端:

<button id="btnDownload">Download</button>

<script type="text/javascript">
    const request = {
        method: 'POST',
        body: JSON.stringify({
            fake: 'data'
        })
    }

    document.getElementById('download').onclick = () => {
        fetch('/generate', request)
            .then(res => {
                return res.text()
            })
            .then(content => {});
    }
</script>

答案 2 :(得分:0)

使用标签下载可以实现相同的功能。我更喜欢这个。它没有JS,但没有在safari中工作。

<!DOCTYPE html>
<html>
<body>

<p>Click on the w3schools logo to download the image:<p>

<a href="http://www.w3schools.com/images/myw3schoolsimage.jpg" download>
  <img border="0" src="http://www.w3schools.com/images/myw3schoolsimage.jpg" alt="W3Schools" width="104" height="142">
</a>

<p><b>Note:</b> The download attribute is not supported in Edge version 12, IE, Safari or Opera version 12 (and earlier).</p>

</body>
</html>

refernce: http://www.w3schools.com/tags/att_a_download.asp

相关问题