mirror of
https://github.com/danog/phpseclib.git
synced 2025-01-22 04:51:19 +01:00
Merge branch 'master' into php5
* master: ASN1: fix unit test ASN1: add unit test for non-constructed context-specific change ASN1: fix issue with non-constructed context-specific tags README: update download link to 0.3.8
This commit is contained in:
commit
eff5f64560
@ -6,7 +6,7 @@ MIT-licensed pure-PHP implementations of an arbitrary-precision integer
|
|||||||
arithmetic library, fully PKCS#1 (v2.1) compliant RSA, DES, 3DES, RC4, Rijndael,
|
arithmetic library, fully PKCS#1 (v2.1) compliant RSA, DES, 3DES, RC4, Rijndael,
|
||||||
AES, Blowfish, Twofish, SSH-1, SSH-2, SFTP, and X.509
|
AES, Blowfish, Twofish, SSH-1, SSH-2, SFTP, and X.509
|
||||||
|
|
||||||
* [Download (0.3.7)](http://sourceforge.net/projects/phpseclib/files/phpseclib0.3.7.zip/download)
|
* [Download (0.3.8)](http://sourceforge.net/projects/phpseclib/files/phpseclib0.3.8.zip/download)
|
||||||
* [Browse Git](https://github.com/phpseclib/phpseclib)
|
* [Browse Git](https://github.com/phpseclib/phpseclib)
|
||||||
* [Code Coverage Report](http://phpseclib.bantux.org/code_coverage/php5/latest/)
|
* [Code Coverage Report](http://phpseclib.bantux.org/code_coverage/php5/latest/)
|
||||||
|
|
||||||
|
@ -333,19 +333,24 @@ class File_ASN1
|
|||||||
case FILE_ASN1_CLASS_APPLICATION:
|
case FILE_ASN1_CLASS_APPLICATION:
|
||||||
case FILE_ASN1_CLASS_PRIVATE:
|
case FILE_ASN1_CLASS_PRIVATE:
|
||||||
case FILE_ASN1_CLASS_CONTEXT_SPECIFIC:
|
case FILE_ASN1_CLASS_CONTEXT_SPECIFIC:
|
||||||
|
if ($constructed) {
|
||||||
$newcontent = $this->_decode_ber($content, $start);
|
$newcontent = $this->_decode_ber($content, $start);
|
||||||
$length = $newcontent['length'];
|
$length = $newcontent['length'];
|
||||||
if (substr($content, $length, 2) == "\0\0") {
|
if (substr($content, $length, 2) == "\0\0") {
|
||||||
$length+= 2;
|
$length+= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// the array encapsulation is for BC with the old format
|
||||||
|
$content = array($newcontent);
|
||||||
|
}
|
||||||
|
|
||||||
$start+= $length;
|
$start+= $length;
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'type' => $class,
|
'type' => $class,
|
||||||
'constant' => $tag,
|
'constant' => $tag,
|
||||||
// the array encapsulation is for BC with the old format
|
// the array encapsulation is for BC with the old format
|
||||||
'content' => array($newcontent),
|
'content' => $content,
|
||||||
// the only time when $content['headerlength'] isn't defined is when the length is indefinite.
|
// the only time when $content['headerlength'] isn't defined is when the length is indefinite.
|
||||||
// the absence of $content['headerlength'] is how we know if something is indefinite or not.
|
// the absence of $content['headerlength'] is how we know if something is indefinite or not.
|
||||||
// technically, it could be defined to be 2 and then another indicator could be used but whatever.
|
// technically, it could be defined to be 2 and then another indicator could be used but whatever.
|
||||||
|
@ -268,4 +268,14 @@ class Unit_File_ASN1Test extends PhpseclibTestCase
|
|||||||
$decoded = $asn1->decodeBER(base64_decode($str));
|
$decoded = $asn1->decodeBER(base64_decode($str));
|
||||||
$this->assertCount(3, $decoded[0]['content']);
|
$this->assertCount(3, $decoded[0]['content']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group github477
|
||||||
|
*/
|
||||||
|
public function testContextSpecificNonConstructed()
|
||||||
|
{
|
||||||
|
$asn1 = new File_ASN1();
|
||||||
|
$decoded = $asn1->decodeBER(base64_decode('MBaAFJtUo7c00HsI5EPZ4bkICfkOY2Pv'));
|
||||||
|
$this->assertInternalType('string', $decoded[0]['content'][0]['content']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user