gpt4 book ai didi

graphql - 如何使用 Nuxt ServerMiddleware 和 Apollo GraphQL 处理 301 重定向

转载 作者:行者123 更新时间:2023-12-02 03:08:37 25 4
gpt4 key购买 nike

我目前正在构建一个 Vue/Nuxt 应用程序,并结合修改后的 Saleor 安装来在线销售产品。

当我们从现有系统迁移时,我们需要能够处理从旧网站 URL 到新网站 URL 的 301 重定向。

我已修改 API 以响应以下 GraphQL 查询。

export const CHECK_REDIRECTS_QUERY = gql`
query Redirect($oldPath: String) {
redirect(oldPath: $oldPath) {
oldPath
newPath
}
}
`

this recommendation之后我在 ~/serverMiddleware/redirect.js 文件中创建了以下代码

import { CHECK_REDIRECTS_QUERY } from '~/graphql/navigation/queries'

export default function(req, res, next) {
console.log('redirects middleware')
// context.userAgent = process.server ? context.req.headers['user-agent'] : navigator.userAgent
this.$apollo
.query({
query: CHECK_REDIRECTS_QUERY,
variables: {
oldPath: '/test/11/old/'
}
})
.then(({ data }) => {
if (data.redirect.newUrl !== '') {
res.writeHead(301, { Location: data.redirect.newUrl })
res.end()
}
})
}

我还将其添加到我的 nuxt.config.js 文件中,如下所示:

 ... 
serverMiddleware: ['~/serverMiddleware/redirect.js'],
...

这不起作用,而且我不仅没有得到重定向,我期望函数开头的 console.log 也不会触发。

此外,我还尝试使用 github 推荐中编写的代码,这非常“不稳定”,在大约 50 次服务器重新启动中可能会触发两次。

我没有收到任何控制台通知,表明 apollo 无法在服务器中间件中使用,并且网站的其余部分似乎运行正常。

此外,为了澄清,我假设中间件应该在每个页面上自动触发,而不需要从组件手动调用?

最佳答案

最后我在nuxtjs's github中找到了解决方案

res.writeHead(301, { Location: redirect.to })
res.end()

完成!

关于graphql - 如何使用 Nuxt ServerMiddleware 和 Apollo GraphQL 处理 301 重定向,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58326878/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com