当前位置:首页 > 文章列表 > 文章 > php教程 > PHP加密入门:基础与常用算法详解

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怎么加密新手入门_从零学PHP加密基础与常用算法认识【教程】

PHP 加密不是“选一个函数套进去就完事”,新手最容易栽在混淆hashencryptencode这三类操作上——比如用base64_encode()当加密,结果数据一解就开;或者拿md5()存密码,却没加盐也没用迭代。

别把哈希当加密:密码存储必须用 password_hash()

哈希(如md5sha1)不可逆,适合验密码,但绝不能直接哈希明文密码。现代 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搭建个人主页教程,无需代码设计
上一篇
Canva搭建个人主页教程,无需代码设计
CSS 实现渐变边框颜色,可以使用 border-image 配合 linear-gradient,具体步骤如下:✅ 1. 基本语法.element {
  border: 2px solid transparent; /* 设置边框为透明 */
  border-image: linear-gradient(方向, 起始颜色, 结束颜色) 1;
}linear-gradient(方向, 颜色1,
下一篇
CSS 实现渐变边框颜色,可以使用 border-image 配合 linear-gradient,具体步骤如下:✅ 1. 基本语法.element { border: 2px solid transparent; /* 设置边框为透明 */ border-image: linear-gradient(方向, 起始颜色, 结束颜色) 1; }linear-gradient(方向, 颜色1,
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    2345次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    2157次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    2114次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    2316次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    2284次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码