この記事では、ログイン認証を実装するためのExpressの具体的なコードを例として紹介します。具体的な内容は以下のとおりです。 Express によって実装されたルーティング ログインは、多くのシナリオに適用できます。このコードは、将来の使用のために記録されます。 まずメインファイル: server.js 定数 express = require('express'); 定数static = require('express-static'); bodyParser は、'body-parser' を必要とします。 const multer = require('multer'); // 構成ファイルをアップロードするパス。ここではローカル アドレスです。const multerObj = multer({ dest: './static/upload' }); クッキーパーサーが必要です。 const cookieSession = require('cookie-session'); const 統合 = require('統合'); // サブルート ページを使用する必要があります。インストールされていることを確認してください。const expressRoute = require('express-route'); 定数 mysql = require('mysql'); var server = express(); サーバーを listen (8080); // 送信されたデータとファイルを処理します。server.use(bodyParser.urlencoded()); server.use(multerObj.any()); // クッキーと署名の処理 server.use(cookieParser()); (関数 () { var キー = []; (var i = 0; i < 100000; i++) の場合 { キー[i] = 'secret' + Math.random(); }; server.use(cookieSession({ 名前: 'session_id', キー: キー、 最大年齢: 20 * 60 * 1000 })); })(); // テンプレートのレンダリング server.engine('html', consolidate.ejs); server.set('ビュー', 'テンプレート'); server.set('ビューエンジン', 'html'); // ルート分割 server.use('/', require('./route/web/index.js')()); // フロントエンドルーティング server.use('/admin/', require('./route/admin/index.js')()); // バックエンドルーティング // 静的データ server.use(static('./static/')); 上記は全体的な構造フレームワークです。今後はルーティング部分のみに注目してください。以下はバックグラウンドルーティング部分です。 定数 express = require('express'); モジュール.エクスポート = 関数 () { var ルーター = express.Router(); // ログインする前に router.use((req, res, next) => { req.session['admin_id'] && req.url != '/login' の場合 { res.redirect('/admin/login'); } それ以外 { 次(); } }); router.use('/login', require('./login')()); // 通常のログイン後のその他のルート router.get('/', (req, res) => { res.render('admin/index.ejs', {}); }); // ビジネスに基づいてルーティングを追加します router.use('/banners', require('./banners')()); リターンルーター; }; Express のモジュール性は、実際にはレベルごとにルーティングすることによって定義されます。次に、上記のコード内のログイン コードの実装を見てみましょう。 定数 express = require('express'); // カプセル化されたパブリックメソッド (md5) 暗号化モジュール const common = require('../../libs/common'); 定数 mysql = require('mysql'); var db = mysql.createPool({ ホスト: 'localhost', ユーザー: 'root'、 パスワード: '123456', データベース: 'ブログ' }); モジュール.エクスポート = 関数 () { var ルーター = express.Router(); router.get('/', (req, res) => { res.render('admin/login.ejs', {}); }); router.post('/', (req, res) => { var ユーザー名 = req.body.username; var パスワード = common.md5(req.body.password + common.MD5_SUFFIX); db.query(`SELECT * FROM admin_table WHERE username='${username}'`, (err, data) => { もし(エラー){ // 返されるデータは非常に単純です。実際には、オブジェクトが返されます。res.status(500).send('データベース接続エラー').end(); } それ以外 { データ長が0の場合 res.status(400).send('管理者が存在しません').end(); } それ以外 { if (data[0].password == パスワード) { req.session['admin_id'] = data[0].ID; res.redirect('/admin/'); } それ以外 { res.status(400).send('パスワードが間違っています').end(); } } } }); }); リターンルーター; }; 上記のコードには common モジュールのインポートがあることに気付いたかもしれません。このファイルは主に、md5 暗号化メソッドなどのいくつかの共通メソッドを定義します。 const crypto = require('crypto'); モジュール.エクスポート = { MD5_SUFFIX: 'FDSW$t34tregt5tO&$(#RHuyoyiUYE*&OI$HRLuy87odlfh)', md5: 関数 (str) { var obj = crypto.createHash('md5'); obj.update(文字列); obj.digest('hex') を返します。 } }; 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: Docker クリーニングキラー/Docker オーバーレイ ファイルがディスク領域を大量に占有する
【著者】 Liu Bo: Ctrip テクニカル サポート センターのシニア データベース マネージ...
この記事では、jQueryツリービューツリー構造のアプリケーションコードを例として紹介します。具体的...
この記事では、25 の有名な Web サイト (Google、Yahoo、Twitter、Digg ...
CSS を使用する場合は、DOCTYPE (ドキュメント タイプ定義) を記述することを忘れないでく...
この記事では主に、Vue + SpringBoot でページ分割されたリストデータを実装する方法を紹...
目次クッキーの設定方法クッキーのデメリット: LocalStorage と SessionStora...
目次vue2の場合vue3ではセットアップに関する注意事項セットアップライフサイクルは、before...
データ型: 列に格納できるデータとそのデータが実際にどのように格納されるかを定義する基本ルール。デー...
デフォルトのテンプレートメソッドはvue2に似ており、コンポーネント内のセットアップ関数を使用します...
この質問は、MySQL の権限に関する WeChat グループのネットユーザー間の議論です。次のよう...
Dockerfile の設定に問題はありませんが、ENTRYPOINT コマンドを実行するとエラー...
目次結合構文: 1. InnerJOIN: (内部結合) 2. LeftJOIN: (左結合) 3....
Google Chrome では、ログインに成功すると、パスワードを記憶するかどうかを尋ねるメッセー...
目次1. fill() 構文2. fill() の使用3. まとめ序文:配列の初期化方法についてはよ...
1. インストールパッケージの準備VMware-player-15.0.4-12990004、非商...