我阅读了hapi.js的正式文档,代码类似于文档,但不可能设置cookie。
const Hapi=require('hapi');
const server = Hapi.server({
host:'localhost',
port:3333
});
server.state('user', {
ttl: 24 * 60 * 60 * 1000, // One day
isSecure: true,
isHttpOnly: true,
encoding: 'base64json',
clearInvalid: false,
strictHeader: true
});
server.route({
method:'POST',
path:'/login',
handler:function(request,h) {
var data = request.payload;
if(data.account === "a" && data.password === "a"){
h.state('user', { account: "shmily" });
console.log(request.state.user); //undefined
return h.response('success');
}else{
return "wrong";
}
}
});
async function start() {
try {
await server.start();
}
catch (err) {
process.exit(1);
}
console.log('服务器开启了3333端口!');
};
start();我想设置曲奇,但它不work.My英语不是很好,我希望每个人都能更宽容。
发布于 2018-04-18 09:55:21
您应该在开发中将isSecure更改为false。当它被设置为真正的cookie时,当没有安全连接(Https)时,就不会设置cookie。
因此,请更改代码,如下所示
server.state('user', {
ttl: 24 * 60 * 60 * 1000, // One day
isSecure: false,
isHttpOnly: true,
encoding: 'base64json',
clearInvalid: false,
strictHeader: true
});https://stackoverflow.com/questions/49652131
复制相似问题