C语言中如何避免弱加密

发布时间 - 2023-05-16 00:00:00    点击率:

1、弱加密

加密指以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的内容。常见的加密算法主要可分为:对称加密、非对称加密、单向加密。各类加密算法的使用场景不同,根据加密算法的特性如运算速度、安全性、密钥管理方式来选择合适的算法,但安全性是衡量加密算法优劣的一个重要指标,容易被破解的加密算法被称为弱加密算法,例如可以使用穷举法在有限的时间内破解des算法。本篇文章以java语言源代码为例,分析弱加密产生的原因以及修复方法。

2、 弱加密的危害

对于抗攻击性弱的加密算法,一旦被利用会造成个人隐私信息泄漏甚至财产损失。从2018年1月至2019年4月,CVE中共有2条漏洞信息与其相关。漏洞信息如下:

CVE 漏洞概况
CVE-2018-9028 CA Privileged AccessManager 2.x中传输密码时使用弱加密,降低了密码破解的复杂性。
CVE-2018-6619 在 Easy Hosting Control Panel(EHCP)v0.37.12.b通过利用无盐的弱加密算法,使攻击者更容易破解数据库密码。

3、示例代码

下面使用示例代码来源于Benchmark (https://www.owasp.org/index.php/Benchmark),源文件名:BenchmarkTest00019.java。

3.1缺陷代码

上述示例代码操作是读取请求中的内容并将其加密处理,在第49行获取读取配置文件的实例 benchmarkprops。在第50行加载配置文件,在第52行~53行读取配置文件中的属性 cryptoAlg1,若无此属性默认使用 DESede/ECB/PKCS5Paddingalgorithm 赋值。第54行将使用 algorithm 作为加密算法构造加密对象c。接下来准备加密的密码。第57~58行实例化了一个DES加密算法的密钥生成器。第59行指定加密对象 c 的操作模式为加密,其中 key 为密钥。第62行~76行对将请求中的输入流转换为字节数组input,在第77行进行对 input 进行加密,加密结果是字节数组 result 。其中使用 DES 算法生成的密钥短,仅有56位,运算速度较慢,而且DES算法完全依赖密钥,易受穷举搜索法攻击。

使用代码卫士对上述示例代码进行检测,可以检出“弱加密”缺陷,显示等级为中。在代码行第57行报出缺陷,如图1所示:

图1:弱加密的检测示例

3.2 修复代码

在上述修复代码中,第58行使用AES算法替代DES算法,AES最少可生成128位,最高256位的密钥,且运算速度快,占用内存低。

使用代码卫士对修复后的代码进行检测,可以看到已不存在“弱加密”缺陷。如图2:


图2:修复后检测结果

4、  如何避免弱加密

安全性要求较高的系统中,建议应使用安全的加密算法(如AES、RSA)对敏感数据进行加密。


# c语言  # 配置文件  # 如图  # 穷举  # 较高  # 时间内  # 不存在  # 可以看到  # 被称为  # 可以使用  # 为例 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Laravel如何处理异常和错误?(Handler示例)  如何在宝塔面板中创建新站点?  深圳网站制作平台,深圳市做网站好的公司有哪些?  Firefox Developer Edition开发者版本入口  Laravel如何实现多对多模型关联?(Eloquent教程)  Laravel Docker环境搭建教程_Laravel Sail使用指南  如何在景安服务器上快速搭建个人网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  ,怎么在广州志愿者网站注册?  Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  详解vue.js组件化开发实践  Python图片处理进阶教程_Pillow滤镜与图像增强  Laravel模型事件有哪些_Laravel Model Event生命周期详解  Laravel用户密码怎么加密_Laravel Hash门面使用教程  北京企业网站设计制作公司,北京铁路集团官方网站?  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  如何在万网开始建站?分步指南解析  Windows Hello人脸识别突然无法使用  北京网站制作公司哪家好一点,北京租房网站有哪些?  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置  HTML 中动态设置元素 name 属性的正确语法详解  如何基于PHP生成高效IDC网络公司建站源码?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解  Internet Explorer官网直接进入 IE浏览器在线体验版网址  Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  WordPress 子目录安装中正确处理脚本路径的完整指南  jquery插件bootstrapValidator表单验证详解  如何在自有机房高效搭建专业网站?  如何有效防御Web建站篡改攻击?  bing浏览器学术搜索入口_bing学术文献检索地址  如何用PHP快速搭建CMS系统?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  Laravel如何处理和验证JSON类型的数据库字段  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  IOS倒计时设置UIButton标题title的抖动问题  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel如何发送系统通知?(Notification渠道示例)  个人摄影网站制作流程,摄影爱好者都去什么网站?  JavaScript常见的五种数组去重的方式  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  Python文件流缓冲机制_IO性能解析【教程】  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