也想出现在这里? 联系我们

SILC 客户端以及服务器密钥协商远程整数溢出漏洞

作者 : 小编 本文共1784个字,预计阅读时间需要5分钟 发布时间: 2021-06-17 共5.24K人阅读
也想出现在这里? 联系我们

受影响系统:

SILC server <= 1.1.1

SILC client <= 1.1.3

不受影响系统:

SILC server 1.1.2

SILC client 1.1.4

描述:

SILC(Secure Internet Live Conferencing)是安全的互联网会议讨论系统,可以发送任何类型的信息,包括多媒体信息,如视频、音频、图像等。

SILC处理畸形的数据交换时存在漏洞,远程攻击者可能利用此漏洞控制服务器。

如果要初始连接到SILC服务器,对等端(客户端、路由器和服务器)之间要执行相互认证并执行密钥协商协议以获得之后用于加密通讯的共享密钥。对等端之间的加密数据是通过以PKCS#1 1.5标准编码的报文交换的。

SILC的PKCS1编码功能是在silcpkcs1.c文件的silccrypt库中实现的,用于解码PKCS#1报文的代码在silc_pkcs1_decode函数中实现,如下所示:

/———–

SilcBool silc_pkcs1_decode(SilcPkcs1BlockType bt,

const unsigned char *data,

SilcUInt32 data_len,

unsigned char *dest_data,

SilcUInt32 dest_data_size,

SilcUInt32 *dest_len)

{

int i = 0;

SILC_LOG_DEBUG(("PKCS#1 decoding, bt %d", bt));

/* Sanity checks */

if (!data || !dest_data || dest_data_size < 3 ||

data[0] != 0x00 || data[1] != (unsigned char)bt) {

SILC_LOG_DEBUG(("Malformed block"));

return FALSE;

}

/* Decode according to block type */

switch (bt) {

case SILC_PKCS1_BT_PRV0:

/* Do nothing */

break;

case SILC_PKCS1_BT_PRV1:

/* Verification */

(1) for (i = 2; i < data_len; i )

if (data[i] != 0xff)

break;

break;

case SILC_PKCS1_BT_PUB:

/* Decryption */

(2) for (i = 2; i < data_len; i )

if (data[i] == 0x00)

break;

break;

}

/* Sanity checks */

(3) if (data[i ] != 0x00) {

SILC_LOG_DEBUG(("Malformed block"));

return FALSE;

}

if (i – 1 < SILC_PKCS1_MIN_PADDING) {

SILC_LOG_DEBUG(("Malformed block"));

return FALSE;

}

if (dest_data_size < data_len – i) {

SILC_LOG_DEBUG(("Destination buffer too small"));

return FALSE;

}

/* Copy the data */

(4) memcpy(dest_data, data i, data_len – i);

/* Return data length */

if (dest_len)

*dest_len = data_len – i;

return TRUE;

}

– ———–/

在上面的代码中,如果在传输私有(BT_PRIV1)或公开(BT_PUB)密钥材料时有效PKCS#1编码的恶意伪造报文所有位分别设置为0xff或非0x00的话,就会导致执行流在(1)和(2)退出循环,无符整数变量i设置为data_len,然后在(3)同一变量i以1递增,因此设置为data_len 1。在(3)传送过滤检查的特制报文最终会由于在(4)处memcpy()函数中传送的第三个参数中的整数溢出而导致内存破坏。由于i设置为了datalen 1,用于计算第三个参数值的data_len – i表达式会为-1,导致由于符号转换错误而覆盖进程内存。成功利用这个漏洞会导致程序拒绝服务,或以SILC程序的权限执行任意指令。

厂商补丁:

目前厂商已经发布了升级补丁以修复这个安全问题,请到厂商的主页下载:

http://silcnet.org/software/download/

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » SILC 客户端以及服务器密钥协商远程整数溢出漏洞

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录