2017-01-05 4 views
0

私は何か似たようなことをしていますが、動作しない部分はif(isset($ _ POST ['submit']))の下でIFです。おもう。 運がないと多くの方法を試してみました... とにかく、私はこの解決策に従いましたhttps://stackoverflow.com/a/21504949/4167976成功なし。

<?php 
session_start(); 
$char = "abcdefghijklmnopqrstuvwxyz1234567890"; 
$code = $char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)]; 
$_SESSION["testcode"] = $code; 
echo $_SESSION["testcode"]."<br>"; // echo here only for testing 

if(isset($_POST['submit'])) { 
    $code1 = mb_substr($_POST['fullcode'], 0, 5); 
    $code2 = mb_substr($_POST['fullcode'], -6); 

    if ($code2 == $_SESSION["testcode"]) 
     {echo "The code is correct!";} 
    else 
     {echo "Wrong code!";} 

    // unset($_SESSION['testcode']); // ??? 
} 

?> 
<!DOCTYPE html> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
</head> 
<body> 

<form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post"> 
<input type="text" name="fullcode"> 
<input type="Submit" name="submit" value="Submit!"> 
</form> 

</body> 
</html> 

は、私の何を私が間違っているを教えてください...ありがとう:

は、ここに私のテストのphpとhtmlです! :)

EDIT:

<?php 
session_start(); 

if (!isset($_SESSION["testcode"])) { 
    $char = "abcdefghijklmnopqrstuvwxyz1234567890"; 
    $code = $char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)]; 
    $_SESSION["testcode"] = $code; 
} 

if(isset($_POST['submit'])) { 
    $code1 = mb_substr($_POST['fullcode'], 0, 5); 
    $code2 = mb_substr($_POST['fullcode'], -6); 

    if ($code2 === $_SESSION["testcode"]) 
     {echo "The code is correct!<br>";} 
    else 
     {echo "Wrong code!<br>";} 

    unset($_SESSION['testcode']); 
    $char = "abcdefghijklmnopqrstuvwxyz1234567890"; 
    $code = $char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)]; 
    $_SESSION["testcode"] = $code; 
} 
?> 

条件がfalseの場合は最後に、新しいコードを入手!

+0

すべての読み込みでテストコードを上書きします( '$ _SESSION [" testcode "] = $ code')。それが提出されたかどうか最初にチェックします。 – chris85

+0

さらに、@ chris85は言った。そのセッションを非表示の入力に割り当てて比較します。別のページも使用する必要があります。 –

+0

隠しテキストフィールドの代わりに$ _SESSIONに値を格納する方が良いでしょうか? – Devilix

答えて

0
<?php 
session_start(); 

// first request. 
// if not set session 'testcode' and set it, else do nothing. 
// prevent session be covered. 
if (!isset($_SESSION["testcode"])) { 
    reFreshCode(); 
} 

if(isset($_POST['submit'])) { 
    $code1 = mb_substr($_POST['fullcode'], 0, 5); 
    $code2 = mb_substr($_POST['fullcode'], -6); 
    if ($code2 == $_SESSION["testcode"]) 
     echo "The code is correct!"; 
    else { 
     // get a new code IF the condition is false! 
     echo "Wrong code!"; 
     echo “new code:”.reFreshCode(); 
    } 
} 

function reFreshCode() { 
    $char = "abcdefghijklmnopqrstuvwxyz1234567890"; 
    $code = $char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)].$char[rand(0,35)]; 
    return $_SESSION["testcode"] = $code; 
} 
+0

正常に動作していますが、コードが間違っていると、別の新しいものが生成されませんか?常に同じものがあります。 – Devilix

+0

1つのクライアントは、セッションを解除するまで1つのセッションIDを生成します。クライアントのステータスを取得することができます。ログインやログアウトのようなものです。 –

+0

と私はどのように私は新しいランダムなコードを取得する設定を解除することはできますか? – Devilix

関連する問題