php整型溢出问题
今天在写个程序 发现插入的MYSQL数据和POST的不一致 调试发现是数据转换时发生的错误
比如一个手机号 我想转换为int 这个手机号是任意字符 不是手机号则false 以前都是用intval
比较好用 比如
if(intval('13688017729'))
...然后继续
发现
echo intval('13688017729');这句不等于13688017729了
我的PDO是这样搞的 帮我看下怎么完善下 修改这个BUG
if (array_key_exists($key, $data)) {
if (isset($data[$key])) {
if ($table_column[$key]["d_type"] == "decimal" || $table_column[$key]["d_type"] == "double") {
$newdata[$key] = doubleval($data[$key]);
} elseif ($table_column[$key]["d_type"] == "int" || $table_column[$key]["d_type"] == "smallint" || $table_column[$key]["d_type"] == "tinyint" || $table_column[$key]["d_type"] == "mediumint" || $table_column[$key]["d_type"] == "bigint") {
$newdata[$key] = intval($data[$key]);
} elseif ($table_column[$key]["d_type"] == "float") {
$newdata[$key] = floatval($data[$key]);
} else {
$newdata[$key] = $data[$key];
}
}
}
------解决方案--------------------
不能这样做!手机号码已经超出整型数的表示范围了
要检查他是否全由数字组成可用 is_numeric 函数或正则
------解决方案--------------------
出现错误是因为数据库长度溢出 而不是因为你的类型转换.所以如果想存储手机号的话可以将字段类型修改成bigint
0
0
相关文章
PHP检测视频文件格式的方式_PHP检测视频文件格式教程
实现基于JavaScript可用性的PHP内容动态加载策略
PHP如何根据JavaScript可用性动态加载内容:一种优雅的降级方案
防止异步Fetch POST请求后页面跳转并自动刷新当前页面的教程
基于JavaScript可用性加载不同PHP文件的教程
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
Java Spring Boot 微服务实战
本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。
1
2025.12.24
热门下载
网站特效
/
网站源码
/
网站素材
/
前端模板
精品课程
最新文章









