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é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ódigo de área válido (sólo números)."/>
<input type="text" name="empresa_tel" class="required digits" value="<?php echo $empresa_txt['empresa_tel']; ?>" title="Debe ingresar un teléfono válido (sólo nú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 usemysql_*
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 mysqli_fetch_assoc 没有返回正确的值