0

我也一直在尝试使用 PHP 来验证我的表单。该表单要求用户输入详细信息,一旦表单被验证,这些详细信息将被输入到数据库中的表中。我在表单中有一个名字字段,我正在尝试验证它以确保它输入了一个值(必填字段)并且应该只包含字母字符或连字符(-)字符。

这是我到目前为止所拥有的:

<?php
if (isset($_POST["submit"])) {

$flag = false;
$badchar = "";
$string = $_POST["fname"];
$string = trim($string);
$length = strlen($string);
$strmsg = "";

if ($length == 0) {
$strmsg = '<span class="error"> Please enter your first name</span>';
$flag = true;}
else {
for ($i=0; $i<$length;$i++){
    $c = strtolower(substr($string, $i, 1));
    if (strpos("abcdefghijklmnopqrstuvwxyz-", $c) == false){
        $badchar .=$c;
        $flag = true;
    }
}
if ($flag) {
    $strmsg = '<span class="error"> The field contained the following invalid characters: $badchar</span>';}
}
if (!$flag) {
    $strmsg = '<span class="error"> Correct!</span>';}
}
?>

<h1>Customer Information Collection <br /></h1>

<form method="POST" action="<?php echo $_SERVER["PHP_SELF"];?>" id="custinfo" >
<table>
<tr>
    <td><label for="custid">Customer ID (integer value): </label></td>
    <td><input type="text" id="custid" name="custid" value="<?php echo $temp ?>" size=11 /><?php echo $msg; ?></td>
</tr>

<tr>
    <td><label for="customerfname">Customer First Name: </label></td>
    <td><input type="text" id="fname" name="fname" size=50/><?php echo $strmsg; ?></td>
</tr>

我遇到的问题是,当我输入正确的字符串(例如 John)时,它仍然给我错误“该字段包含以下无效字符:$badchar”,而且当输入不正确的字符时,我希望它显示错误消息中 $badchar 的位置不正确的字符,但它只显示“该字段包含以下无效字符:$badchar”。有没有办法做到这一点?

对于这些问题的任何帮助将不胜感激。

4

2 回答 2

1

您的问题是您已经完成== false并且strpos可以返回 0 (第一个字符的索引),其评估为false. == false与which交换=== false检查该值是否为布尔值 false,而不是评估为 false 的值。请参阅http://php.net/manual/en/function.strpos.php上的“返回值”部分

要打印 $badchar 的值,请将行更改为

$strmsg = '<span class="error"> The field contained the following invalid characters: '.$badchar.'</span>';

这会将变量连接到您的字符串中

于 2013-05-03T16:32:00.563 回答
0

您的代码有一些问题。

strpos()返回文本中搜索字符串位置的基于 0 的索引,或者返回false. 您需要使用===运算符来检查结果;否则,0结果将被解释为错误。

在您的错误字符串中,您看到:
该字段包含以下无效字符:$badchar

在 php 中,变量只在双引号字符串中解析出来。由于您使用的是单引号,它只会回显您输入的实际文本,而不是变量的内容。您可以切换字符串中的双引号和单引号来修复它。

于 2013-05-03T16:34:45.043 回答