LuatOS-SOC接口文档(air780E)--crypto - 加解密和hash函数
crypto.md5(str)
计算md5值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的md5值的hex字符串 |
例子
-- 计算字符串"abc"的md5
log.info("md5", crypto.md5("abc"))
crypto.hmac_md5(str, key)
计算hmac_md5值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
| string | 密钥 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的hmac_md5值的hex字符串 |
例子
-- 计算字符串"abc"的hmac_md5
log.info("hmac_md5", crypto.hmac_md5("abc", "1234567890"))
crypto.sha1(str)
计算sha1值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的sha1值的hex字符串 |
例子
-- 计算字符串"abc"的sha1
log.info("sha1", crypto.sha1("abc"))
crypto.hmac_sha1(str, key)
计算hmac_sha1值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
| string | 密钥 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的hmac_sha1值的hex字符串 |
例子
-- 计算字符串"abc"的hmac_sha1
log.info("hmac_sha1", crypto.hmac_sha1("abc", "1234567890"))
crypto.sha256(str)
计算sha256值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的sha256值的hex字符串 |
例子
-- 计算字符串"abc"的sha256
log.info("sha256", crypto.sha256("abc"))
crypto.hmac_sha256(str, key)
计算hmac_sha256值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
| string | 密钥 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的hmac_sha256值的hex字符串 |
例子
-- 计算字符串"abc"的hmac_sha256
log.info("hmac_sha256", crypto.hmac_sha256("abc", "1234567890"))
crypto.sha512(str)
计算sha512值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的sha512值的hex字符串 |
例子
-- 计算字符串"abc"的sha512
log.info("sha512", crypto.sha512("abc"))
crypto.hmac_sha512(str, key)
计算hmac_sha512值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 需要计算的字符串 |
| string | 密钥 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 计算得出的hmac_sha512值的hex字符串 |
例子
-- 计算字符串"abc"的hmac_sha512
log.info("hmac_sha512", crypto.hmac_sha512("abc", "1234567890"))
crypto.cipher_encrypt(type, padding, str, key, iv)
对称加密
参数
| 传入值类型 | 解释 |
|---|---|
| string | 算法名称, 例如 AES-128-ECB/AES-128-CBC, 可查阅crypto.cipher_list() |
| string | 对齐方式, 支持PKCS7/ZERO/ONE_AND_ZEROS/ZEROS_AND_LEN/NONE |
| string | 需要加密的数据 |
| string | 密钥,需要对应算法的密钥长度 |
| string | IV值, 非ECB算法需要 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 加密后的字符串 |
例子
-- 计算AES
local data = crypto.cipher_encrypt("AES-128-ECB", "PKCS7", "1234567890123456", "1234567890123456")
local data2 = crypto.cipher_encrypt("AES-128-CBC", "PKCS7", "1234567890123456", "1234567890123456", "1234567890666666")
crypto.cipher_decrypt(type, padding, str, key, iv)
对称解密
参数
| 传入值类型 | 解释 |
|---|---|
| string | 算法名称, 例如 AES-128-ECB/AES-128-CBC, 可查阅crypto.cipher_list() |
| string | 对齐方式, 支持PKCS7/ZERO/ONE_AND_ZEROS/ZEROS_AND_LEN/NONE |
| string | 需要解密的数据 |
| string | 密钥,需要对应算法的密钥长度 |
| string | IV值, 非ECB算法需要 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 解密后的字符串 |
例子
-- 用AES加密,然后用AES解密
local data = crypto.cipher_encrypt("AES-128-ECB", "PKCS7", "1234567890123456", "1234567890123456")
local data2 = crypto.cipher_decrypt("AES-128-ECB", "PKCS7", data, "1234567890123456")
-- data的hex为 757CCD0CDC5C90EADBEEECF638DD0000
-- data2的值为 1234567890123456
crypto.crc16(method, data, poly, initial, finally, inReversem outReverse)
计算CRC16
参数
| 传入值类型 | 解释 |
|---|---|
| string | CRC16模式(”IBM”,”MAXIM”,”USB”,”MODBUS”,”CCITT”,”CCITT-FALSE”,”X25”,”XMODEM”,”DNP”,”USER-DEFINED”) |
| string | 字符串 |
| int | poly值 |
| int | initial值 |
| int | finally值 |
| int | 输入反转,1反转,默认0不反转 |
| int | 输入反转,1反转,默认0不反转 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | 对应的CRC16值 |
例子
-- 计算CRC16
local crc = crypto.crc16("")
crypto.crc16_modbus(data)
直接计算modbus的crc16值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 数据 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | 对应的CRC16值 |
例子
-- 计算CRC16 modbus local crc = crypto.crc16_modbus(data)
crypto.crc32(data)
计算crc32值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 数据 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | 对应的CRC32值 |
例子
-- 计算CRC32 local crc = crypto.crc32(data)
crypto.crc8(data)
计算crc8值
参数
| 传入值类型 | 解释 |
|---|---|
| string | 数据 |
| int | crc多项式,可选,如果不写,将忽略除了数据外所有参数 |
| int | crc初始值,可选,默认0 |
| boolean | 是否需要逆序处理,默认否 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | 对应的CRC8值 |
例子
-- 计算CRC8 local crc = crypto.crc8(data) local crc = crypto.crc8(data, 0x31, 0xff, false)
crypto.trng(len)
生成真随机数
参数
| 传入值类型 | 解释 |
|---|---|
| int | 数据长度 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 指定随机数字符串 |
例子
-- 生成32位随机数ir local r = crypto.trng(4) local _, ir = pack.unpack(r, "I")
crypto.totp(secret,time)
计算TOTP动态密码的结果
参数
| 传入值类型 | 解释 |
|---|---|
| string | 网站提供的密钥(就是BASE32编码后的结果) |
| int | 可选,时间戳,默认当前时间 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | 计算得出的六位数结果 计算失败返回nil |
例子
--使用当前系统时间计算
local otp = crypto.totp("asdfassdfasdfass")
crypto.base64_encode(data)
将数据进行base64编码
参数
| 传入值类型 | 解释 |
|---|---|
| string | 待编码的数据 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 编码后的数据 |
例子
-- 本函数与 string.toBase64 是同一个
local data = "123"
local bdata = crypto.base64_encode(data)
log.info("base64", "encode", data, bdata)
data = crypto.base64_decode(data)
log.info("base64", "decode", data, bdata)
crypto.base64_decode(data)
将数据进行base64解码
参数
| 传入值类型 | 解释 |
|---|---|
| string | 待解码的数据 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 解码后的数据 |
例子
-- 本函数与 string.fromBase64 是同一个
local data = "123"
local bdata = crypto.base64_encode(data)
log.info("base64", "encode", data, bdata)
data = crypto.base64_decode(data)
log.info("base64", "decode", data, bdata)
crypto.cipher_list()
获取当前固件支持的cipher列表
参数
无
返回值
| 返回值类型 | 解释 |
|---|---|
| table | 本固件支持的cipher列表,字符串数组 |
例子
-- 本API于2022.07.27添加
local ciphers = crypto.cipher_list()
if ciphers thenlog.info("crypto", "ciphers list", json.encode(ciphers))
end
crypto.cipher_suites()
获取当前固件支持的cipher suites列表
参数
无
返回值
| 返回值类型 | 解释 |
|---|---|
| table | 本固件支持的cipher suites列表,字符串数组 |
例子
-- 本API于2022.11.16添加
local suites = crypto.cipher_suites()
if suites thenlog.info("crypto", "ciphers suites", json.encode(suites))
end
crypto.md_file(tp, path, hmac)
计算文件的hash值(md5/sha1/sha256及hmac形式)
参数
| 传入值类型 | 解释 |
|---|---|
| string | hash类型, 大小字母, 例如 “MD5” “SHA1” “SHA256” |
| string | 文件路径, 例如 /luadb/logo.jpg |
| string | hmac值,可选 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | HEX过的hash值,若失败会无返回值 |
例子
-- 无hmac的hash值
log.info("md5", crypto.md_file("MD5", "/luadb/logo.jpg"))
log.info("sha1", crypto.md_file("SHA1", "/luadb/logo.jpg"))
log.info("sha256", crypto.md_file("SHA256", "/luadb/logo.jpg"))-- 带hmac的hash值
log.info("hmac_md5", crypto.md_file("MD5", "/luadb/logo.jpg", "123456"))
log.info("hmac_sha1", crypto.md_file("SHA1", "/luadb/logo.jpg", "123456"))
log.info("hmac_sha256", crypto.md_file("SHA256", "/luadb/logo.jpg", "123456"))
crypto.md(tp, data, hmac)
计算数据的hash值(md5/sha1/sha256及hmac形式)
参数
| 传入值类型 | 解释 |
|---|---|
| string | hash类型, 大小字母, 例如 “MD5” “SHA1” “SHA256” |
| string | 待处理的数据 |
| string | hmac值,可选 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | HEX过的hash值,若失败会无返回值 |
例子
-- 无hmac的hash值
log.info("md5", crypto.md("MD5", "1234567890"))
log.info("sha1", crypto.md("SHA1", "1234567890"))
log.info("sha256", crypto.md("SHA256", "1234567890"))-- 带hmac的hash值
log.info("hmac_md5", crypto.md("MD5", "1234567890", "123456"))
log.info("hmac_sha1", crypto.md("SHA1", "1234567890", "123456"))
log.info("hmac_sha256", crypto.md("SHA256", "1234567890", "123456"))
crypto.hash_init(tp)
创建流式hash用的stream
参数
| 传入值类型 | 解释 |
|---|---|
| string | hash类型, 大写字母, 例如 “MD5” “SHA1” “SHA256” |
| string | hmac值,可选 |
返回值
| 返回值类型 | 解释 |
|---|---|
| userdata | 成功返回一个数据结构,否则返回nil |
例子
-- 无hmac的hash stream
local md5_stream = crypto.hash_init("MD5")
local sha1_stream = crypto.hash_init("SHA1")
local sha256_stream = crypto.hash_init("SHA256")-- 带hmac的hash stream
local md5_stream = crypto.hash_init("MD5", "123456")
local sha1_stream = crypto.hash_init("SHA1", "123456")
local sha256_stream = crypto.hash_init("SHA256", "123456")
crypto.hash_update(stream, data)
流式hash更新数据
参数
| 传入值类型 | 解释 |
|---|---|
| userdata | crypto.hash_init()创建的stream, 必选 |
| string | 待计算的数据,必选 |
| return | 无 |
返回值
无
例子
crypto.hash_update(stream, "OK")
crypto.hash_finish(stream)
获取流式hash校验值并释放创建的stream
参数
| 传入值类型 | 解释 |
|---|---|
| userdata | crypto.hash_init()创建的stream,必选 |
返回值
| 返回值类型 | 解释 |
|---|---|
| string | 成功返回计算得出的流式hash值的hex字符串,失败无返回 |
例子
local hashResult = crypto.hash_finish(stream)
crypto.checksum(data, mode)
计算checksum校验和
参数
| 传入值类型 | 解释 |
|---|---|
| string | 待计算的数据,必选 |
| int | 模式,累加模式, 0 - 异或, 1 - 累加, 默认为0 |
返回值
| 返回值类型 | 解释 |
|---|---|
| int | checksum值,校验和 |
例子
-- 本函数在 2022.12.28 添加
-- 单纯计算checksum值
local ck = crypto.checksum("OK")
log.info("checksum", "ok", string.format("%02X", ck))
-- 第二个参数mode在2023.5.23日添加
相关文章:
LuatOS-SOC接口文档(air780E)--crypto - 加解密和hash函数
crypto.md5(str) 计算md5值 参数 传入值类型 解释 string 需要计算的字符串 返回值 返回值类型 解释 string 计算得出的md5值的hex字符串 例子 -- 计算字符串"abc"的md5 log.info("md5", crypto.md5("abc"))crypto.hmac_md5(str, k…...
自动化测试的定位及一些思考
大家对自动化的理解,首先是想到Web UI自动化,这就为什么我一说自动化,公司一般就会有很多人反对,因为自动化的成本实在太高了,其实自动化是分为三个层面的(UI层自动化、接口自动化、单元测试)&a…...
展会动态 | 迪捷软件邀您参加2023世界智能网联汽车大会
*9月18日之前注册的观众免收门票费* 由北京市人民政府、工业和信息化部、公安部、交通运输部和中国科学技术协会联合主办的2023世界智能网联汽车大会将于9月21日-24日在北京中国国际展览中心(顺义馆)举行。 论坛背景 本届展会以“聚智成势 协同向新——…...
jenkins自动化部署springboot、gitee项目
服务器需要安装jdk11、maven、gitee 1. jenkins安装 # yum源 sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat/jenkins.repo # 公钥 sudo rpm --import https://pkg.jenkins.io/redhat/jenkins.io-2023.key # 安装 yum install jenkins如果yum源报…...
Python环境配置及基础用法Pycharm库安装与背景设置及避免Venv文件夹
目录 一、Python环境部署及简单使用 1、Python下载安装 2、环境变量配置 3、检查是否安装成功 4、Python的两种模式(编辑模式&交互模式) 二、Pycharm库安装与背景设置 1、Python库安装 2、Pycharm自定义背景 三、如何避免Venv文件夹 一、P…...
PHP常见的SQL防注入方法
利用Mysqli和PDO 产生原因主要就是一些数据没有经过严格的验证,然后直接拼接 SQL 去查询。导致产生漏洞,比如: $id $_GET[id]; $sql "SELECT name FROM users WHERE id $id";因为没有对 $_GET[‘id’] 做数据类型验证…...
分布式和中间件等
raft协议 paxos算法ddos 如何避免?怎么预防?怎么发现?利用了TCP什么特点?怎么改进TCP可以预防?服务端处理不了的请求怎么办?连接数最大值需要设置吗?怎么设置? Thrift RPC过程是什么样子的?异构系统怎么完成通信?跟http相比什么优缺点?了解grpc吗?kafka topic part…...
通过http发送post请求的三种Content-Type分析
通过okhttp向服务端发起post网络请求,可以通过Content-Type设置发送请求数据的格式。 常用到的三种: 1)application/x-www-form-urlencoded; charsetutf-8 2)application/json; charsetutf-8 3)multipart/form-dat…...
Vue中的自定义指令详解
文章目录 自定义指令自定义指令-指令的值(给自定义指令传参数) 自定义指令 自定义指令:自己定义的指令,可以封装一些dom 操作,扩展额外功能(自动聚焦,自动加载,懒加载等复杂的指令封…...
[管理与领导-100]:管理者到底是什么?调度器?路由器?交换机?监控器?
目录 前言: 二层交换机 三层路由器 监视器(Monitor) 调度器 前言: 人在群体中,有点像设备在网络中,管理者到底承担什么的功能? 二层交换机 交换机是计算机网络中,用于连接多台…...
保研CS/软件工程/通信问题汇总
机器学习 1.TP、TN、FP、FN、F1 2.机器学习和深度学习的区别和联系 模型复杂性:深度学习是机器学习的一个子领域,其主要区别在于使用深层的神经网络模型。深度学习模型通常包含多个隐层,可以学习更加复杂的特征表示,因此在某些任…...
word、excel、ppt转为PDF
相关引用对象在代码里了 相关依赖 <dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.0.1</version></dependency> <dependency><groupId>org.apache.poi</group…...
2023华为杯D题——基于Kaya模型的碳排放达峰实证研究
一、前言 化石能源是推动现代经济增长的重要生产要素,经济生产活动与碳排放活动密切相关。充分认识经济增长与碳排放之间的关系对转变生产方式,确定碳达峰、碳中和路径极为必要。本研究在对经济增长与碳排放关系现有研究梳理的基础上,系统地分…...
有哪些好用的上网行为管理软件?(上网行为管理软件功能好的软件推荐)
随着互联网的快速发展,企业的信息化管理和员工的上网行为已经成为企业信息化建设的重要组成部分。上网行为管理软件作为一种新型的管理工具,可以帮助企业实现对员工上网行为的管控和优化,进而提高企业的工作效率和网络安全。本文将对多款市场…...
npm install报错 code:128
报的错误: npm ERR! code 128 npm ERR! An unknown git error occurred npm ERR! command git --no-replace-objects ls-remote ssh://gitgithub.com/nhn/raphael.git npm ERR! gitgithub.com: Permission denied (publickey). npm ERR! fatal: Could not read from remote re…...
爬虫 — Scrapy 框架(一)
目录 一、介绍1、同步与异步2、阻塞与非阻塞 二、工作流程三、项目结构1、安装2、项目文件夹2.1、方式一2.2、方式二 3、创建项目4、项目文件组成4.1、piders/__ init __.py4.2、spiders/demo.py4.3、__ init __.py4.4、items.py4.5、middlewares.py4.6、pipelines.py4.7、sett…...
Python编程语言学习笔记
目录 1 书写格式1.1 程序框架格式1.1 注释1.2 保留字 2 数据2.1 整数类型2.2 浮点类型2.3 复数类型2.4 数值运算符2.5 数值运函数2.6 数值类型转换函数2.7 math 库2.8 字符串2.8.1 字符串的表示2.8.2 字符串的区间访问2.8.3 字符串操作符2.8.4 字符串操作函数 2.9 字符串类型的…...
【运维面试100问】(三)说说你在故障排除方面的经历
本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》:python零基础入门学习 《python运维脚本》: python运维脚本实践 《shell》:shell学习 《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战 《k8…...
Postman 全局配置接口路径变量等
Postman 全局配置接口路径变量等 一、简介 这里主要是介绍通过配置postman接口测试工具,简化每次新增模块等接口时修改url的繁琐过程,方便以后查阅!!! 二、全局变量设置 1、新增测试环境 新增测试环境 2、接口集合设…...
一文掌握CodiMD安装与使用
简介:CodiMD 是一个基于 Markdown 语言的实时协作文档编辑器,它允许多个用户在同一个文档上进行实时编辑。CodiMD 的前身是 HackMD,但为了满足更开放的开源社区需求,CodiMD 作为其社区版本独立出来。 优势: 1. 开源且…...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作
一、上下文切换 即使单核CPU也可以进行多线程执行代码,CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短,所以CPU会不断地切换线程执行,从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...
如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...
Qemu arm操作系统开发环境
使用qemu虚拟arm硬件比较合适。 步骤如下: 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载,下载地址:https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...
通过 Ansible 在 Windows 2022 上安装 IIS Web 服务器
拓扑结构 这是一个用于通过 Ansible 部署 IIS Web 服务器的实验室拓扑。 前提条件: 在被管理的节点上安装WinRm 准备一张自签名的证书 开放防火墙入站tcp 5985 5986端口 准备自签名证书 PS C:\Users\azureuser> $cert New-SelfSignedCertificate -DnsName &…...
永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器
一、原理介绍 传统滑模观测器采用如下结构: 传统SMO中LPF会带来相位延迟和幅值衰减,并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF),可以去除高次谐波,并且不用相位补偿就可以获得一个误差较小的转子位…...
ubuntu22.04 安装docker 和docker-compose
首先你要确保没有docker环境或者使用命令删掉docker sudo apt-get remove docker docker-engine docker.io containerd runc安装docker 更新软件环境 sudo apt update sudo apt upgrade下载docker依赖和GPG 密钥 # 依赖 apt-get install ca-certificates curl gnupg lsb-rel…...
人工智能 - 在Dify、Coze、n8n、FastGPT和RAGFlow之间做出技术选型
在Dify、Coze、n8n、FastGPT和RAGFlow之间做出技术选型。这些平台各有侧重,适用场景差异显著。下面我将从核心功能定位、典型应用场景、真实体验痛点、选型决策关键点进行拆解,并提供具体场景下的推荐方案。 一、核心功能定位速览 平台核心定位技术栈亮…...
Java后端检查空条件查询
通过抛出运行异常:throw new RuntimeException("请输入查询条件!");BranchWarehouseServiceImpl.java // 查询试剂交易(入库/出库)记录Overridepublic List<BranchWarehouseTransactions> queryForReagent(Branch…...
