首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何发送在nuxt.js中压缩的api响应

如何发送在nuxt.js中压缩的api响应
EN

Stack Overflow用户
提问于 2022-02-18 20:58:20
回答 1查看 170关注 0票数 1

Chrome灯塔告诉我,通过压缩我的api路由,我可以节省大约90%的传输字节。

我如何修改这段代码(api/某样东西,to )以启用压缩?

代码语言:javascript
运行
复制
export default {
    path: '/api/something',
    async handler(req, res) {
        let data = await obtainDataSomehow();
        res.end(JSON.stringify(data));
    }
}

静态文件和呈现的路由已经被压缩,我只对api路由有问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-23 11:45:11

选项1:速成和压缩中间件

如果您生成了服务器中间件扩展Express,那么您可以使用压缩中间件来处理HTTP响应的压缩:

例如:

代码语言:javascript
运行
复制
    import express from 'express';
    import compression from 'compression';
    
    const app = express();
    // NB: compression threshold set to 0 for demonstration purposes only;
    //     this should be set to a higher value, such as the default 1 kb
    //     in live applications
    app.use(compression({ threshold: 0 }));
    
    app.get('*', (req, res) => {
      const data = { success: true };
      res.setHeader('Content-Type', 'application/json');
      res.end(JSON.stringify(data));
    });
    
    export default {
      path: '/api/something',
      handler: app
    }

这可以从命令行进行测试,如:

代码语言:javascript
运行
复制
    curl -H "Accept-Encoding: gzip" -i http://localhost:3000/api/something

,它将显示响应头Content-Encoding: gzip

选项2:委托网关/反向代理

如果您的实时部署运行在网关或反向代理(如NGINX、Apache、Cloudflare等)后面,您可以让它处理压缩,而不必让服务器中间件这样做。

在这个场景中,还可以禁用Nuxt nuxt.config.js中的渲染器对其他资源的压缩。

代码语言:javascript
运行
复制
    export default {
      render: {
        compressor: false
      }
    };
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71179768

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档