次のコードがあります。
[...]
// Escape values
$username = $mysqli->real_escape_string($username);
$password = $mysqli->real_escape_string($password);
// Create the SQL string
$sql = "SELECT *
FROM users
WHERE username = '$username' AND password = '$password';";
// Run query
if ($result = $mysqli->query($sql)) {
[...]
さて、私は ChrisB5 というユーザー名を持っています。ChrisB5 は適切なパスワードで正しく検証していますが... chrisb5 は認証に失敗します。私は utf8_unicode_ci を持っているので...データベースは検索時に大文字と小文字を区別しないはずですよね?それが役立つ場合、私のDBタイプはMyISAMです。私は何を間違っていますか?...ありがとう!
編集:
phpmyadmin で次のコードを実行したところ、動作しました... それでも PHP を使用した mysqli は動作しません! これは私には非常に奇妙です...
SELECT *
FROM users
WHERE username
= 'chrisb5'
LIMIT 0 , 30
これにより、ChrisB5 のレコードが返されました。
また、サーバーのデフォルトがlatin1であることもわかりました...しかし、提案されているようにデフォルトをutf8に修正しましたが、まだうまくいきません! 試してみる価値がありました。