我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解PHP的Sodium加密扩展函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解PHP的Sodium加密扩展函数

Sodium 扩展在 PHP7.2 后是跟随 PHP 源码一起发布的,只需要在编译的时候加上 --with-sodium 即可安装成功。如果是 PHP7.2 之前的版本,需要单独安装这个扩展。同时,操作系统中也需要安装 libsodium-devel 库。

AEAD_AES_256_GCM 加解密

首先是这个 AEAD_AES_256_GCM 加解密能力函数的应用。在微信支付相关的开发中,有一个接口就是使用的这种方式进行数据加密,在官方文档中,也提供了 PHP 对应的解密方式,其中使用的就是 Sodium 扩展库中的函数。(见文末参考文档中第二条链接)


$data = '测试加密'; // 原始数据
$nonce = random_bytes(SODIUM_CRYPTO_AEAD_AES256GCM_NPUBBYTES); // 加密证书的随机串,加密证书的随机串
$ad = 'fullstackpm'; // 加密证书的随机串
$kengen = sodium_crypto_aead_aes256gcm_keygen(); // 密钥

// 是否可用
echo sodium_crypto_aead_aes256gcm_is_available(), PHP_EOL; // 1

// 加密
$pem = sodium_crypto_aead_aes256gcm_encrypt($data, $ad, $nonce, $kengen);
var_dump($pem);
// string(28) "��VRw!�����f��l�O�tV=\x�"

// 解密
$v = sodium_crypto_aead_aes256gcm_decrypt($pem, $ad, $nonce, $kengen);
var_dump($v);
// string(12) "测试加密"

代码中的注释已经详细说明了相关函数及参数。在微信支付中使用这个来解密时,ad、key、nonce 等都是由微信提供过来的,而我们这里做为演示,都是自己生成的内容。

sodium_crypto_aead_aes256gcm_encrypt() 加密生成的内容也是二进制的内容,所以相对来说也是非常安全的一种加密形式。

信息签名

Sodium 扩展库同样也为我们带来了验证数据是否被篡改的功能,也就是对信息进行签名比对的能力。


// 信息签名
$key = sodium_crypto_auth_keygen(); // 生成随机签名密钥
$message = '测试认证签名';

// 生成签名
$signature = sodium_crypto_auth($message, $key);
var_dump($signature);
// string(32) "�B�
//                9���l�wn�x���ӛc�ܙ�u^j��"

// 验证签名
var_dump(sodium_crypto_auth_verify($signature, $message, $key));
// bool(true)

它们需要的就是一个简单的随机签名密钥,然后通过对签名摘要和原文进行比对来确定数据在传输过程中是否被篡改。

Hash

是的,你没看错,Sodium 扩展也为我们提供了一套 Hash 加密的函数。不过它的使用要复杂一些,生成的内容有点像 密码散列算法 生成的内容。不过我们还是更推荐使用 密码散列算法 中的 password_hash() 来生成这类的 Hash 密码。


// Hash
$password = '测试Hash';
$hash = sodium_crypto_pwhash_str(
    $password,
    SODIUM_CRYPTO_PWHASH_OPSLIMIT_INTERACTIVE, // 最大计算量
    SODIUM_CRYPTO_PWHASH_MEMLIMIT_INTERACTIVE // 最大RAM量
);
var_dump($hash);
// string(97) "$argon2id$v=19$m=65536,t=2,p=1$VFfdNV4W0MFwLiLPdr9i6g$QDmd5sQToZANYTVEkPVTbPvbY7tuf1ALKU3IXrF44R0"

// 验证 Hash 信息
var_dump(sodium_crypto_pwhash_str_verify($hash, $password));
// bool(true)

总结

虽说我们平常可能没接触过,但是确实在开发中 Sodium 扩展还是有实际应用的,既然微信都使用这种加密方式进行了数据加密,我们也应该对它有更深入的了解。不过,还是希望官方能够尽早完善文档,否则也无法系统地学习这套扩展里面的内容。

测试代码:

参考文档

参考文档:

https://www.php.net/manual/en/book.sodium.php

https://pay.weixin.qq.com/wiki/doc/api/xiaowei.php?chapter=19_11

