ホームページ >バックエンド開発 >PHPチュートリアル >PHPが2回入力されたパスワードが一致していることを確認するときに「0」を処理するにはどうすればよいですか?

PHPが2回入力されたパスワードが一致していることを確認するときに「0」を処理するにはどうすればよいですか?

WBOY
WBOYオリジナル
2016-06-13 13:45:061966ブラウズ

PHP が 2 回入力されたパスワードが一致していることを確認するときに「0」に対処するにはどうすればよいですか?
質問したいのですが、「00000 の場合」という奇妙な問題が発生しました。初めて「000」が入力された場合、プログラムはそれが一貫しているとみなします。つまり、ユーザーが入力したパスワードがすべて 0 の場合、0 がいくつあっても関係ありません。そうです、それは通ります。

コード:

// 管理者変数を定義します。送信された場合は、送信された値になります。それ以外の場合は、デフォルトで admin
$admname = (isset($_POST['admname'] ) ) ? トリム($_POST['admname']) : '管理者';

if (isset($_POST['submitted']))
{
$admpass1 = (isset( $ _POST['admpass1'])) トリム($_POST['admpass1']) : '';
$admpass2 = (isset($_POST['admpass2'])) ? ' ]) : '';

if ($admname !='' && $admpass1 !='' && ($admpass1 == $admpass2))
{
…… ……

-----解決策---------
試してください ===
------解決策------------------
md5の暗号化結果を比較します。
------解決策---------
数値を比較して換算すればいいだけかも明示的に文字列型を確認する
------解決策---------

話し合う

ご返信ありがとうございます! === を使用すると解決します。

これは単なる文字列比較ですが、なぜデータ型を制限する必要があるのでしょうか?どちらも文字列です。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。