Merge branch '2.0' into 3.0

This commit is contained in:
terrafrost 2024-02-24 13:23:11 -06:00
commit 0192fcc4aa
3 changed files with 18 additions and 0 deletions

View File

@ -1148,6 +1148,11 @@ abstract class ASN1
$oid = [];
$pos = 0;
$len = strlen($content);
// see https://github.com/openjdk/jdk/blob/2deb318c9f047ec5a4b160d66a4b52f93688ec42/src/java.base/share/classes/sun/security/util/ObjectIdentifier.java#L55
if ($len > 4096) {
//user_error('Object Identifier size is limited to 4096 bytes');
return false;
}
if (ord($content[$len - 1]) & 0x80) {
return false;

Binary file not shown.

View File

@ -450,4 +450,17 @@ class ASN1Test extends PhpseclibTestCase
$decoded = ASN1::decodeBER($em);
$this->assertNull($decoded);
}
public function testLongOID()
{
$cert = file_get_contents(dirname(__FILE__) . '/ASN1/mal-cert-02.der');
$asn1 = new ASN1();
//$this->setExpectedException('PHPUnit_Framework_Error_Notice');
$decoded = $asn1->decodeBER($cert);
$this->assertFalse($decoded[0]);
//$x509 = new X509();
//$x509->loadX509($cert);
}
}