我正在尝试使用postgres进行快速会话。经过几个小时的调试,我已经解决了所有问题,但只有一个。一切正常但有效:
如果我在pgAdmin中运行此查询,我的会话可以正常工作
CREATE TABLE "sessions" (
"sid" varchar NOT NULL COLLATE "default",
"sess" json NOT NULL,
"expire" timestamp(6) NOT NULL
)
WITH (OIDS=FALSE);
ALTER TABLE "sessions" ADD CONSTRAINT "session_pkey" PRIMARY KEY ("sid")
NOT DEFERRABLE INITIALLY IMMEDIATE;
如果我使用sequelize创建模型,那么它不会保存会话。我很确定,很明显我在模型定义中缺少一些部分,并且会欣赏任何输入。
var Sessions = database.define('sessions', {
sid: {
type: Sequelize.STRING,
primaryKey: true
},
expire: {
type: Sequelize.DATE,
allowNull: true
},
sess: Sequelize.JSON
});
return Sessions;
其余代码使用此
var pgSession = require('connect-pg-simple')(expressSession),
sessionSettings = {
store: new pgSession ({
conString: 'postgres://' + dbConfig.user +':' + dbConfig.password+ '@' + dbConfig.host+ ':5432/' + dbConfig.database,
tableName : 'sessions'
}),
secret: 'whatevergoeshere',
resave: false,
saveUninitialized: false,
cookie: {
maxAge: 7*24*60*60*1000
}
};
app.use(expressSession(sessionSettings));
我不知道如何包含缺失的部分和sequelize文档是要么缩短主题,要么我睡眠不足
其余的代码可以根据要求提供,但非常肯定它不会影响任何内容,因为如果我不强制与sequelize模型同步并使用查询,一切正常。
此外,以下是pgAdmin的外观,顶部一个是在pgAdmin中创建的,底部是由sequelize创建的
答案 0 :(得分:2)
为了使用“connect-session-sequelize”自动生成会话表,需要在SequelizeStore实例上调用sync()方法
var session = require('express-session');
var Sequelize = require('sequelize');
var db = new Sequelize('test', 'root', '****');
var SequelizeStore = require('connect-session-sequelize')(session.Store);
var sessionStore = new SequelizeStore({
db: db,
checkExpirationInterval: 15 * 60 * 1000,
expiration: 7 * 24 * 60 * 60 * 1000
});
app.use(session({
secret: 'keyboard cat',
resave: false, saveUninitialized: false,
store: sessionStore
}));
sessionStore.sync()
答案 1 :(得分:1)
Sequelize默认创建createdAt和updatedAt列,不允许为NULL。通过使用“connect-pt-simple”模块添加行,它会无声地失败,因为它不为这两个字段提供值。 要么自己处理案例并更新这些值,要么在模型中使用属性“allowNull:true”设置这两个值,或者添加默认值。 当然,第一种选择是首选,将来可能会很方便。