C知道精选 换一换
openssl使用gcm模式解密,iv12字节,c实现
为了使用openssl库中的GCM模式解密,需要使用以下代码: ```c #include <openssl/conf.h> #include <openssl/evp.h> #include <openssl/err.h> int DecryptGCM(unsigned char *ciphertext, int ciphertext_len, unsigned char *aad, int aad_len, unsigned char *key, unsigned char *iv, int iv_len, unsigned char *plaintext) { EVP_CIPHER_CTX *ctx; int len; int plaintext_len; int ret; /* Create and initialise the context */ if(!(ctx = EVP_CIPHER_CTX_new())) return -1; /* Initialise the decryption operation using GCM mode */ if(1 != EVP_DecryptInit_ex(ctx, EVP_aes_128_gcm(), NULL, NULL, NULL)) return -1; /* Set IV length */ if(1 != EVP_CIPHER_CTX_ctrl(ctx, EVP_CTRL_GCM_SET_IVLEN, iv_len, NULL)) return -1; /* Initialise key and IV */ if(1 != EVP_DecryptInit_ex(ctx, NULL, NULL, key, iv)) return -1; /* Provide any associated data */ if(aad_len > 0) { if(1 != EVP_DecryptUpdate(ctx, NULL, &len, aad, aad_len)) return -1; } /* Decrypt ciphertext */ if(1 != EVP_DecryptUpdate(ctx, plaintext, &len, ciphertext, ciphertext_len)) return -1; plaintext_len = len; /* Set expected tag value */ if(1 != EVP_CIPHER_CTX_ctrl(ctx, EVP_CTRL_GCM_SET_TAG, 16, ciphertext + ciphertext_len)) return -1; /* Finalise the decryption */ ret = EVP_DecryptFinal_ex(ctx, plaintext + len, &len); /* Clean up */ EVP_CIPHER_CTX_free(ctx); if(ret > 0) plaintext_len += len; else return -1; return plaintext_len; } ``` 其中,参数ciphertext是要解密的数据,ciphertext_len是密文的长度,aad是associated data,aad_len是associated data的长度,key是密钥,iv是初始向量,iv_len是初始向量的长度,plaintext是解密后的明文。 例如,要解密一个长度为ciphertext_len的加密后的消息,可以使用以下代码: ```c unsigned char ciphertext[ciphertext_len]; /* 加密后的消息 */ unsigned char *aad = NULL; /* associated data */ int aad_len = 0; /* associated data的长度 */ unsigned char key[16]; /* 密钥 */ unsigned char iv[12]; /* 初始向量 */ unsigned char plaintext[ciphertext_len]; int plaintext_len = DecryptGCM(ciphertext, ciphertext_len, aad, aad_len, key, iv, 12, plaintext); if(plaintext_len < 0) { /* 解密失败 */ } else { /* 解密成功 */ } ``` 需要注意的是,当解密失败时,DecryptGCM函数会返回一个负数。如果解密成功,函数会返回解密后的明文的长度(即plaintext_len)。 希望这个回答可以帮助你解决问题!
查看
精选课程 更多
Java实战之Redis入门到精通
简介:本门课程主要讲解的是缓存中间件Redis常见且典型的数据结构、相关的核心技术栈及其典型的应用场景的实战,其中涉及到的相关代码实战主要是基于SpringBoot2.x搭建的项目进行实战实现的! 其中的数据结构就包括:字符串String/列表List/集合Set/有序集合SortedSet/哈希Hash以及Key的过期失效等等,在课程的最后还介绍了“点赞系统中点赞功能模块的设计与实现”,可以说是拒绝纸上谈兵、注重实战并学以致用,课程的大纲如下所示: 下面贴一贴本课程重点介绍的数据结构及其典型的应用场景吧(完整的请参考课程的目录),见下面的大图: 其中,“点赞功能模块的设计与实战实现”可以说是本门课程的核心重点与高潮!如下几张图所示即为点赞功能模块所拆分出来的诸多详细的功能流程图: 掌握本门课程相关的技术要点之后,debug相信各位小伙伴在面试以及实际项目实战开发过程中将能带来大大的帮助.... 其他相关的核心功能在这里就不一 一详细介绍了....还等什么呢,此时不学习redis,更待何时呀!!!
钟林森 开发组长/高级工程师
超级会员 ¥ 69.00 ¥69.00 8384观看
Java实战之Spring Boot入门到精通
内容简介: 本课程主要是从最基础的技术要点一步一个脚印的介绍Spring Boot2.0相关的核心技术栈,包括如何基于Spring Boot2.0搭建一个企业级的多模块项目、整合Spring MVC和Mybatis实现项目中功能模块的CRUD,校验器Validator、Lombok、动态配置参数、开发环境切换、全局异常处理、定时任务、多线程、热加载、发送邮件、上传下载文件、多数据源等核心干货,为各位小伙伴提供企业级项目开发中常见且典型的核心技术! 其课程大纲如下所示: 在课程的最后,我们介绍并实战了一个典型的应用场景:“用户注册”,主要是将前面章节介绍的内容融入到一个完整的功能模块中,做到学以致用!其完整的功能流程图如下图所示: 基本要求: 1、基本要求:具备一定的JavaSE以及Java Web项目的开发基础、了解spring boot更佳 2、工具要求:会使用Intellij IDEA 、Navicat 以及 Postman
钟林森 开发组长/高级工程师
超级会员 ¥ 99.00 ¥99.00 1.4w+观看
从零开始自然语言处理
本课程隶属于自然语言处理(NLP)实战系列。自然语言处理(NLP)是数据科学里的一个分支,它的主要覆盖的内容是:以一种智能与高效的方式,对文本数据进行系统化分析、理解与信息提取的过程。通过使用NLP以及它的组件,我们可以管理非常大块的文本数据,或者执行大量的自动化任务,并且解决各式各样的问题,如自动摘要,机器翻译,命名实体识别,关系提取,情感分析,语音识别,以及主题分割等等。 一般情况下一个初级NLP工程师的工资从15万-35万不等,所以掌握NLP技术,对于人工智能学习者来讲是非常关键的一个环节。 【超实用课程内容】 课程从自然语言处理的基本概念与基本任务出发,对目前主流的自然语言处理应用进行全面细致的讲解,包括文本分类,文本摘要提取,文本相似度,文本情感分析,文本特征提取等,同时算法方面包括经典算法与深度学习算法的结合,例如LSTM,BiLSTM等,并结合京东电商评论分类、豆瓣电影摘要提取、今日头条舆情挖掘、饿了么情感分析等过个案例,帮助大家熟悉自然语言处理工程师在工作中会接触到的常见应用的实施的基本实施流程,从0-1入门变成自然语言处理研发工程师。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/25649 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/25649,点击右下方课程资料、代码、课件等打包下载 通过第二课时下载材料
钱兴会 CTO/CIO/技术副总裁/总工程师
超级会员 ¥ 199.00 ¥199.00 1w+观看
iOS动态库注入
本课程主要针对iOS动态库注入技术做了详细讲解和实战演示,分为技术篇和运维篇,最终目标是将动态库注入到目标ipa包中,并且执行动态库中的代码,实现动态库与ipa交互。 技术篇&nbsp;-&nbsp;主要从基础知识、涉及工具,以及一个完整的手动注入实例流程来讲解,面向技术开发人员; 运维篇&nbsp;-&nbsp;通过利用自动注入工具、重签名工具来可视化的注入动态库,面向运维等非技术人员; 课程目录 课程简介 1,课程目标和大纲 技术篇 2,基础知识&nbsp;-&nbsp;动态库 3,基础知识&nbsp;-&nbsp;IPA包 4,基础知识&nbsp;-&nbsp;Mach-O 5,基础知识&nbsp;-&nbsp;代码注入 6,基础知识&nbsp;-&nbsp;重签名 7,涉及工具&nbsp;-&nbsp;Xcode/iOSOpenDev/Terminal 8,涉及工具&nbsp;-&nbsp;yololib/MachOView/iFunBox/iReSign 9,实例演示&nbsp;-&nbsp;创建.dylib动态库 10,实例演示&nbsp;-&nbsp;创建测试APP 11,实例演示&nbsp;-&nbsp;手动注入动态库(开发模式) 12,实例演示&nbsp;-&nbsp;手动注入动态库(重签名模式) 运维篇 13,运维篇&nbsp;-&nbsp;准备工作 14,运维篇&nbsp;-&nbsp;实战演示 15,运维篇&nbsp;-&nbsp;技术支持 课程总结 16,课程总结
王明敏 CEO/董事长/总经理
超级会员 ¥ 69.00 ¥69.00 2093观看
【鸿蒙项目实战】基于鸿蒙服务卡片的分布式游戏:找我
本课程将以一个鸿蒙(HarmonyOS)App作为基础讲解如何使用Java开发鸿蒙App。这个App是一个基于鸿蒙服务卡片的游戏,类似“连连看”。这款游戏涉及到的技术如下: &nbsp; 1. 组件的使用(Button、Text、ListContainer) 2. 服务卡片的基本使用方法 3. 服务卡片之间的交互 4. FA(Page Ability的使用方法) 5. FA的流转 6. 获取设备列表 7. 数据库技术 8. 网络技术 9. 多线程技术 10. 国际化 &nbsp; &nbsp; &nbsp;
李宁 技术总监/研发总监
超级会员 ¥ 128.00 ¥128.00 2781观看
Android 10.0 根文件系统和编译系统
1, 讲解android根文件系统结构和组成 2, 讲解android系统镜像的概念和拆包 3, 讲解Android系统源码结构 4, 讲解Android系统编译规则 5, 讲解Android系统ADB使用和Log日志调试方法 6, 讲解Android系统Android.mk和Android.bp是各种规则 &nbsp;
旗浩 系统开发
¥ 458.00 ¥458.00 2214观看
优质内容专辑 更多
微信小程序源码合集
微信小程序,简称小程序,英文名Mini Program,是一种不需要下载安装即可使用的应用,它实现了应用"触手可及"的梦想,用户扫一扫或搜一下即可打开应用。 不懂开发,怎样可以拥有一个属于自己的小程序?二次开发,想要基于某个小程序框架实例练手? 本期专题收集8个小程序源码资源,包含交友互动、答题、商城、教育等超多行业,其中像【微信小程序商城源码】资源中除了包含小程序的商品浏览,商品详情,微信授权登录,微信支付等功能,还有后台管理系统,服务后端可进行商品及订单的管理,包含上架、下架、公告,发货等功能。 现在一键打包下载仅需【¥9.9】,开通会员更能免费下载,超多会员专属福利等你解锁。
浏览 · 12.6w+ 下载 · 1w+
Python爬虫经典案例合集
网络爬虫(又称为网页蜘蛛,网络机器人)就是模拟浏览器发送网络请求,接收请求响应,按照一定的规则,自动地抓取万维网信息的程序或者脚本。 不精通python,怎样快速入门python爬虫、学好爬虫技能?“小白”如何让自己在爬虫道路上少走弯路,实现弯道超车? 本期专题收录8个python爬虫经典案例,内容包含新浪微博、招聘网站、天气预报、股票评论、豆瓣电影等经典实例,其中【python新浪微博爬虫,爬取微博和用户信息】资源中不仅包含爬取微博用户的基本信息,还包含数据可视化分析代码,让你从零开始快速学会简单的Python网络爬虫,实现数据的采集与分析。
浏览 · 10.2w+ 下载 · 5865
java游戏源码经典合集
作为编程语言界的常青藤Java,无论是在企业级应用,还是后端开发中,均有着无可替代的地位。而对于Java的入门,很多新手们不可避免的会走一些弯道。那么,如何才能有效地避开这些误区?如何快速实践? 本期专题收录了8个java游戏源码经典资源,以迭代重构的方式构建游戏基本雏形,在游戏中掌握java语言的表达魅力。其中【java源码包---java 源码 大量 实例】通过多个游戏开发实战案例,讲解游戏开发中的热点技术知识,带领初学者走进Java,从实现玩家功能到运行测试游戏,手把手教你玩转小游戏开发,不知不觉中提高Java编程能力。
浏览 · 11.1w+ 下载 · 1.3w+
微信小程序商城源码合集
微信小程序是一种无需下载安装即可使用的应用,能以最低的成本触达用户。掌握了微信小程序开发技术,等同于打通了手机应用开发蓝海的出海口! 零基础新手如何快速入门微信小程序开发?如何拥有自己的微信小程序商城? 本期专题整理了8个微信小程序商城源码资源,包含从开发账号注册、开发工具安装、小程序开发到发布的全过程。其中【CSDN最全面的微信小程序源码和模板】提供的上百个微信小程序商城开发源码不仅可以实现小程序的商品浏览,商品详情,微信授权登录,微信支付等功能,还有后台管理系统,服务后端可进行商品及订单的管理,包含上架、下架、公告,发货等功能,手把手带你理解小程序的基本架构和开发手法,让你在开发路上少走弯路。
浏览 · 2.5w+ 下载 · 1050
上传资源 快速赚钱
voice
center-task 前往需求广场,查看用户热搜