我有一个公司的注册表,有多个字段。除了一个之外的所有工作都很好...后来添加了一个不工作的,它总是存储相同的数字,但我无法弄清楚原因。
我查了一下:
我提交表单的那一刻,$_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字段中的数字保持不变。
你可以帮我解决这个问题吗?我现在不能在这里粘贴所有相关的代码,但是如果你想看到别的东西,请告诉我......
答案 0 :(得分:2)
我唯一想到的是:如果您使用的是32位整数,而您输入的电话号码的评估值大于2147483647,则intval将始终返回2147483647。
我将其更改为将电话号码存储为字符串。
答案 1 :(得分:1)
我认为你在DB int列中,将其更改为varchar,问题将得到解决。
答案 2 :(得分:1)
我在这里继续讨论,而不是在评论中,因为我们可能会做些什么。
所以如果你写$ _POST ['empresa_cuit']你会看到正确的值吗?
价值是多少?可以在那里使任何字符使intval无法解析它 - 在这种情况下intval返回0。