質問 最近、SSH フレームワークを使用して実用的なプロジェクトを完了していたときに、長い間悩まされていた不可解なバグに遭遇しました。最終的にそれを解決し、次のように記録しました。
…EXM? ? ?これでいいですか?さて、このバグの原因を突き止めたほうがいいでしょう。その後、さまざまなトラブルシューティング手順を実行しましたが、問題は見つかりませんでした。最後に、HQL の代わりにデータベースを直接クエリする SQL ステートメントを記述することを考えましたが、問題が見つかりました。 ユーザー名 = 'admin'、パスワード = 'admin' の場合、ユーザーから * を選択します。 ユーザー名 = 'Admin'、パスワード = 'admin' の場合、ユーザーから * を選択します。 上記の 2 つの SQL ステートメントを使用してテーブルを個別にクエリすると、結果は驚くほど同じになります。 ……! !検索エンジンにアクセスして、キーワード「MySQL クエリ ケース」を検索すると、問題が見つかります。 MySQL クエリでは大文字と小文字は区別されません。これは本当にショックでした。キーワードは一般的に大文字と小文字が区別されないことは知っていましたが、クエリされるパラメータでも大文字と小文字が区別されないとは思いませんでした。 !次の SQL ステートメントをもう一度試しても、結果は同じです。 ユーザー名 = 'ADMIN'、パスワード = 'admin' の場合、ユーザーから * を選択します。 解決 インターネットで関連記事を探しましたが、よく書かれていました。ここに記事の説明を貼り付けます。 Mysql のデフォルトの文字検索戦略は、utf8_general_ci (大文字と小文字を区別しない)、utf8_general_cs (大文字と小文字を区別する)、utf8_bin (大文字と小文字を区別するバイナリ比較) です。 (注意: MySQL 5.6.10 では、utf8_genral_cs はサポートされていません!!! ! ! ) テーブルを作成するときは、テーブルの collate プロパティを utf8_general_cs または utf8_bin に直接設定します。テーブルがすでに作成されている場合は、フィールドの Collation プロパティを utf8_general_cs または utf8_bin に直接変更します。 -- テーブルを作成します: テーブルtesttを作成します( id INT 主キー、 名前 VARCHAR(32) NOT NULL )ENGINE = INNODB COLLATE = utf8_bin; -- テーブル構造の照合プロパティを変更します。ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL; SQL ステートメントを変更し、クエリするフィールドの前に -- 各条件の前に binary キーワードを追加します。select * from user where binary username = 'admin' and binary password = 'admin'; -- パラメータを binary('') で囲みます。select * from user where username like binary('admin') and password like binary('admin');
要約する 以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。 以下もご興味があるかもしれません:
|
<<: Ubuntu 16.04にJenkinsをインストールするための詳細な手順
>>: オンラインチャットを実現するVue+sshフレームワーク
Web プロジェクトを開発する場合、IIS をインストールする必要があります。IIS がインストール...
MySQLに何がインストールされているか確認する rpm -qa | grep -i mysql n...
序文MySQL の権限を簡単に理解すると、MySQL では自分の能力の範囲内で操作が許可され、その限...
この本「グラフィックデザイナーとして成長する」は多くの人が読んでおり、私もオリジナルの PDF 版を...
理由はインストール後にきちんとアンインストールされなかったためです。この問題を解決するには、次の点に...
目次1. 4つのコンセプト1. JavaScriptはシングルスレッドです2. タスクキュー3. 同...
目次1. JavaScriptで配列を作成する方法2. 配列メソッドの概要3. 方法の詳細な説明1....
この記事の例では、日付と時刻の選択を実装するための uniapp の具体的なコードを参考までに共有し...
コードは次のようになります。 <!DOCTYPE html> <html> ...
2011 年に最も顕著なウェブサイトの変更は、一連の製品に新しいユーザー インターフェースを導入した...
目次序文配列.isArrayコンストラクタインスタンスプロトタイプオブジェクト.プロトタイプ.toS...
docker リポジトリ自体は非常に遅いですが、中国の Alibaba Cloud ミラー リポジト...
ページに複数の画像を導入すると、画像のサイズがばらつくことがあります。しかし、それらを一貫したサイズ...
異なるブラウザ間でページの表示を一致させるためには、フロントエンド開発において CSS スタイルのク...
1. リテラルとローカル変数へのアクセスは最も高速ですが、配列要素とオブジェクト メンバーへのアクセ...