sop/asn1

A PHP library for X.690 ASN.1 DER encoding and decoding.

Maintainers

👁 sop

Package info

github.com/sop/asn1

pkg:composer/sop/asn1

Statistics

Installs: 1 816 457

Dependents: 46

Suggesters: 0

Stars: 60

Open Issues: 4

4.1.2 2025-01-08 13:56 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT a652a5c4db949e4e1d065820aeef68c297ce404d

  • Joni Kollani <joni.kollani.woop@gmail.com>

asn1asn.1DERx690x.690


README

👁 Build Status
👁 Scrutinizer Code Quality
👁 Coverage Status
👁 License

A PHP library for X.690 Abstract Syntax Notation One (ASN.1) Distinguished Encoding Rules (DER) encoding and decoding.

Requirements

  • PHP >=7.2
  • gmp
  • mbstring

Installation

This library is available on Packagist.

composer require sop/asn1

Usage

The general idea is that each ASN.1 type has its corresponding PHP class, that knows the details of encoding and decoding the specific type.

To decode DER data, use fromDER static method of the expected type. To encode object to DER, use toDER instance method.

Many methods return an UnspecifiedType object, that works as an intermediate wrapper with accessor methods ensuring type safety.

All objects are immutable and method chaining is promoted for the fluency of the API. Exception shall be thrown on errors.

Code Examples

Here are some simple usage examples. Namespaces are omitted for brevity.

Encode

Encode a sequence containing a UTF-8 string, an integer and an explicitly tagged object identifier, conforming to the following ASN.1 specification:

Example ::= SEQUENCE {
 greeting UTF8String,
 answer INTEGER,
 type [1] EXPLICIT OBJECT IDENTIFIER
}
$seq = new Sequence(
 new UTF8String('Hello'),
 new Integer(42),
 new ExplicitlyTaggedType(
 1, new ObjectIdentifier('1.3.6.1.3'))
);
$der = $seq->toDER();

Decode

Decode DER encoding from above.

$seq = UnspecifiedType::fromDER($der)->asSequence();
$greeting = $seq->at(0)->asUTF8String()->string();
$answer = $seq->at(1)->asInteger()->intNumber();
$type = $seq->at(2)->asTagged()->asExplicit()->asObjectIdentifier()->oid();

Real-World Examples

See the following for more practical real-world usage examples.

ASN.1 References

License

This project is licensed under the MIT License.