Node.js下express.js+Redis+passport.js實(shí)現(xiàn)登錄認(rèn)證

<form action="/login" method="post">
        <div> <label for="username">Username</label> <input id="username" name="username" type="text"
                        autocomplete="username" required /> </div>
        <div> <label for="current-password">Password</label> <input id="current-password" name="password"
                        type="password" autocomplete="current-password" required /> </div>
        <div> <button type="submit">Sign in</button> </div>
</form>
const express = require("express");
const Redis = require("ioredis");
const session = require("express-session");
const passport = require("passport");
const RedisStore = require("connect-redis")(session);
const LocalStrategy = require("passport-local").Strategy;
const bodyParser = require("body-parser");
const ejs = require("ejs");

const app = express();
app.use(bodyParser.urlencoded());
app.set("views", __dirname + "/views");
app.set("view engine", "ejs");
app.engine("html", ejs.__express);
app.set("view engine", "html");

passport.serializeUser((user, done) => {
  done(null, user.username);
});
passport.deserializeUser(function (username, done) {
  done(null, { username });
});

app.use(
  session({
    name: "ang_server_session",
    secret: "ang test",
    resave: false,
    rolling: true,
    saveUninitialized: false,
    cookie: {
      maxAge: 86400000,
      secure: false,
      httpOnly: true,
      path: "",
      sameSite: "strict",
      domain: "",
    },
    store: new RedisStore({
      client: new Redis({
        host: "114.115.134.189",
        port: 6379,
        db: 10,
        password: "***",
      }),
    }),
  })
);

app.use(passport.initialize());
app.use(passport.session());
passport.use(
  new LocalStrategy(
    { usernameField: "username", passwordField: "password" },
    function (username, password, done) {
      if (username == "ang" && password == "11111") {
        return done(null, { username, password });
      } else {
        return done(null, false, { message: "賬戶或密碼錯(cuò)誤" });
      }
    }
  )
);

app.get("/", function (req, res) {
  if (req.isAuthenticated()) {
    res.send(
      "歡迎您!" + req.session.passport.user + "!" + '<a href="logout">登出</a>'
    );
  } else {
    res.send('您好!游客!<a href="login">請(qǐng)登錄</a>');
  }
});

app.get("/login", function (req, res) {
  res.render("login");
});

app.post(
  "/login",
  passport.authenticate("local", {
    failureRedirect: "/login",
    failureMessage: true,
  }),
  function (req, res) {
    res.redirect("/");
  }
);

app.get("/logout", function (req, res) {
  req.logout();
  res.redirect("/");
});

const server = app.listen(8081, function () {
  const host = server.address().address;
  const port = server.address().port;
  console.log("應(yīng)用實(shí)例戒财,訪問地址為 http://%s:%s", host, port);
});


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市捺弦,隨后出現(xiàn)的幾起案子固翰,更是在濱河造成了極大的恐慌,老刑警劉巖羹呵,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件骂际,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡冈欢,警方通過查閱死者的電腦和手機(jī)歉铝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來凑耻,“玉大人太示,你說我怎么就攤上這事∠愫疲” “怎么了类缤?”我有些...
    開封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)邻吭。 經(jīng)常有香客問我餐弱,道長(zhǎng),這世上最難降的妖魔是什么囱晴? 我笑而不...
    開封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任膏蚓,我火速辦了婚禮,結(jié)果婚禮上畸写,老公的妹妹穿的比我還像新娘驮瞧。我一直安慰自己,他們只是感情好枯芬,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開白布论笔。 她就那樣靜靜地躺著采郎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪狂魔。 梳的紋絲不亂的頭發(fā)上尉剩,一...
    開封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音毅臊,去河邊找鬼理茎。 笑死,一個(gè)胖子當(dāng)著我的面吹牛管嬉,可吹牛的內(nèi)容都是我干的皂林。 我是一名探鬼主播,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼蚯撩,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼础倍!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起胎挎,我...
    開封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤沟启,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后犹菇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體德迹,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年揭芍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胳搞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡称杨,死狀恐怖肌毅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情姑原,我是刑警寧澤悬而,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站锭汛,受9級(jí)特大地震影響笨奠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜店乐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一艰躺、第九天 我趴在偏房一處隱蔽的房頂上張望呻袭。 院中可真熱鬧眨八,春花似錦、人聲如沸左电。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至段誊,卻和暖如春闰蚕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背连舍。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來泰國打工没陡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人索赏。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓盼玄,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親潜腻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子埃儿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容