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 の起動時に共有ディレクトリを自動的にマウントする最良の方法

推薦する

MySQLデータベースでの値の追加、変更、削除、クリアの例

3. MySQLデータ管理最初の方法:お勧めできません。複雑そうです -- 学生テーブルの grad...

Ubuntu 14 に Nginx-RTMP ストリーミング サーバーをインストールするチュートリアル

1. RTMP RTMP ストリーミング プロトコルは、Adobe が開発したリアルタイムのオーディ...

Linux自動ログイン例の説明

インターネット上には、expect を使用して自動ログインを実現するスクリプトが多数存在しますが、明...

JavaScript で同時実行制御を実装する方法

目次1. 同時実行制御の概要1.1 フェーズ1 1.2 フェーズ2 1.3 フェーズ3 2. 同時実...

Dockerコンテナ間の通信と外部ネットワーク通信の操作

コンテナ間の通信1. コンテナのネットワーク共有このモードの Docker コンテナはネットワーク ...

Vue でのキープアライブコンポーネントの使用例

問題の説明(キープアライブとは何か)キープアライブ 名前の通り、アクティブな状態を維持します。誰が活...

ウェブデザインにおけるインタラクション: ページングの問題に関する簡単な説明

機能: 前のページまたは次のページにジャンプします。要素: ページングの基本要素は、前のページ + ...

CentOS8 ネットワークカード設定ファイル

1. はじめにCentOS8 システムの更新、新しいバージョンは人々に非常に快適に感じさせます。 こ...

純粋な CSS3 でペットの鶏のサンプルコードを実現

最近、CSS3に関する知識や記事をたくさん読んできましたが、CSS3はとても便利に使えると思います。...

HTML/CSS での空白処理とページ内の空白を保持する方法

HTML の空白ルールHTML では、コンテンツ内の複数のスペースは通常 1 つとみなされ、連続する...

CSS の 6 つの重要なセレクター (3 秒で覚える)

出典: https://blog.csdn.net/qq_44761243/article/deta...

MySQL 8.x msi バージョンのインストール チュートリアル (画像とテキスト付き)

1. MySQLをダウンロードする公式サイトのダウンロードアドレス https://dev.mys...

MySQLのMERGEストレージエンジンの詳細な説明

MERGE ストレージ エンジンは、MyISAM テーブルのグループを論理ユニットとして扱い、同時に...

Windows 10 での MySQL 8.0.12 解凍バージョンのインストール グラフィック チュートリアル

この記事は、MySQL 8.0.12解凍版のインストールグラフィックチュートリアルを記録しています。...

MySQL IDは1から増加し始め、不連続IDの問題を素早く解決します

mysql idは1から始まり、不連続なidの問題を解決するために自動的に増加します。強迫性障害の私...