作为一个小型(大型)业余爱好项目,我开始用 C# 制作一个(非常原始的)ssh-2.0 客户端。
这是为了探索和更好地理解 DH 并帮助加深我对加密的熟悉程度:)
根据 RFC 4253,我已经开始这样的初始连接:
(省略不相关的变量预设等)
Random cookie_gen = new Random();
while ((ssh_response = unsecure_reader.ReadLine()) != null)
{
MessageBox.Show(ssh_response);
if (ssh_response.StartsWith("SSH-2.0-")
{
// you told me your name, now I'll tell you mine
ssh_writer.Write("SSH-2.0-MYSSHCLIENT\r\n");
ssh_writer.Flush();
// now I should write up my supported (which I'll keep to the required as per rfc 4253)
ssh_writer.Write(0x20); // SSH_MSG_KEXINIT
byte[] cookie = new byte[16];
for (int i = 0; i < 16; i++)
cookie[i] = Convert.ToByte(cookie_gen.Next(0, 10));
ssh_writer.Write(cookie); // cookie
// and now for the name-list
// This is where I'm troubled
// "Footer"
ssh_writer.Write(0x00); // first_kex_packet_follows
ssh_writer.Write(0x00); // 0
ssh_writer.Flush();
}
}
正如您在 RFC 4253 第 16 页上看到的,我预计会提供 10 个名单。这些是否只是假设为字符串,或者如何标记每个列表的开始/结束(仅通过换行符\n)?我在正确的轨道上吗? (请记住,在此之后我将处理 DH 和加密。我的问题仅基于迄今为止的初步接触)。
欢迎和赞赏任何帮助或意见,
PS:我知道存在库,但这与我的项目无关。
正如 RFC 4251 第 9 页所述:
不得使用终止空字符,也不得使用
对于单个名称,也不对于整个列表。
命名的 RFC 中也有示例。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)