0

0

PHP如何将整型转换为十六进制 PHP数字转hex字符串【分享】

尼克

尼克

发布时间:2026-03-11 21:32:02

|

961人浏览过

|

来源于php中文网

原创

dechex()最快但仅支持非负整数;sprintf()更灵活可格式化、支持负数补码(不跨平台);超大整数需gmp_strval()或bcmod();注意大小写、前缀、二进制存储及输入校验。

php如何将整型转换为十六进制 php数字转hex字符串【分享】

dechex() 最快,但只支持非负整数

PHP 里最直接的整型转十六进制字符串方法就是 dechex(),它把十进制整数转成小写、无前缀的 hex 字符串。比如 dechex(255) 返回 "ff"

注意它不处理负数:传入 -1 会返回 "0"(不是补码表示),也不接受浮点数——传 3.14 会被截断为 3,然后转成 "3"

  • 只适用于 0 到 PHP_INT_MAX 范围内的整数(32 位系统上限约 21 亿,64 位约 9×10¹⁸)
  • 结果不含 "0x" 前缀,也不补零;需要大写可用 strtoupper(dechex($n))
  • 性能极好,底层 C 实现,比格式化函数快一个数量级

要带前缀、补零或处理负数?用 sprintf()

当需要控制输出格式(比如固定 8 位、加 "0x"、支持负数补码语义),sprintf() 更灵活。它本质是格式化输出,"%x" 对应小写 hex,"%X" 对应大写,"%08x" 表示至少 8 位、不足左补零。

对负数,sprintf("%x", -1) 在大多数系统上会按补码解释(例如 64 位 Linux 返回 "ffffffffffffffff"),但这依赖平台和编译器,**不可跨平台保证**。

立即学习PHP免费学习笔记(深入)”;

一帧秒创
一帧秒创

基于秒创AIGC引擎的AI内容生成平台,图文转视频,无需剪辑,一键成片,零门槛创作视频。

下载
  • sprintf("%04x", 255)"00ff"sprintf("0x%02X", 10)"0x0A"
  • 传入浮点数会自动截断(不是四舍五入),sprintf("%x", 3.9)"3"
  • dechex() 略慢,但差异在纳秒级,日常完全可忽略

超大整数(> PHP_INT_MAX)必须用 gmp_strval()bcmod() 手动拆解

PHP 的整型有平台限制,一旦数字超过 PHP_INT_MAX(比如 100! 或某些哈希值),原生函数会静默转成 float,精度丢失,dechex()sprintf() 都不可靠。

这时得用任意精度扩展:启用 GMP 后,gmp_strval($gmp_num, 16) 是最稳的方案;没 GMP 就只能靠 bcmod() + 循环取余模拟,代码更长、速度更慢。

  • gmp_strval(gmp_init("123456789012345678901234567890"), 16) 安全返回完整 hex
  • 别试图用 (string)$bigInt 再喂给 dechex() —— 字符串转整型时已溢出
  • Web 环境中未启用 GMP 时,这个坑非常隐蔽:看起来有输出,但末几位全是错的

常见错误:混淆字符串和数值、忽略大小写与前缀需求

很多人卡在“为什么我存进数据库的 hex 查出来不对”,其实问题不在转换函数,而在后续使用环节。

比如用 dechex() 得到 "ff",直接拼 SQL:"WHERE hash = '$hex'",如果字段是 BINARY 类型,就得确保传的是 "\xff" 而不是字符串 "ff";又或者前端期望大写 "FF",后端却返回小写,导致校验失败。

  • hex 字符串比较时注意大小写:MySQL 的 HEX() 默认大写,PHP dechex() 小写,混用会匹配不上
  • 存二进制数据别用 hex 字符串代替 pack("H*", $hex),否则占三倍空间
  • 从 URL 或表单拿到的 hex 字符串(如 "a1b2c3"),别漏掉验证是否全为 [0-9a-fA-F],否则 hexdec() 可能返回 0
事情说清了就结束。真正麻烦的从来不是怎么转,而是转完之后——在哪用、怎么比、边界怎么守。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1663

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Swoft2.x速学之http api篇课程
Swoft2.x速学之http api篇课程

共16课时 | 1万人学习

php初学者入门课程
php初学者入门课程

共10课时 | 0.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号