如何解决Express-session 不使用 Apollo 客户端在 Next.js 应用程序中设置 cookie
我有这个带有 Apollo 客户端的 Next.js,并尝试使用 express-sesssion
进行身份验证。
这是 cors
和 session
的配置:
...
const app = express()
if (isProduction) app.set('trust proxy',1) // trust first proxy
app.use(cors({
origin: true,credentials: true,}))
const RedisStore = connectRedis(session)
app.use(session({
store: new RedisStore({client: redis}),secret: 'foobar',resave: false,saveUninitialized: true,cookie: {
maxAge: +COOKIE_MAX_AGE,httpOnly: true,secure: isProduction,},}))
...
它确实在 Postman 中设置了 cookie,但它没有在 Next.js 应用程序中设置任何 cookie(用铬测试)。
这是 Next.js 中的 apolloClient
配置:
...
function createApolloClient() {
return new ApolloClient({
ssrMode: typeof window === 'undefined',link: new HttpLink({
uri: 'http://localhost:8000/graphql',// Server URL (must be absolute)
// credentials: 'include',// Additional fetch() options like `credentials` or `headers`. Default is `same-origin`
}),cache: new InMemoryCache(),})
}
...
Apollo 说如果正面和背面不是同一个站点,我应该设置 credentials: 'include'
。但是如果我设置它,它会抛出 Unhandled Runtime Error Error: Failed to fetch
。
我做错了什么?
堆栈:apollo-server-express、express、express-session、connect-redis、ioredis、next.js、@apollo/client
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。