php加密验签
签名生成步骤(小程序端/前端):
确定参与签名的参数:选择需要参与签名的请求参数,通常包括请求的时间戳、随机数、请求的数据等。
参数排序与拼接:将所有参与签名的参数按照字母顺序排序,并拼接成一个待签名的字符串。
生成签名:使用 HMAC 算法(如 HMAC-SHA256)和预设的密钥对拼接后的字符串进行签名。HMAC 需要一个密钥和一个消息作为输入,生成一个固定长度的哈希值作为输出。
发送请求:将签名和其他请求参数一起发送给服务器。
在小程序中,如果你需要进行 HMAC 加密(通常与某个哈希函数如 SHA256 结合使用),你可以使用小程序提供的 JavaScript 运行时环境来实现。但是,小程序标准库并不直接提供 HMAC 加密函数,因此你需要使用现成的 JavaScript 库,或者自己实现 HMAC 算法。
这里有一个使用 JavaScript(可以在小程序中运行)和 CryptoJS 库(需要你自己引入)来实现 HMAC-SHA256 加密的示例:
-
首先,你需要将 CryptoJS 库添加到你的小程序项目中。你可以通过 npm 安装它(虽然小程序原生不支持 npm,但你可以将 npm 包转换为小程序支持的格式),或者手动下载并添加到项目中。
-
然后,你可以使用以下代码进行 HMAC-SHA256 加密:
// 假设你已经以某种方式引入了 CryptoJS 库
// 例如,通过 require 或 import(如果小程序支持)
// var CryptoJS = require('path/to/crypto-js'); // 小程序可能不支持 require,所以你需要其他方式引入 // 示例:使用 CryptoJS 进行 HMAC-SHA256 加密
function hmacSha256(message, secret) { // CryptoJS.HmacSHA256 需要两个参数:要加密的消息和密钥 var hash = CryptoJS.HmacSHA256(message, secret); // toString() 方法将加密结果转换为十六进制字符串 return hash.toString(CryptoJS.enc.Hex);
} // 使用示例
var message = 'The quick brown fox jumps over the lazy dog'; // 要加密的消息
var secret = 'my-secret-key'; // 密钥
var encrypted = hmacSha256(message, secret);
console.log(encrypted); // 输出加密后的十六进制字符串
注意:由于小程序环境可能限制了对外部库的引入和使用,因此你可能需要找到一种方法来将 CryptoJS 或其他加密库打包成小程序可以使用的格式。这通常涉及到使用工具(如 webpack 或其他打包器)来转换库,并手动将其添加到你的小程序项目中。
如果你不想使用外部库,你也可以查找 HMAC-SHA256 的纯 JavaScript 实现,并将其包含在你的小程序代码中。但是,请注意,实现加密算法时要格外小心,以确保它们的安全性和正确性。
签名验证步骤(PHP 后台):
接收请求参数:从请求中获取所有参与签名的参数以及签名值。
参数排序与拼接:使用与小程序端相同的规则,对接收到的参数进行排序并拼接成待验证的字符串。
验证签名:使用相同的 HMAC 算法和密钥,对待验证的字符串进行哈希计算,生成一个本地的签名值。
比较签名:将生成的本地签名值与请求中携带的签名值进行比较。
判断结果:如果两个签名值相同,则认为请求是合法的;否则,拒绝请求。
<?php//获取签名
function generateSignature($params, $secretKey)
{ksort($params); // 对参数进行排序$stringToSign = http_build_query($params,'', '&',PHP_QUERY_RFC3986); // 拼接参数 注意:使用RFC 3986 标准进行编码确保和前端url转译的特殊字符(空格)保持一致return hash_hmac('sha256', $stringToSign, $secretKey); // 使用 HMAC-SHA256 生成签名
}//验签
function verifySignature($params, $receivedSignature, $secretKey)
{$expectedSignature = generateSignature($params, $secretKey); // 生成期望的签名return hash_equals($expectedSignature, $receivedSignature); // 比较签名是否一致
}// 假设这是从请求中获取的参数和签名$requestParams = [ 'timestamp' => '1679312345', 'nonce_str' => 'abcdefg', 'user_id'=>1 ];$receivedSignature = '签名值从请求中获取'; //签名$secretKey = '你的密钥'; // 这个密钥应该安全地存储在服务器上,并且只有服务器知道// 验证签名if (verifySignature($requestParams, $receivedSignature, $secretKey)){echo "签名验证成功!";} else {echo "签名验证失败!";}
- hash:用于验证数据的完整性,不需要密钥,但可能容易受到冲突攻击。
- HMAC_hash:结合了密钥和哈希函数来验证数据的完整性和来源,更安全,因为需要知道密钥才能验证 HMAC 值。
- 注意: http_build_query($params,'', '&',PHP_QUERY_RFC3986); // 拼接参数 注意:使用RFC 3986 标准进行编码确保和前端url转译的特殊字符(空格)保持一致
相关文章:
php加密验签
签名生成步骤(小程序端/前端): 确定参与签名的参数:选择需要参与签名的请求参数,通常包括请求的时间戳、随机数、请求的数据等。 参数排序与拼接:将所有参与签名的参数按照字母顺序排序,并拼接成…...
【Golang - 90天从新手到大师】Day06 - 数组
系列文章合集 Golang - 90天从新手到大师 数组是golang中最常用的一种数据结构,数组就是同一类型数据的有序集合 定义一个数组 格式: var name [n]type n为数组长度,n>0 且无法修改,type为数组的元素类型如: var a [2]int上面的例子定义了一个长度为2,元素类型为int的数组…...
java的有参构造方法
java的有参构造方法和无参构造方法类似,区别是构造方法名称里后面跟着一个括号,括号里是参数的定义 示例代码如下 class student4{private String name;private int age;public student4(String n,int a) {namen;agea;System.out.println("调用了…...
Vue66-vue-默认插槽
一、默认插槽需求 1-1、原本的写法: 在每个category组件中用v-show来做条件渲染,但是不方便! 1-2、默认插槽 img标签,ul标签,video标签,都是在app组件中完成解析之后,塞到category组件中的&…...
tsf-consul的使用
在腾讯云微服务平台TSF中使用Consul作为服务发现组件,通常需要遵循以下步骤: ### 1. 创建应用 首先,您需要在TSF控制台创建一个应用。在创建应用时,选择合适的业务类型、开发语言、开发框架等信息。对于使用Consul作为服务发现组件的Spring Cloud应用,您需要选择“业务应…...
【perl】基本语法 /备忘录/
分享 perl 语言学习资源 Perl 教程|极客教程 (geek-docs.com) Perl [zh] (runebook.dev) Perl 运算符 | 菜鸟教程 (runoob.com) Perl Documentation - Perldoc Browser Search the CPAN - metacpan.org 当然还有一些经典书籍,不再列举。 1、数字 1.1、数字表…...
mongodb 集群安装
整体架构图: 1. 配置域名 Server1: OS version: CentOS Linux release 8.5.2111 hostnamectl --static set-hostname mongo01 vi /etc/sysconfig/network # Created by anaconda hostnamemong01 echo "192.168.88.20 mong1 mongo01.com mongo…...
绿茶集团重启IPO:流量渐退、业绩波动,还能讲出好故事吗?
近日,绿茶集团有限公司(下称“绿茶集团”)向港交所递交上市申请,花旗、招银国际为其联席保荐人。 回望绿茶集团的上市之路,可谓有诸多坎坷。该公司于2021年3月首度向港交所发起冲击,但却将中文版招股书中的“流动负债总额”错写成…...
Git与SSH
Git Git是一种分布式版本控制系统,最初由Linus Torvalds为管理Linux内核开发而设计并开发。Git可以帮助开发团队协作管理代码,跟踪代码变更历史,并在需要时回溯到特定版本。 分布式版本控制:每个开发者都可以拥有完整的代码仓库…...
我的创作纪念日--码农阿豪
个人名片 🎓作者简介:java领域优质创作者 🌐个人主页:码农阿豪 📞工作室:新空间代码工作室(提供各种软件服务) 💌个人邮箱:[2435024119qq.com] 📱…...
Git 学习笔记(超详细注释,从0到1)
Git学习笔记 1.1 关键词 Fork、pull requests、pull、fetch、push、diff、merge、commit、add、checkout 1.2 原理(看图学习) 1.3 Fork别人仓库到自己仓库中 记住2个地址 1)上游地址(upstream地址):http…...
GitLab项目组相关操作(创建项目组Group、创建项目组的项目、为项目添加成员并赋予权限)
天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。 君不见,黄河之水天上来,奔流到海不复回。 君不见,高堂明镜悲白发,朝如青丝暮成雪。 ——《将…...
英语恶补ing
ing的词组都有停下来做某事的感觉了。 second hand是形容词了。 wouldnt buy这里的would是情态动词,也是助动词 助动词不能单独使用,要搭配实义动词,这样才能构成谓语 情态动词(modals)在英语中有多种作用ÿ…...
DS1339C串行实时时钟-国产兼容RS4C1339
RS4C1339串行实时时钟是一种低功耗的时钟/日期设备,具有两个可编程的一天时间报警器和一个可编程方波输出。地址和数据通过2线双向总线串行传输。时钟/日期提供秒、分钟、小时、天、日期、月份和年份信息。对于少于31天的月份,月末的日期会自动调整&…...
神经网络模型---LeNet-5
一、LeNet-5 1.定义LeNet-5模型 model models.Sequential([1.1添加一个二维卷积层,有6个过滤器,每个过滤器的尺寸是5x5。输入图像尺寸是28x28像素,具有1个颜色通道,激活函数是relu layers.Conv2D(6, (5, 5), activationrelu, input_shape…...
免费分享:1994-2020年中国各行业二氧化碳排放数据(附下载方法)
日前,国务院印发《2024—2025年节能降碳行动方案》针对重点领域进行部署,同时明确了制度标准、价格政策、资金支持、科技引领、市场化机制、全民行动等6项措施,为节能降碳提供支撑保障。1994-2020年中国各行业二氧化碳排放数据为评估环境政策…...
Qemu虚拟机在线迁移到VMware
libvirt版本:libvirt-10.0.0qemu版本:qemu-8.2.0 在生产环境中,大多数的场景是 vmware 虚拟机迁移到 qemu 环境,一般是通过关机然后导出、导入磁盘镜像来实现。 如果要将 qemu 环境虚拟机迁移到 vmware 怎么办呢?要求…...
计算机游戏因为d3dcompiler_47.dll丢失无法启动怎么办?解决只要d3dcompiler_47.dll丢失无法启动游戏软件的方法
d3dcompiler_47.dll 是一个动态链接库文件,属于 Microsoft DirectX 的一部分,主要负责编译和运行 3D 图形程序。它是支持 Direct3D 功能的核心组件,Direct3D 是一种用于编程 3D 图形的 API,广泛应用于游戏和图形密集型应用程序中。…...
LDO的原理及测试方法
一、基本结构 这是LM317芯片的核心,这个电路单元称为Bandgap Reference带隙基准源。属于模拟集成电路中的经典电路结构。 LDO拓扑结构图 常见的基本结构 利用VBE的负温度系数,而VT是正温度系数,正负温度系数抵消就的得到稳定的基准参考电压了(三极管的方程VBE=VT*In(lC/IS…...
图论算法学习
图论 dfs是可一个方向去搜,不到黄河不回头,直到遇到绝境了,搜不下去了,再换方向(换方向的过程就涉及到了回溯)。bfs是先把本节点所连接的所有节点遍历一遍,走到下一个节点的时候,再…...
别再瞎找了!10个AI论文软件测评:全学科适配,开题报告+毕业论文全搞定
在学术研究日益数字化的今天,论文写作已成为高校师生和科研人员不可回避的核心任务。然而,从选题构思到文献检索、从初稿撰写到格式调整,每一个环节都可能成为效率的“卡点”。尤其在AI技术快速迭代的背景下,市场上涌现出大量论文…...
MySQL迁移到金仓的集合类型支持实践:CREATE TYPE + SET 的兼容实现
MySQL迁移到金仓的集合类型支持实践:CREATE TYPE SET 的兼容实现 在当前信创加速落地的背景下,金仓数据库(KingbaseES)因其对MySQL生态的深度适配能力,正被政务、金融、能源等关键行业纳入核心系统技术评估范围。尤其…...
第0010课 - 控制速度
第0010课 - 控制速度 学习目标 深入理解"歇一会儿" 学会用按键改变速度 理解速度与歇一会儿时间的关系 任务描述 按 1-5 键改变坦克的移动速度,1最快,5最慢! 本节课源代码 /*第0010课 - 控制速度目标:学会用Sleep函数控制坦克移动速度解释:Sleep(毫秒数) …...
M2LOrder模型内网穿透部署方案:安全访问本地情感分析服务
M2LOrder模型内网穿透部署方案:安全访问本地情感分析服务 最近在折腾M2LOrder这个情感分析模型,本地部署跑得挺顺畅,但遇到个实际问题:想给同事演示一下效果,或者临时让外部服务调用一下,总不能让人家跑到…...
5个高效控制技巧:JoyCon-Driver让跨平台手柄映射效率提升300%
5个高效控制技巧:JoyCon-Driver让跨平台手柄映射效率提升300% 【免费下载链接】JoyCon-Driver A vJoy feeder for the Nintendo Switch JoyCons and Pro Controller 项目地址: https://gitcode.com/gh_mirrors/jo/JoyCon-Driver 在游戏与创意设计领域&#x…...
重构网盘下载体验:Online-disk-direct-link-download-assistant技术原理与应用实践
重构网盘下载体验:Online-disk-direct-link-download-assistant技术原理与应用实践 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改(改自6.1.4版本) ,…...
百度网盘提速工具评测:突破下载限制的开源解决方案
百度网盘提速工具评测:突破下载限制的开源解决方案 【免费下载链接】pan-baidu-download 百度网盘下载脚本 项目地址: https://gitcode.com/gh_mirrors/pa/pan-baidu-download 30秒核心价值速览 🚀 多线程加速:最高支持32线程并行下载…...
在Linux x86_64系统中编译mission
以下在ubuntu18.10 gcc8.3编译通过。安装编译工具:sudo apt install build-essential sudo apt install cmake重命名以下目录中的wsf_module为wsf_module-(子目录的不用管)以屏蔽图形界面相关的模块:swdev/src/engage swdev/src/…...
突破Cursor试用限制:革新性设备标识重置技术全解析
突破Cursor试用限制:革新性设备标识重置技术全解析 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Youve reached your trial request limit. / Too many free trial accounts used on this machine. Please upgrade to pro. We hav…...
黑丝空姐-造相Z-Turbo实战:Java开发者集成AIGC应用开发指南
黑丝空姐-造相Z-Turbo实战:Java开发者集成AIGC应用开发指南 最近和几个做Java后端的朋友聊天,发现他们对AIGC挺感兴趣,但总觉得这是Python或者前端的事儿,离自己有点远。有个朋友说,他们公司想做个内部用的营销素材生…...
