mirror of
https://github.com/phpseclib/phpseclib.git
synced 2024-12-31 21:21:55 +00:00
PKCS8: fix public private checks for human readable keys
This commit is contained in:
parent
aff0e68f54
commit
0f6e1c2218
@ -315,11 +315,15 @@ abstract class PKCS8 extends PKCS
|
|||||||
*/
|
*/
|
||||||
protected static function load($key, $password = '')
|
protected static function load($key, $password = '')
|
||||||
{
|
{
|
||||||
$decoded = self::preParse($key);
|
if (!Strings::is_stringable($key)) {
|
||||||
|
throw new \UnexpectedValueException('Key should be a string - not a ' . gettype($key));
|
||||||
|
}
|
||||||
|
|
||||||
$isPublic = strpos($key, 'PUBLIC') !== false;
|
$isPublic = strpos($key, 'PUBLIC') !== false;
|
||||||
$isPrivate = strpos($key, 'PRIVATE') !== false;
|
$isPrivate = strpos($key, 'PRIVATE') !== false;
|
||||||
|
|
||||||
|
$decoded = self::preParse($key);
|
||||||
|
|
||||||
$meta = [];
|
$meta = [];
|
||||||
|
|
||||||
$decrypted = ASN1::asn1map($decoded[0], Maps\EncryptedPrivateKeyInfo::MAP);
|
$decrypted = ASN1::asn1map($decoded[0], Maps\EncryptedPrivateKeyInfo::MAP);
|
||||||
@ -661,10 +665,6 @@ abstract class PKCS8 extends PKCS
|
|||||||
{
|
{
|
||||||
self::initialize_static_variables();
|
self::initialize_static_variables();
|
||||||
|
|
||||||
if (!Strings::is_stringable($key)) {
|
|
||||||
throw new \UnexpectedValueException('Key should be a string - not a ' . gettype($key));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (self::$format != self::MODE_DER) {
|
if (self::$format != self::MODE_DER) {
|
||||||
$decoded = ASN1::extractBER($key);
|
$decoded = ASN1::extractBER($key);
|
||||||
if ($decoded !== false) {
|
if ($decoded !== false) {
|
||||||
@ -690,6 +690,10 @@ abstract class PKCS8 extends PKCS
|
|||||||
*/
|
*/
|
||||||
public static function extractEncryptionAlgorithm($key)
|
public static function extractEncryptionAlgorithm($key)
|
||||||
{
|
{
|
||||||
|
if (!Strings::is_stringable($key)) {
|
||||||
|
throw new \UnexpectedValueException('Key should be a string - not a ' . gettype($key));
|
||||||
|
}
|
||||||
|
|
||||||
$decoded = self::preParse($key);
|
$decoded = self::preParse($key);
|
||||||
|
|
||||||
$r = ASN1::asn1map($decoded[0], ASN1\Maps\EncryptedPrivateKeyInfo::MAP);
|
$r = ASN1::asn1map($decoded[0], ASN1\Maps\EncryptedPrivateKeyInfo::MAP);
|
||||||
|
@ -678,4 +678,16 @@ MIIEDwIBADATBgcqhkjOPQIBBggqhkjOPQMBBwSCA/MwggPvAgEBBIID6P//////
|
|||||||
$key = PublicKeyLoader::load($key);
|
$key = PublicKeyLoader::load($key);
|
||||||
$this->assertInstanceOf(PublicKey::class, $key);
|
$this->assertInstanceOf(PublicKey::class, $key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testMislabledPKCS8PubKey()
|
||||||
|
{
|
||||||
|
$this->expectException('\phpseclib3\Exception\NoKeyLoadedException');
|
||||||
|
|
||||||
|
$key = '-----BEGIN PRIVATE KEY-----
|
||||||
|
MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAErPJyxEu2/oKCrJaaTVTrq39DKJ2X
|
||||||
|
cN6W+k8UvGf+Y/lDWNbFitQocabsDUvSN0edHH3UKP5QPTz4cOlyIPMrXQ==
|
||||||
|
-----END PUBLIC KEY-----';
|
||||||
|
$key = PublicKeyLoader::load($key);
|
||||||
|
$this->assertInstanceOf(PublicKey::class, $key);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user