vue+springbootでログイン認証コードを実現

vue+springbootでログイン認証コードを実現

この記事では、ログイン認証コードを実装するためのvue+springbootの具体的なコードを例として紹介します。具体的な内容は以下のとおりです。

まずは効果画像をご覧ください

ログインページに検証コードHTMLを追加する

バックエンドの pom ファイルに kaptcha 依存関係を追加する

<依存関係>
     <groupId>com.github.penggle</groupId>
     <artifactId>キャプチャ</artifactId>
     <バージョン>2.3.2</バージョン>
</依存関係>

KaptchaConfigツールクラスを作成する

パッケージ com.brilliance.module.system.controller.util;
 
com.google.code.kaptcha.impl.DefaultKaptcha をインポートします。
com.google.code.kaptcha.util.Config をインポートします。
org.springframework.context.annotation.Bean をインポートします。
org.springframework.context.annotation.Configuration をインポートします。
 
java.util.Properties をインポートします。
 
@構成
パブリッククラスKaptchaConfig{
    @ビーン
    パブリックDefaultKaptcha getDefaultKaptcha() {
        デフォルトのKaptcha defaultKaptcha = 新しい DefaultKaptcha();
        プロパティ properties = new Properties();
        // 画像の幅 properties.setProperty("kaptcha.image.width", "180");
        // 画像の高さ properties.setProperty("kaptcha.image.height", "50");
        // 画像の境界線のプロパティ。setProperty("kaptcha.border", "yes");
        // 境界線の色 properties.setProperty("kaptcha.border.color", "105,179,90");
        // フォント色のプロパティ。setProperty("kaptcha.textproducer.font.color", "blue");
        // フォントサイズ properties.setProperty("kaptcha.textproducer.font.size", "40");
        //セッションキー
        properties.setProperty("kaptcha.session.key", "コード");
        // 検証コードの長さ properties.setProperty("kaptcha.textproducer.char.length", "4");
        // フォントのプロパティ。setProperty("kaptcha.textproducer.font.names", "Songti、Kaiti、Microsoft YaHei");
        設定 config = new Config(properties);
        defaultKaptcha.setConfig(config);
        defaultKaptcha を返します。
    }
}

コントローラーでは、生成された検証コードは後で検証するために redis に保存されます (redis の設定と依存関係は Baidu で確認できます)

