特定の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>