node express项目中使用了connect-history-api-fallback中间件后原有的获取图片接口加载失败

如题

接口代码如下

/ get /avatar/file_id
router.get('/avatar', async (req, res, next) => {
    const id = req.query.file_id
    const url = await FileModel.getFilePath(id)
    res.set('content-type', 'image/jpg')
    let stream = fs.createReadStream(url)
    let responseData = []; // 存储文件流
    if (stream) { // 判断状态
        stream.on('data', chunk => {
            responseData.push(chunk)
        })
        stream.on('end', () => {
            let finalData = Buffer.concat(responseData)
            res.write(finalData)
            res.end();
        });
    }
})

FileModel.getFilePath 代码如下

// 获取文件路径
handleFile.getFilePath = async function  (id) {
    let fileObject = await handleFile.getFileById(id)
    return path.join(__dirname, `../uploads/${fileObject.filename}`)
}

index.js 引入 history 代码如下

const express = require('express')
const session = require('express-session')
const bodyParser = require('body-parser')
const routes = require('./routes')
const history = require('connect-history-api-fallback')
const path = require('path')
const favicon = require('serve-favicon')

const app = new express()

app.use(history())
app.use(bodyParser.urlencoded({extended: true}))
app.use(express.static(path.join(__dirname, '../dist')))
app.use(favicon(path.join(__dirname, './favicon.ico')))



const sessionStore = new session.MemoryStore({ reapInterval: 3600 * 1000 })
app.use(session({
    secret: 'Stefanie Sun',
    store: sessionStore,
    resave: true, // 强制更新 session
    saveUninitialized: true,  // 
    cookie: { maxAge: 3600 * 1000 }, // 过期时间
    rolling: true
}))


routes(app)

但是在界面中使用获取图片接口时报了 304 且获取不到文件

clipboard.png

我将 history 删掉后就一切正常
求问这个怎么解决

阅读 5.6k
2 个回答

解决了,其实是用了connect-history-api-fallback中间件后所有的get请求都会变成index,所以get请求根本没有执行,设置rewrites就行了

app.use(history({
    rewrites: [
      {
        from: /^\/api\/.*$/,
        to: function(context) {
            return context.parsedUrl.path
        }
      }
    ]
  }))

设置了rewrites之后表示所有带api的get都代理到parsedUrl.path,其实就是原来的路径

这个包是干啥的啊,能对stream流使用吗

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题