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/PKCS5Padding 给 algorithm 赋值。第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列操作与查询技巧