以上就是详解PHP的Sodium加密扩展函数的详细内容,更多关于PHP的Sodium加密扩展函数的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解PHP的Sodium加密扩展函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP加密函数与解密函数详解

这篇文章主要为大家详细介绍了PHP中的加密函数与解密函数的相关资料,文中的示例代码讲解详细,对我们学习了解PHP有一定的帮助,需要的可以参考一下
2022-11-13

PHP 函数的扩展加载机制

php扩展加载通过php.ini配置文件或代码直接加载,分别是:1. 添加extension=module_name.so行到php.ini配置文件;2. 使用dl("module_name.so")函数动态加载扩展。PHP 函数扩展加载机
PHP 函数的扩展加载机制
2024-04-26

PHP代码加密和扩展解密的示例分析

这篇文章主要介绍了PHP代码加密和扩展解密的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法
2023-06-14

PHP 函数的扩展函数有哪些?

是的,php 函数扩展函数可以修改或增强现有函数的行为,包括:user_error():报告用户可读的错误消息trigger_error():报告 php 错误消息set_error_handler():注册一个用户函数来处理错误resto
PHP 函数的扩展函数有哪些?
2024-04-10

PHP加密函数 Javascript/Js 解密函数

php加密,js解密,貌似没什么意义,主要是key在js中会被看到,不过在某些地方可能会用到
2022-11-15

如何扩展 PHP 的函数库?

php 函数库扩展方法:创建自定义函数;调用 spl_autoload_register() 注册函数库;使用自定义函数,就像内置函数一样。如何扩展 PHP 的函数库简介PHP 通过函数库为开发人员提供了丰富的功能。然而,有时需要创建自
如何扩展 PHP 的函数库?
2024-04-21

详解PHPlaravel中的加密与解密函数

Laravel为我们提供了完整的加密方法及加密模式。这篇文章主要带大家具体看下laravel为我们提供的加密及解密方法,感兴趣的小伙伴可以了解一下
2022-11-13

PHP 函数扩展的调试指南

PHP 函数扩展的调试指南扩展 PHP 函数是一个强大的功能,它允许您增强 PHP 核心的功能。然而,在调试这些扩展时可能会遇到挑战。本指南将介绍有效的调试技术,帮助您快速识别和解决错误。开启 PHP 调试模式ini_set('disp
PHP 函数扩展的调试指南
2024-04-26

PHP 函数扩展的最佳实践

php 函数扩展的最佳实践包括使用命名空间、类型提示、启用严格模式检查以及处理错误,从而创建稳定、可靠且可维护的函数扩展。PHP 函数扩展的最佳实践PHP 提供了扩展库的功能,允许开发人员添加自己的函数到 PHP 解释器中。遵循最佳实践对
PHP 函数扩展的最佳实践
2024-04-28

JavaScript函数扩展与箭头函数超详细讲解

这篇文章主要介绍了JavaScript函数扩展与箭头函数的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2022-11-13

PHP 函数在云计算中的扩展

php 函数可在云计算中通过以下方式进行扩展:使用 amazon lambda 函数通过 google cloud functions 扩展使用 azure functionsPHP 函数在云计算中的扩展云计算为 PHP 开发人员提供了众
PHP 函数在云计算中的扩展
2024-05-02

PHP 函数的扩展和第三方模块

要扩展 php 函数功能,可以使用扩展和第三方模块。扩展提供附加函数和类,可通过 pecl 包管理器安装和启用。第三方模块提供特定功能,可通过 composer 包管理器安装。实践案例包括使用扩展解析复杂 json 数据和使用模块验证数据。
PHP 函数的扩展和第三方模块
2024-04-13

PHP 函数扩展的代码维护技巧

PHP 函数扩展的代码维护技巧为了确保 PHP 函数扩展的长期稳定和可维护性,遵循一些代码维护最佳实践至关重要。以下是一些实用的技巧,以及真实的案例演示:1. 模块化设计将扩展拆分成更小的、可重用的模块,每个模块执行特定任务。这样做可
PHP 函数扩展的代码维护技巧
2024-04-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录