PHP加密入门:基础与常用算法详解
2026-05-15 08:02:23
0浏览
收藏
PHP加密开发绝非简单套用函数,而需精准区分哈希(如password_hash用于安全存密)、真加密(如openssl_encrypt配合AES-256-CBC与随机IV)和纯编码(如base64_encode无任何保密性),新手常因混淆三者导致严重安全隐患;本文直击核心误区——禁用md5/sha1存密、淘汰ECB模式、杜绝URL传密钥,并强调工程细节:密钥二进制处理、IV每次重生成、数据库字段足长、OpenSSL兼容性检查,真正守住从密码存储到数据传输的每一道防线。

PHP 加密不是“选一个函数套进去就完事”,新手最容易栽在混淆hash、encrypt、encode这三类操作上——比如用base64_encode()当加密,结果数据一解就开;或者拿md5()存密码,却没加盐也没用迭代。
别把哈希当加密:密码存储必须用 password_hash()
哈希(如md5、sha1)不可逆,适合验密码,但绝不能直接哈希明文密码。现代 PHP(7.2+)唯一推荐的密码哈希方式是password_hash(),它自动选算法、加盐、调迭代次数。
password_hash($password, PASSWORD_ARGON2ID)(PHP 7.3+,安全性最高)password_hash($password, PASSWORD_DEFAULT)(当前默认是 bcrypt,向后兼容)- 绝对不要写
md5($password)或sha1($password . $salt)——盐要随机生成,迭代要足够,这些password_hash()已帮你封好 - 验证时只用
password_verify($input, $hash_from_db),别自己拼盐、比对哈希值
真加密要用 openssl_encrypt(),别碰 mcrypt
mcrypt扩展早在 PHP 7.1 就被移除,现在所有对称加密(如 AES)必须走openssl_encrypt()/openssl_decrypt()。它要求你明确指定算法、模式、IV 和密钥处理方式。
- 推荐组合:
AES-256-CBC(需 32 字节密钥 + 16 字节随机 IV) - 密钥不能是短口令字符串——要用
hash('sha256', $raw_key, true)转成二进制 - IV 必须每次加密都新生成(
random_bytes(16)),且和密文一起保存(通常拼在密文前或单独字段) - 错误示例:
openssl_encrypt($data, 'AES-128-ECB', $key)—— ECB 模式不安全,无 IV,会暴露重复块
base64_encode() 和 urlencode() 不是加密,只是编码
它们只是把二进制数据转成文本表示,毫无保密性。常见误用场景:把加密后的密文再base64_encode(),然后以为“更安全”;或把密钥用urlencode()存进 URL 当参数传。
base64_encode()是为了传输/存储二进制安全,解码只要base64_decode()- 真正加密后的密文(如
openssl_encrypt输出)本就是二进制,必须base64_encode()才能存数据库或传 JSON;但这一步不增加安全性 - 密钥、IV 绝对不能出现在 URL、日志、前端 JS 或 HTML 属性里——哪怕经过
urlencode()
开发时最容易漏掉的三件事
不是算法选错,而是工程细节崩盘:
- 没检查
openssl_encrypt()返回false(比如密钥长度不对、IV 长度错、算法名拼错) - 用
password_hash()生成的 hash 存进数据库字段太短(VARCHAR(255)才够,bcrypt 最长约 60 字符,Argon2 可达 190+) - 本地测试用
localhost跑没问题,上线后因 OpenSSL 版本低或缺少libsodium扩展,PASSWORD_ARGON2ID直接报错
加密不是加个函数就安心了,关键在理解每个函数的边界:它防谁?防什么?失效条件是什么。比如password_hash()防拖库撞库,但防不了中间人窃听登录请求——那得靠 HTTPS。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP加密入门:基础与常用算法详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
Canva搭建个人主页教程,无需代码设计
- 上一篇
- Canva搭建个人主页教程,无需代码设计
- 下一篇
- CSS 实现渐变边框颜色,可以使用 border-image 配合 linear-gradient,具体步骤如下:✅ 1. 基本语法.element { border: 2px solid transparent; /* 设置边框为透明 */ border-image: linear-gradient(方向, 起始颜色, 结束颜色) 1; }linear-gradient(方向, 颜色1,
查看更多
最新文章
-
- 文章 · php教程 | 5分钟前 |
- PHP压缩图片方法|GD库优化图片体积
- 257浏览 收藏
-
- 文章 · php教程 | 17分钟前 |
- PHP快速返回JSON数据的优化方法
- 446浏览 收藏
-
- 文章 · php教程 | 18分钟前 |
- PHP多线程开启方法及配置详解
- 349浏览 收藏
-
- 文章 · php教程 | 26分钟前 |
- PHP数组过滤方法与技巧
- 292浏览 收藏
-
- 文章 · php教程 | 37分钟前 |
- PHP如何查找数组元素【步骤详解】
- 302浏览 收藏
-
- 文章 · php教程 | 49分钟前 |
- PHP加密入门:基础与常用算法详解
- 309浏览 收藏
-
- 文章 · php教程 | 8小时前 | phpenv
- phpEnv下载安装教程及操作指南
- 238浏览 收藏
-
- 文章 · php教程 | 9小时前 | phpenv
- phpEnv修改session.gc_maxlifetime设置方法
- 196浏览 收藏
-
- 文章 · php教程 | 9小时前 | PHP字符串
- PHP随机打乱字符串方法详解
- 425浏览 收藏
-
- 文章 · php教程 | 9小时前 |
- PHP严格模式:declare(strict_types=1)的重要性
- 135浏览 收藏
-
- 文章 · php教程 | 9小时前 |
- PHP三元运算符嵌套报错原因解析
- 122浏览 收藏
-
- 文章 · php教程 | 9小时前 | Xdebug
- Sublime Text 3配置Xdebug调试教程
- 481浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4517次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4870次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4743次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 6602次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 5104次使用
查看更多
相关文章
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

