
本文深入探讨ssh公钥的格式校验,强调支持多种密钥算法(如ed25519、rsa、ecdsa等)的重要性。文章详细解析了ssh公钥的结构,并提供了一个功能全面的正则表达式,用于验证公钥的算法类型、base64编码主体及可选注释。同时,本文还涵盖了如何在php等环境中正确应用此正则表达式,并提出了进一步的安全性考虑。
SSH公钥是用于身份验证的关键组成部分,其基本结构通常遵循以下模式:
[算法类型] [Base64编码的密钥数据] [可选注释]
例如:
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC... user@example.com
其中:
在SSH密钥的实践中,推荐支持多种密钥算法,而非仅限于旧的RSA算法。目前,一些常见的、被广泛支持和推荐的算法包括:
您可以通过在终端运行 ssh -Q key 命令来查看您的SSH客户端当前支持的密钥算法列表。为了确保兼容性和安全性,在进行公钥校验时,应考虑支持这些主流算法。
为了有效验证SSH公钥的格式,我们需要构建一个能够识别上述结构并兼容多种算法的正则表达式。在PHP等语言中使用正则表达式时,需要注意选择合适的定界符,以避免与正则表达式内部字符(如 /)冲突。
以下是一个推荐的、功能健壮的SSH公钥校验正则表达式:
/^ssh-(ed25519|rsa|dss|ecdsa) AAAA(?:[A-Za-z0-9+\/]{4})*(?:[A-Za-z0-9+\/]{2}==|[A-Za-z0-9+\/]{3}=|[A-Za-z0-9+\/]{4})( [^@]+@[^@]+)?$/让我们分解这个正则表达式的各个部分:
在PHP中,由于正则表达式中包含 / 字符,为了避免与 preg_match 函数的默认定界符 / 冲突,我们通常会选择其他字符作为定界符,例如 # 或 ~。
<?php
function validateSshPublicKey(string $publicKey): bool
{
// 使用 # 作为定界符,避免与正则表达式内部的 / 冲突
$pattern = '#^ssh-(ed25519|rsa|dss|ecdsa) AAAA(?:[A-Za-z0-9+\/]{4})*(?:[A-Za-z0-9+\/]{2}==|[A-Za-z0-9+\/]{3}=|[A-Za-z0-9+\/]{4})( [^@]+@[^@]+)?$#';
return (bool) preg_match($pattern, $publicKey);
}
// 示例公钥
$validKey1 = 'ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC... user@example.com';
$validKey2 = 'ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIC...'; // 没有注释的ed25519密钥
$invalidKey1 = 'ssh-rsa AAAAinvalidkey'; // Base64格式错误
$invalidKey2 = 'invalid-algo AAAAB3NzaC1yc2EAAAADAQABAAABAQC...'; // 算法类型错误
$invalidKey3 = 'ssh-rsa AAAAthis/is/a/test=='; // 假设这是一个有效的Base64编码,但缺少完整的结构
echo "Valid Key 1: " . (validateSshPublicKey($validKey1) ? 'Valid' : 'Invalid') . "\n";
echo "Valid Key 2: " . (validateSshPublicKey($validKey2) ? 'Valid' : 'Invalid') . "\n";
echo "Invalid Key 1: " . (validateSshPublicKey($invalidKey1) ? 'Valid' : 'Invalid') . "\n";
echo "Invalid Key 2: " . (validateSshPublicKey($invalidKey2) ? 'Valid' : 'Invalid') . "\n";
echo "Invalid Key 3: " . (validateSshPublicKey($invalidKey3) ? 'Valid' : 'Invalid') . "\n";
?>
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号