PHP 发布的值之一不正确

Posted

技术标签:

【中文标题】PHP 发布的值之一不正确【英文标题】:One of the PHP posted values is not right 【发布时间】:2013-10-14 02:08:54 【问题描述】:

我有一个包含多个字段的公司注册表单。除了一个都可以正常工作...不工作的那个是后来添加的,它总是存储相同的数字,但我不知道为什么。

我已经检查过:

mysql 数据库中的默认值:没有。 从控制台用JS拉取输入的值:是正确的字段名,拉取正确的值 已验证只有一个具有该名称的字段:很好。 寻找存储在许多包含文件中的数字:我找不到。

在我提交表单的那一刻,$_POST["empresa_cuit "] 总是带有相同的数字,这与我在输入字段中输入的内容无关。

这是我的一些代码:

这两个功能是:

function defaultForm() 
        global $url, $url_prefix, $user_prefix;
        global $root;
        global $selected;
        global $id;
        $empresa = get_empresa($id);
        $empresa_txt = mysql_fetch_array($empresa);
    ?>
        <form method="post" enctype="multipart/form-data" id='update_datos'>
            <h2>Empresa <?php echo $empresa_txt['empresa']; ?></h2>
            <div class="clearfix">
                <label for="empresa">Nombre de la empresa</label>
                <div class="input">
                     <input type="text" name="empresa" value="<?php echo $empresa_txt['empresa']; ?>" class="required" title="Este campo es obligatorio."/>      
                </div>
            </div>
            <div class="clearfix">
                <label for="empresa_cuit">CUIT</label>
                <div class="input">
                    <input type="text" name="empresa_cuit" id="empresa_cuit" class="required digits"  minlength="11" maxlength="11" title="Ingrese los 11 dígitos del CUIT, sin guiones." value="<?php //echo $empresa_txt['empresa_cuit'];?>"/>
                    <br  /><span class="aclaracion">Ingrese sólo números.</span>
                </div>
            </div>

            <div class="clearfix">
                <label for="empresa_tel">Tel&eacute;fono</label>
                <div class="input">
                    <input type="text" name="empresa_cod_tel" id="empresa_cod_tel" maxlength="6" size="6" class="required digits areacode" value="<?php echo $empresa_txt['empresa_cod_tel']; ?>"  title="Debe ingresar un c&oacute;digo de &aacute;rea v&aacute;lido (s&oacute;lo n&uacute;meros)."/>
                    <input type="text" name="empresa_tel" class="required digits"  value="<?php echo $empresa_txt['empresa_tel']; ?>" title="Debe ingresar un tel&eacute;fono v&aacute;lido (s&oacute;lo n&uacute;meros)."/>
                </div>
            </div>

            <input name="Submit" type="submit" value="Actualizar" class='white button'/>
            <input name="filter" type="hidden" value="processForm">
            <!-- hidden value points the switch to processing -->
        </form>

    <?php return;  #/ End of defaultForm ?>

-

function processForm()  
    echo $empresa_cuit = intval($_POST['empresa_cuit']);

...

我已将此行移至最顶部,以便立即监控该值。此后,该功能的其余部分无关紧要,它总是显示相同的数字!该号码是电话号码格式,所以我认为它可能与电话字段(empresa_cod_tel 和 empresa_tel)有关,但不管我在那里输入什么,CUIT 字段中的号码保持不变。

你能帮我解决这个问题吗?我现在不能在这里粘贴所有相关的代码,但是如果您想查看其他内容,请告诉我...

【问题讨论】:

你的mysql表中的字段是什么数据类型,表中存储了什么数字? 同意以上观点。您必须超出数据类型的最大限制。尝试将其更改为接受更高值的数据类型。 Please, don't use mysql_* functions in new code。它们不再维护and are officially deprecated。看到red box?改为了解prepared statements,并使用PDO 或MySQLi - this article 将帮助您决定哪个。如果你选择 PDO,here is a good tutorial. 如果在表单发布时写一个 print_r($_POST),你会看到什么?你能在那里看到正确的值吗? 它是一个长度为20的int,用于存储一个11位数字。我不认为这是它...... 【参考方案1】:

我唯一的想法是:如果您使用 32 位整数并且您输入的电话号码的计算结果大于 2147483647,则 intval 将始终返回 2147483647。

我会将其更改为将电话号码存储为字符串。

【讨论】:

就是这样!我从没想过提到数字会有所帮助,但它正是那个,现在我已经将类型更改为字符串,它工作正常。谢谢!!【参考方案2】:

我认为你有在 DB int 列,将其更改为 varchar,问题将得到解决。

【讨论】:

【参考方案3】:

我在这里继续讨论,而不是在 cmets 中继续讨论,因为我们可能会做一些事情。

所以如果你写 $_POST['empresa_cuit'] 你应该看到正确的值?

价值是什么?那里是否有任何字符导致 intval 无法解析它 - 在这种情况下 intval 返回 0。

【讨论】:

以上是关于PHP 发布的值之一不正确的主要内容,如果未能解决你的问题,请参考以下文章

PHP:分配后的值不正确

SQL 查询为 PHP 中的 ID 列返回不正确的值

PHP mysqli_fetch_assoc 没有返回正确的值

Razorflow Php 错误:遇到格式不正确的数值

MySQL 高分 - 用户的个人排名:重复的条目导致不正确的值

PHP获取多个同名复选框的值的处理(完整正确版本)