1

特定のPHPアドレスに送信すると正常に機能する単純なJavascript検証コードがありますが、作成したPHPページに送信すると機能しません。

コードは現時点では非常に基本的なもので、正規表現を使用していくつかのフィールドを検証します。

基本的に、既製の PHP ファイル (アクセスできません) で試してみると、すべてのフィールドが正しくなるまでエラー ダイアログ ボックスが表示されて正常に動作します。

一方、私が作成したPHPページでは、エラーをキャッチしてダイアログボックスを表示しますが、OKアラートボックスをクリックすると、フィールドがPHPファイルに送信されます。

何が起こっているのか、誰かが私に手がかりを与えることができますか?

ありがとうございました。

これはJavascriptです:

<script type="text/javascript">
  /* <![CDATA[ */
  // this function calls all the other functions that validate each field of the submitting form
  function validate() {
    var validated = false;
    validated = validateRId() && validateEId();
    return validated;
  }
  // this validates the RID: checking that the field is filled with a number between 1    //and 99999
  function validateRId() {
    var RIdElement =  document.getElementById("RID");
    patternRId = /^([1-9][0-9]{0,4})$/;
    if (patternRId.test(RIdElement.value)) {
      return true;
    } else {
      alert ("Please Enter your RID (a number range 1 to 99999))");
      RIdElement.focus();
      return false
    }
  }
  // this validates the EventID: checking that the field is filled with a number between 1 and 99999
  function validateEId() {
    var EIdElement =  document.getElementById("EID");
    patternEId = /^([1-9][0-9]{0,4})$/;
    if (patternEId.test(EIdElement.value)) {
      return true;
    } else {
      alert ("Please Enter the EID (a number range 1 to 99999))");
      EIdElement.focus();
      return false
    }
  }
  /* ]]> */
</script>
<p/>
  <form action="http://adress.php" method="post" name="submitrunnertime"  onsubmit = "return validate()">
    <table>
      <tr><td>Runner ID*</td>
        <td><input type="text" name="RID" id="RID" size="5" maxlength="5"/></td>
      </tr>
      <tr><td>Event ID*</td>
        <td><input type="text" name="EID" id="EID" size="5" maxlength="5"/></td>
      </tr>
    </table>
    <input type="submit" name="submit" value="submit"/>
    <hr/>
  </form>
</body>
</html>

これはPHPです:

<body>
<?php
  // access details as variables
  $username = "xxxx";
  $password = "tttt";
  $hostname = "rrrrr";
  //connection
  $connection = mysql_connect($hostname, $username, $password) or die ('connection problem:' . mysql_error());
  echo $connection . "CONNECTION SUCCEDED<br><br><br>";
  //select a database
  $mydb = mysql_select_db("xxxx", $connection)or die ('db problem:' . mysql_error());
  echo $mydb . " DB SELECTED <br><br><br>";
?>
</body>
</html>
4

1 に答える 1