Vue+Spring Bootで検証コード機能を実現

Vue+Spring Bootで検証コード機能を実現

この記事では、検証コード機能を実装するためのvue+spring bootの具体的なコードを例として紹介します。具体的な内容は以下のとおりです。

試してみるために、vue を使用して検証コードを作成しました。次のようになります。

1.imgタグ

<画像
     = "高さ:40px; 幅: 100px; カーソル: ポインター;"
     ref="画像識別コード"
     :src="選択したロゴ画像.imgUrl"
     クラス="logoImg"
 >

2.jsコード

/**
     * 認証コードを取得 */
    識別コードを取得する() {
      selft = this とします。
      //pic = this.$refs.imgIdentifyingCode とします
      自己t.loadingChack = true;
      uuid = Utils.getUuid(32, 16); とします。
      this.$store.state.uuid = uuid;
      this.$api.reader.getVerify() を実行します。
        { レスポンスタイプ: "arraybuffer", uuid: uuid },
        r => {
          selft.loadingChack = false;
          selft.selectedLogoPicture.imgUrl = "data:image/png;base64," + r;
        }
      );
    },

3.コントローラー

@RequestMapping("/getVerify")
 public void getVerify(@RequestParam String uuid、HttpServletRequest リクエスト、HttpServletResponse レスポンス) {
  response.setContentType("image/jpeg"); // 出力コンテンツが画像であることをブラウザに伝えるためにレスポンス タイプを設定します。 response.setHeader("Pragma", "No-cache"); // レスポンス ヘッダー情報を設定し、このコンテンツをキャッシュしないようにブラウザに伝えます。 response.setHeader("Cache-Control", "no-cache");
  response.setDateHeader("有効期限", 0);
  userService.getRandcodedDawTransparent(uuid, request, response); // 検証コード画像出力メソッド}

4.サービス

@オーバーライド
 パブリック void getRandcodedDawTransparent(String uuid, HttpServletRequest リクエスト, HttpServletResponse レスポンス) {
  試す {
   マップ<String, Object> map = CodeUtil.getRandcodedDawTransparent();
   //生成されたランダム文字列をセッションに保存します。log.info("==saved uuid:"+uuid);
   log.info("==保存されたコード:"+map.get("code"));
   sessionUtil.saveCode(uuid、map.get("コード"));

   レスポンスのContentTypeを"image/png"に設定します。
   出力ストリーム out = response.getOutputStream();

   out.write((byte[]) map.get("img"));
   出力をフラッシュします。
   out.close();
  } キャッチ (IOException e) {
   ログエラー(e.getMessage());
  }
 }

5.ユーティリティ

パブリック静的Map<String, Object> getRandcodedDawTransparent() はIOExceptionをスローします {
  Map<String, Object> rsMap = 新しい HashMap<>();
  // BufferedImage オブジェクトを作成します。 BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
  // Graphics2D を取得
  Graphics2D g2d = image.createGraphics();

  // 背景を透明にするには次のコードを追加します image = g2d.getDeviceConfiguration().createcompatibleImage(width, height, Transparency.TRANSLUCENT);
  g2d.dispose();
  g2d = image.createGraphics();

  g2d.setFont(new Font("Times New Roman", Font.ROMAN_BASELINE, 18));// フォントサイズ g2d.setColor(getRandColor(110, 133));// フォント色 // 干渉線を描画 for (int i = 0; i <= lineSize; i++) {
   drowLine(g2d, 幅, 高さ);
  }
  // ランダムな文字を描画します String randomString = "";
  (int i = 1; i <= stringNum; i++) の場合 {
   ランダム文字列 = drowString(g2d, ランダム文字列, i);
  }
  log.info(ランダム文字列);
  rsMap.put("コード", ランダム文字列);
  g2d.dispose();
  ByteArrayOutputStream baos = new ByteArrayOutputStream(); // io ストリーム ImageIO.write(image, "png", baos); // ストリームに書き込む byte[] bytes = baos.toByteArray(); // バイトに変換する bytes = Base64.encodeBase64(bytes);
  rsMap.put("img", バイト);

  rsMapを返します。
 }

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

以下もご興味があるかもしれません:
  • グラフィック検証コードSMS送信機能付きVueコンポーネント開発LeanCloud

<<:  UbuntuでMySQLデータベースファイルディレクトリを変更する方法

>>:  Virtualbox で Ubuntu 16.04 の起動時に共有ディレクトリを自動的にマウントする最良の方法

推薦する

Javascriptの基本ループの詳しい説明

目次サイクルのために入室のためのその間しながら行うループから抜け出す要約するサイクルのためにループは...

DockerにFastDFSをインストールする方法

画像をプルする docker pull season/fastdfs:1.2トラッカーを開始 doc...

JavaScript で矢印関数を使用できないシナリオはどれですか

目次1. オブジェクトメソッドを定義する2. プロトタイプメソッドを定義する3. イベントコールバッ...

Tomcat でサーブレット URL パターンを構成する際の問題の詳細な説明

tomcat の web.xml を構成する場合、サーブレットは比較的重要な問題です。ここでは、サー...

CentOS 7 パスワードを忘れた場合の解決プロセス図

必要Windows システムでも Linux システムでも、さまざまな理由でパスワードを忘れてしまう...

MySQL 8.0.11 のインストールと設定方法のグラフィックチュートリアル

MySQL 8.0のインストールと設定方法は参考までに。具体的な内容は以下のとおりです。ダウンロード...

WeChatアプレットがシンプルな計算機機能を実装

WeChatアプレット:シンプルな計算機、参考までに、具体的な内容は次のとおりです。ミニプログラムに...

MySql 8.0 と対応するドライバー パッケージの一致に関する注意事項

MySql 8.0 対応ドライバパッケージのマッチングMySql データベースをバージョン 8.0 ...

HTML タグ マーキーを使用してスクロール効果を実現する簡単な方法 (必読)

ページの自動スクロール効果は JavaScript で実現できますが、今日偶然、JS 制御なしでさま...

Xftp のダウンロードとインストールのチュートリアル (グラフィック チュートリアル)

Windows と Linux 間でファイルを転送する場合は、Xftp ツールを使用できます。この...

開発効率を向上させる 20 の JavaScript ヒント

目次1. 配列を宣言して初期化する2. 合計、最小値、最大値を計算する3. 文字列、数値、オブジェク...

CentOs でノード バージョンを手動でアップグレードする方法

1. 対応するNode.jsパッケージを見つけます。https://nodejs.org/downl...

MySQL で B+ ツリー インデックスを使用する利点は何ですか?

この問題を理解する前に、まず MySQL テーブルのストレージ構造を確認し、次にバイナリ ツリー、マ...

Linuxでサーバーのハードウェア情報を表示する方法

みなさんこんにちは。今日は12連休ですが、何かお買い物はしましたか?今日は「Linux View S...

アダプティブ Web デザインの手法 (モバイル フォンでの優れたアクセス エクスペリエンス)

1. HTML ヘッダーにビューポート タグを追加します。ウェブサイトの HTML ファイルの先頭...