客户端如何进行HmacSHA256加密

2024-04-24 15:52

本文主要是介绍客户端如何进行HmacSHA256加密,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

开发了一个短信验证码接口,为了防止被攻击,在接口层面上加了一个签名。
签名的算法是使用HmacSHA256加密,Base64编码。

加密字符串就以【手机号】+【随机数】的格式举例。

客户端有Android、iOS、H5-js、小程序,都需要进行验签。

secret秘钥随机生成一个

XnvmtittKmvelZSIlmewagwxkWiSNFPn

各平台代码实现逻辑

iOS

import CryptoKitfunc generateSignature(data: String, key: String) -> String? {let key = SymmetricKey(data: key.data(using: .utf8)!)let signature = HMAC<SHA256>.authenticationCode(for: data.data(using: .utf8)!, using: key)return Data(signature).base64EncodedString()
}// 使用
let secret = "" // 后端提供
let data = mobile + nonce; // data是 手机号 + 随机数if let signature = generateSignature(data: data, key: secret) {print(signature)
}

Android

import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;public String generateSignature(String data, String secretKey) throws Exception {Mac sha256_HMAC = Mac.getInstance("HmacSHA256");SecretKeySpec secretKeySpec = new SecretKeySpec(secretKey.getBytes(), "HmacSHA256");sha256_HMAC.init(secretKeySpec);return Base64.getEncoder().encodeToString(sha256_HMAC.doFinal(data.getBytes()));
}// data是请求参数按照一定规则排序后拼接成的字符串
String secret = "" // 后端提供
String data = mobile + nonce; // data是 手机号 + 随机数String signature = generateSignature(data, secret);

H5-js

async function generateSignature(data, secretKey) {const encoder = new TextEncoder();const keyData = encoder.encode(secretKey);const dataToSign = encoder.encode(data);const key = await window.crypto.subtle.importKey("raw", keyData, { name: "HMAC", hash: { name: "SHA-256" } }, true, ["sign"]);const signature = await window.crypto.subtle.sign("HMAC", key, dataToSign);return window.btoa(String.fromCharCode(...new Uint8Array(signature)));
}// 使用示例
const secret = "" // 后端提供
const data = mobile + nonce; // data是 手机号 + 随机数generateSignature(data, secret).then(signature => console.log(signature));

小程序

小程序需要在小程序后台,第三方服务,插件管理中搜索并添加【crypto】

参考:https://developers.weixin.qq.com/miniprogram/dev/framework/plugin/using.html


// 在app.json中添加
"plugins": {"crypto": {"version": "0.0.003","provider": "wxxxxxxxxxx" // 替换成自己插件的id}
}// 引入代码
const crypto = requirePlugin("crypto");// 假设 data 是你要签名的数据,key 是你的密钥
const data = "data_to_sign";
const key = "secret_key";// 生成 HMAC SHA256 签名
function generateSignature(data, key) {let hmac256 = new crypto.HmacSHA256(data, key);return hmac256.toString(crypto.Base64);
}// 调用函数生成签名
generateSignature(data, key);

这篇关于客户端如何进行HmacSHA256加密的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/932165

相关文章

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

SpringSecurity6.0 如何通过JWTtoken进行认证授权

《SpringSecurity6.0如何通过JWTtoken进行认证授权》:本文主要介绍SpringSecurity6.0通过JWTtoken进行认证授权的过程,本文给大家介绍的非常详细,感兴趣... 目录项目依赖认证UserDetailService生成JWT token权限控制小结之前写过一个文章,从S

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详