@レストコントローラ
@RequestMapping("/api/user")
@Api(tags = "システムユーザー管理")
パブリッククラスSysUserControllerはAbstractControllerを拡張します{
 オートワイヤード
 プライベート SysUserService sysUserService;
 オートワイヤード
 プライベート DefaultKaptcha defaultKaptcha;
 
 オートワイヤード
 Redisテンプレート redisテンプレート;
 
 @GetMapping("/createImageCode")
 public void createImageCode(HttpServletRequest リクエスト、HttpServletResponse レスポンス) は IOException をスローします {
  response.setHeader("Cache-Control", "no-store, no-cache");
  レスポンス.setContentType("image/jpeg");
  // テキスト検証コードを生成します。String text = defaultKaptcha.createText();
  // 画像検証コードを生成 BufferedImage image = defaultKaptcha.createImage(text);
  // ここでは、redis を使用して検証コードの値をキャッシュし、有効期限を 60 秒に設定します。redisTemplate.opsForValue().set("imageCode",text,60, TimeUnit.SECONDS);
  ServletOutputStream 出力 = response.getOutputStream();
  ImageIO.write(image, "jpg", out);
  出力をフラッシュします。
  out.close();
 }

生成後、認証コードが正しいかどうかを確認するために、ログイン インターフェイスで認証コードを検証する必要があります。

ログインボタンの外側のレイヤーにリクエスト判定を追加し、入力された認証コードが正しいかどうかを確認し、戻り値に基づいてエラーメッセージを表示します。

@PostMapping("/compareCode")
パブリック RESULT compareCode(@RequestBody String 検証コード) {
    if(!redisTemplate.hasKey("imageCode")) {
  return RESULT.error(500,"認証コードの有効期限が切れています");
 }
 文字列コード = redisTemplate.opsForValue().get("imageCode").toString();
 if(StringUtils.equals(検証コード、コード)) {
  RESULT.ok() を返します。
 } それ以外 {
  RESULT.error(500,"認証コードの入力が正しくありません");を返します。
 }
}

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • 検証コードログインメソッドのVue実装例
  • Vueはログイン時にグラフィック検証コードを実装します
  • Vue は携帯電話の認証コードによるログインを実装します
  • vueを使用して登録ページの効果を実現し、vueを使用してSMS認証コードログインを実現します
  • Vueはログイン認証コードを実装する
  • Vue はグラフィック検証コードログインを実装します
  • Vueはログイン時に画像認証コードを実装します
  • Vue は携帯電話番号と確認コードによるログインを実装します (60 秒のカウントダウンは無効)
  • Vueはログインインターフェースの検証コード機能を実装します
  • vue+Element はログイン用のランダム検証コードを実装します

<<:  データベースのデフォルトパスを変更した後にmysqlが起動できない問題の解決策

>>:  Windows 10 システムに mysql-8.0.13 (zip インストール) をインストールする詳細なチュートリアル

推薦する

iframe でページを開く方法

解決:リンクのターゲット属性値をターゲット フレームワーク名と同じに設定するだけです。具体的な手順:...

MySQL InnoDB のロック機構の詳細な説明

前面に書かれたデータベースは本質的に共有リソースであるため、同時アクセスのパフォーマンスを最大化する...

Centos7 での python3 のインストールとアンインストールに関するチュートリアル

1. Python 3をインストールする1. 依存パッケージをインストールしますyum instal...

Vue+ElementUI で超大規模なフォーム例を処理する方法

最近、社内の業務調整により、以前の超長文のロジックが大幅に変更されたため、リファクタリングする予定で...

Vue の DOM の非同期更新の簡単な分析

目次Vue が DOM を非同期更新する原理1 実際の DOM 要素を取得できるのはいつですか? 2...

HTML で選択ドロップダウン ボックスのコンテンツが不完全に表示され、部分的にカバーされる問題の解決策

今日、問題が発生しました。クエリ バーのドロップダウン ボックスの内容が長すぎて、一部が隠れてしまっ...

Linux でテキストから改行文字を削除する方法

復帰文字 ( Ctrl+M ) に不安を感じても心配しないでください。それらを排除する簡単な方法がい...

JavaScript スロットリングとアンチシェイクに関する簡単な説明

目次スロットルと手ぶれ防止コンセプト:違いスロットリングの実装スロットル機能手ぶれ補正の実装手ぶれ防...

WeChatミニプログラムユーザー認証による携帯電話番号の取得(getPhoneNumber)

序文ミニプログラムには、ユーザーを取得するための非常に便利な API があり、getPhoneNum...

WeChatミニプログラムビデオ集中砲火位置ランダム

この記事では、WeChatミニプログラムのビデオ弾幕の位置をランダム化するための具体的なコードを紹介...

hr 水平線スタイルの例コード

コードをコピーコードは次のとおりです。 <hr style="width:490px...

テーブルの幅を固定して、テキストによって幅が変わらないように設定

ページ内のテーブルの幅を width="600px" に設定した後も、幅が固定さ...

インスピレーションを得るための7つのクールなダイナミックウェブサイトデザイン

デザインの分野では、毎年さまざまなデザインのトレンドや流行があります。たとえば、近年のレスポンシブデ...

JavaScriptはXiaomi Mall公式サイトの完全なページ実装プロセスを模倣します

目次1. ホームページ制作1. ダウンロードアプリの制作2. ナビゲーションバーの制作3. カルーセ...