express 아래 session 에 관 한 몇 가지 주의사항
module
을 거의 찾 을 수 있 습 니 다.express-session
는 express
WEB 프레임 워 크 에서 자주 사용 하 는 session
관리 패키지 입 니 다.주로 다음 과 같은 몇 가지 설정 옵션 이 있 습 니 다.1. 세 션 병행 문제
resave
옵션 이 true
로 설정 되 어 있 으 면 실제 운용 장면 에 동시 요청 이 있 고 의존 session
하 는 경우 주의해 야 합 니 다.문 제 는 요청 한 데 이 터 를 다른 요청 으로 덮어 쓸 수 있 기 때문이다.일부 병렬 서버 에 대해 서 는 이 옵션 을 false
로 설정 해 야 합 니 다.물론 정보 커버 문 제 는 해결 할 수 밖 에 없다.session
데이터 일치 성 문 제 를 잘 해결 하지 못 합 니 다. 예 를 들 어 사용자 가 먼저 업데이트 session
요청 을 보 냅 니 다. 이 요청 은 다른 서버 의 응답 에 의존 하고 후속 적 인 다른 요청 은 최신 session
정보 에 의존 합 니 다. 그렇지 않 으 면 잘못된 응답 을 해 야 합 니 다.이 럴 때 우 리 는 수 동 으로 업데이트 session
의 정 보 를 업데이트 session
정보 에 의존 하 는 병행 요청 을 직렬 화해 야 한다. Promise.resolve()
.then(function() {
req.session.user.gameKey = null;
req.session.user.companyId = null;
return syncUserSession(req);
})
.then(function() {
//....
});
function updateUserInfo(user) {
return new Promise(function(resolve, reject) {
user.gameKey = gameKey;
user.companyId = user.companyIdSrc;
user.save(function() {
req.session.user = user;
});
});
}
2. 중간 부품 을 합 리 적 으로 조합 하 는 순서
session
몇 개의 기본 미들웨어 로 서 매번 요청 할 때마다 생 성 대상, 메모리 배분, 데이터 저장 등 일련의 작업 이 있 습 니 다.실제로 서버 의 일부 자원 응답 은 사용 되 지 않 았 다 express-session
.그래서 우 리 는 그것 을 앞 당 길 수 있다.물론 사용 되 지 않 은 사용자 미들웨어 를 앞 당 길 수도 있다.//
app.use('/public', express.static(staticDir));
app.use(require('cookie-parser')(config.session_secret));
app.use(session({
secret: config.session_secret,
store: new RedisStore({
port: config.redis_port,
host: config.redis_host
}),
resave: false,
saveUninitialized: true
}));
session
모듈 분석 session
데 이 터 를 분석 한 다음 에 cookie-parser
모듈 은 cookie
에 따라 세 션 데 이 터 를 관리 해 야 한다.정적 자원 서 비 스 를 불필요 한 조작 을 미리 피하 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JWT로 세션을 관리하지 마십시오.세상에는 JWT(JOSE/JWS/JWE)로 세션 관리를 해서는 안 된다는 기사가 2017년부터 산 정도 있는데 왠지 JWT에서 세션 관리를 하려고 하는 사람이 있다. 번역 기사이거나 암호의 설명이 너무 길거나 해서,...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.