Drivers License Barcode Data Average ratng: 4,0/5 1849 votes

Keys for obtaining US Driver's license data

Standard for US Driver's Licenses defines 9 different barcode standards (AAMVA versions) with over 80 different fields encoded inside a barcode. Some fields exist on all barcode standards, other exist only on some. To standardize the API, we have structured the fields in the following sections:

With the AirTrack S2 scanner you can scan the code on the back of a driver’s licenses from any state to verify someone’s age quickly and accurately due to the scanner’s ability to parse all the data correctly for you. Florida’s new driver license and ID card incorporates nearly double the fraud protection measures compared to the previous design and is the most secure over-the-counter driver license and ID card available today. The new security features make it highly difficult for criminals to alter or counterfeit credentials.

  1. Keys existing on all barcode versions
    • Mandatory values
    • Optional values
  2. Keys existing on some barcode versions
    • Mandatory values
    • Optional values

Determining AAMVA version

  • kPPAamvaVersionNumber (string value 'kPPAamvaVersionNumber') - Mandatory on all AAMVA driver's license versions. Specifies the version level of the PDF417 bar code format. Possible values are '0', '1', '2', '3', '4', '5', '6', '7', '8', and 'Compact'.

Keys existing on all standard barcode versions

Scanning Drivers License Barcode

Mandatory values

Personal data

  • kPPCustomerFamilyName (string value 'kPPCustomerFamilyName') - Family name of the cardholder.
    • Mandatory on all barcode versions, including compact encoding.
  • kPPCustomerFirstName (string value 'kPPCustomerFirstName') - First name of the cardholder.
    • Mandatory on all barcode versions, including compact encoding.
  • kPPDateOfBirth (string value 'kPPDateOfBirth') - Date on which the cardholder was born. (MMDDCCYY format).
    • Mandatory on all barcode versions, including compact encoding.
  • kPPSex (string value 'kPPSex') - Gender of the cardholder.
    • Mandatory on all barcode versions, including compact encoding.
    • 1 = male,
    • 2 = female.
  • kPPEyeColor (string value 'kPPEyeColor') - Color of cardholder's eyes.
    • Mandatory on all barcode versions, including compact encoding. (ANSI D-20 codes)
    • BLK = Black
    • BLU = Blue
    • BRO = Brown
    • GRY = Gray
    • GRN = Green
    • HAZ = Hazel
    • MAR = Maroon
    • PNK = Pink
    • DIC = Dichromatic
    • UNK = Unknown
  • kPPHeight (string value 'kPPHeight') - Height of cardholder. Possible values are either in inches or in centimeters.
    • Mandatory on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact encoding. Optional on 01.
    • See also kPPHeightIn, kPPHeightCm
    • Inches (in): number of inches followed by ' in' or ' IN'. Example. 6'1' = '073 in'
    • Centimeters (cm): number of centimeters followed by ' cm' or ' CM'. Example. 181 centimeters = '181 cm'
  • kPPAddressStreet (string value 'kPPAddressStreet') - Street portion of the cardholder address. The place where the registered driver of a vehicle (individual or corporation) may be contacted such as a house number, street address etc.
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, where you must use kPPFullAddress.
  • kPPAddressCity (string value 'kPPAddressCity') - City portion of the cardholder address.
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, where you must use kPPFullAddress.
  • kPPAddressJurisdictionCode (string value 'kPPAddressJurisdictionCode') - State portion of the cardholder address.
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, where you must use kPPFullAddress.
  • kPPAddressPostalCode (string value 'kPPAddressPostalCode') - Postal code portion of the cardholder address in the U.S. and Canada. If the trailing portion of the postal code in the U.S. is not known, zeros will be used to fill the trailing set of numbers up to nine (9) digits.
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, where you must use kPPFullAddress.

California Driver's License Barcode Format

License data

  • kPPDocumentIssueDate (string value 'kPPDocumentIssueDate') - Date on which the document was issued. (MMDDCCYY format).
    • Mandatory on all barcode versions, including compact encoding.
  • kPPDocumentExpirationDate (string value 'kPPDocumentExpirationDate') - Date on which the driving and identification privileges granted by the document areno longer valid. (MMDDCCYY format).
    • Mandatory on all barcode versions, including compact encoding.
  • kPPIssuerIdentificationNumber (string value 'kPPIssuerIdentificationNumber') - This number uniquely identifies the issuing jurisdiction and canbe obtained by contacting the ISO Issuing Authority (AAMVA).
    • Mandatory on all standard barcode formats, optional on compact encoding.
  • kPPJurisdictionVersionNumber (string value 'kPPJurisdictionVersionNumber') - Jurisdiction Version Number: This is a number value between '0' and '99' thatspecifies the jurisdiction version level of the PDF417 bar code format.
    • Mandatory on all barcode versions, including compact encoding.
  • kPPJurisdictionVehicleClass (string value 'kPPJurisdictionVehicleClass') - Jurisdiction-specific vehicle class / group code, designating the typeof vehicle the cardholder has privilege to drive.
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, which has no compatible field.
  • kPPJurisdictionRestrictionCodes (string value 'kPPJurisdictionRestrictionCodes') - Jurisdiction-specific codes that represent restrictions to drivingprivileges (such as airbrakes, automatic transmission, daylight only, etc.).
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, which has no compatible field.
  • kPPJurisdictionEndorsementCodes (string value 'kPPJurisdictionEndorsementCodes') - Jurisdiction-specific codes that represent additional privilegesgranted to the cardholder beyond the vehicle class (such as transportation ofpassengers, hazardous materials, operation of motorcycles, etc.).
    • Mandatory on all standard barcode versions. Not defined on Compact encoding, which has no compatible field.
  • kPPCustomerIdNumber (string value 'kPPCustomerIdNumber') - The number assigned or calculated by the issuing authority.
    • Mandatory on all barcode versions, including compact encoding.

Optional values

Driver's License Barcode Data Requirements

Personal data

  • kPPHairColor (string value 'kPPHairColor') - Bald, black, blonde, brown, gray, red/auburn, sandy, white, unknown. If the issuingjurisdiction wishes to abbreviate colors, the three-character codes provided in ANSI D20 must beused.

    • Optional on all barcode versions, including compact encoding.
    • BAL = Bald
    • BLK = Black
    • BLN = Blond
    • BRO = Brown
    • GRY = Grey
    • RED = Red/Auburn
    • SDY = Sandy
    • WHI = White
    • UNK = Unknown
  • kPPNameSuffix (string value 'kPPNameSuffix') - Name Suffix (If jurisdiction participates in systems requiring name suffix (PDPS, CDLIS, etc.), the suffix must be collected and displayed on the DL/ID).

    • Optional on all barcode versions, including compact encoding.
    • JR (Junior)
    • SR (Senior)
    • 1ST or I (First)
    • 2ND or II (Second)
    • 3RD or III (Third)
    • 4TH or IV (Fourth)
    • 5TH or V (Fifth)
    • 6TH or VI (Sixth)
    • 7TH or VII (Seventh)
    • 8TH or VIII (Eighth)
    • 9TH or IX (Ninth).
  • kPPAddressStreet2 (string value 'kPPAddressStreet2') - Second line of street portion of the cardholder address.

    • Optional on all standard barcode versions. Not defined on Compact encoding, where you must use kPPFullAddress.

License data

  • kPPIssuingJurisdiction (string value 'kPPIssuingJurisdiction') - Jurisdictions may define a subfile to contain jurisdiction-specific information.These subfiles are designated with the first character of “Z” and the secondcharacter is the first letter of the jurisdiction's name. For example, 'ZC' wouldbe the designator for a California or Colorado jurisdiction-defined subfile; 'ZQ'would be the designator for a Quebec jurisdiction-defined subfile. In the case ofa jurisdiction-defined subfile that has a first letter that could be more thanone jurisdiction (e.g. California, Colorado, Connecticut) then other data, likethe kPPIssuerIdentificationNumber, kPPAddressJurisdictionCode or kPPFullAddress must be examined to determine the jurisdiction.

    Hp softpaq download tool

    • Optional on all barcode versions, mandatory on Compact Encoding
  • kPPStandardVehicleClassification (string value 'kPPStandardVehicleClassification') - Standard vehicle classification code(s) for cardholder. This data element is aplaceholder for future efforts to standardize vehicle classifications.

    • Optional on all barcode versions, including compact encoding.
  • kPPStandardEndorsementCode (string value 'kPPStandardEndorsementCode') - Standard endorsement code(s) for cardholder. This data element is a placeholder for future efforts to standardize endorsement codes.

    • Optional on all barcode versions, including compact encoding.
    • H = Hazardous Material - This endorsement is required for the operation of any vehicletransporting hazardous materials requiring placarding, as defined by U.S.Department of Transportation regulations.
    • L = Motorcycles – Including Mopeds/Motorized Bicycles.
    • N = Tank - This endorsement is required for the operation of any vehicle transporting,as its primary cargo, any liquid or gaseous material within a tank attached to the vehicle.
    • O = Other Jurisdiction Specific Endorsement(s) - This code indicates one or moreadditional jurisdiction assigned endorsements.
    • P = Passenger - This endorsement is required for the operation of any vehicle used fortransportation of sixteen or more occupants, including the driver.
    • S = School Bus - This endorsement is required for the operation of a school bus. School bus means aCMV used to transport pre-primary, primary, or secondary school students from home to school,from school to home, or to and from school sponsored events. School bus does not include abus used as common carrier (49 CRF 383.5).
    • T = Doubles/Triples - This endorsement is required for the operation of any vehicle that would bereferred to as a double or triple.
    • X = Combined Tank/HAZ-MAT - This endorsement may be issued to any driver who qualifies forboth the N and H endorsements.
  • kPPStandardRestrictionCode (string value 'kPPStandardRestrictionCode') - Standard restriction code(s) for cardholder. This data element is a placeholderfor future efforts to standardize restriction codes.

    • Optional on all standard barcode versions. Not defined on Compact encoding, which has no compatible field.
    • B = Corrective Lenses
    • C = Mechanical Devices (Special Brakes, Hand Controls, or Other Adaptive Devices)
    • D = Prosthetic Aid
    • E = Automatic Transmission
    • F = Outside Mirror
    • G = Limit to Daylight Only
    • H = Limit to Employment
    • I = Limited Other
    • J = Other
    • K = CDL Intrastate Only
    • L = Vehicles without air brakes
    • M = Except Class A bus
    • N = Except Class A and Class B bus
    • O = Except Tractor-Trailer
    • V = Medical Variance Documentation Required
    • W = Farm Waiver

Keys existing on some barcode versions

Mandatory values

Driver's License Barcode Data Card

Personal data

  • kPPCustomerMiddleName (string value 'kPPCustomerMiddleName') - Middle name(s) of the cardholder. In the case of multiple middle names theyshall be separated by a comma ','.-
    • Mandatory on AAMVA version 04, 05, 06, 07, 08, optional on 01. On other standards middlename is included into value of kPPFirstName.
  • kPPHeightIn (string value 'kPPHeightIn') - Height of cardholder. (FT/IN)
    • FEET (1st char); Inches (2nd and 3rd char). Example: 509 = 5 ft., 9 in.
    • Optional on 01.
    • See also kPPHeight, kPPHeightCm
  • kPPHeightCm (string value 'kPPHeightCm') - Height of cardholder in centimeters.
    • Optional on 01.
    • See also kPPHeight, kPPHeightIn
  • kPPCustomerFullName (string value 'kPPCustomerFullName') - Full name of the individual holding the Driver License or ID as defined inANSI D20 Data Dictionary. (Lastname,Firstname,MI,suffix if any). This field contains four portions, separated with the ',' delimiter:
    • Last Name (required)
    • , (required)
    • First Name (required)
    • , (required if other name portions follow, otherwise optional)
    • Middle Name(s) (optional)
    • , (required if other name portions follow, otherwise optional)
    • Suffix Code (optional)
    • , (optional)
  • kPPFullAddress (string value 'kPPFullAddress') - Cardholder address.
    • Mandatory on compact encoding.
  • kPPFamilyNameTruncation (string value 'kPPFamilyNameTruncation') - A code that indicates whether a field has been truncated (T), has not beentruncated (N), or – unknown whether truncated (U).
    • Mandatory on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPFirstNameTruncation (string value 'kPPFirstNameTruncation') - A code that indicates whether a field has been truncated (T), has not beentruncated (N), or – unknown whether truncated (U).
    • Mandatory on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPMiddleNameTruncation (string value 'kPPMiddleNameTruncation') - A code that indicates whether a field has been truncated (T), has not beentruncated (N), or – unknown whether truncated (U).
    • Mandatory on AAMVA 04, 05, 06, 07, 08

License data

  • kPPCountryIdentification (string value 'kPPCountryIdentification') - Country in which DL/ID is issued. U.S. = USA, Canada = CAN.
    • Mandatory on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPDocumentDiscriminator (string value 'kPPDocumentDiscriminator') - Number must uniquely identify a particular document issued to that customer from others that may have been issued in the past. This number may serve multiple purposes of document discrimination, audit information number, and/or inventory control.
    • Mandatory on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPFederalCommercialVehicleCodes (string value 'kPPFederalCommercialVehicleCodes') - Federally established codes for vehicle categories, endorsements, and restrictions that are generally applicable to commercial motor vehicles. If the vehicle is not a commercial vehicle, 'NONE' is to be entered.
    • Mandatory on AAMVA versions 02 and 03.

Optional values

Personal data

  • kPPRaceEthnicity (string value 'kPPRaceEthnicity') - Codes for race or ethnicity of the cardholder, as defined in ANSI D20.
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
    • Race
    • AI = Alaskan or American Indian (Having Origins in Any of The Original Peoples of North America, and Maintaining Cultural Identification Through Tribal Affiliation of Community Recognition)
    • AP = Asian or Pacific Islander (Having Origins in Any of the Original Peoples of the Far East, Southeast Asia, or Pacific Islands. This Includes China, India, Japan, Korea, the Philippines Islands, and Samoa)
    • BK = Black (Having Origins in Any of the Black Racial Groups of Africa)
    • W = White (Having Origins in Any of The Original Peoples of Europe, North Africa,or the Middle East)
    • Ethnicity
    • H = Hispanic Origin (A Person of Mexican, Puerto Rican, Cuban, Central or South American or Other Spanish Culture or Origin, Regardless of Race)
    • O = Not of Hispanic Origin (Any Person Other Than Hispanic)
    • U = Unknown
  • kPPPlaceOfBirth (string value 'kPPPlaceOfBirth') - Country and municipality and/or state/province
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPWeightRange (string value 'kPPWeightRange') - Indicates the approximate weight range of the cardholder:
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08
    • 0 = up to 31 kg (up to 70 lbs)
    • 1 = 32 – 45 kg (71 – 100 lbs)
    • 2 = 46 - 59 kg (101 – 130 lbs)
    • 3 = 60 - 70 kg (131 – 160 lbs)
    • 4 = 71 - 86 kg (161 – 190 lbs)
    • 5 = 87 - 100 kg (191 – 220 lbs)
    • 6 = 101 - 113 kg (221 – 250 lbs)
    • 7 = 114 - 127 kg (251 – 280 lbs)
    • 8 = 128 – 145 kg (281 – 320 lbs)
    • 9 = 146+ kg (321+ lbs)
  • kPPWeightPounds (string value 'kPPWeightPounds') - Cardholder weight in pounds Ex. 185 lb = '185'
    • Optional on AAMVA 01, 04, 05, 06, 07, 08
  • kPPWeightKilograms (string value 'kPPWeightKilograms') - Cardholder weight in kilograms Ex. 84 kg = '084'
    • Optional on AAMVA 01, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPNamePrefix (string value 'kPPNamePrefix') - PREFIX to Driver Name. Freeform as defined by issuing jurisdiction.
    • Optional on AAMVA 01
  • kPPResidenceStreetAddress (string value 'kPPResidenceStreetAddress') - Driver Residence Street Address.
    • Optional on AAMVA version 01.
  • kPPResidenceStreetAddress2 (string value 'kPPResidenceStreetAddress2') - Driver Residence Street Address 2.
    • Optional on AAMVA version 01.
  • kPPResidenceCity (string value 'kPPResidenceCity') - Driver Residence City
    • Optional on AAMVA version 01.
  • kPPResidenceJurisdictionCode (string value 'kPPResidenceJurisdictionCode') - Driver Residence Jurisdiction Code.
    • Optional on AAMVA version 01.
  • kPPResidencePostalCode (string value 'kPPResidencePostalCode') - Driver Residence Postal Code.
    • Optional on AAMVA version 01.
  • kPPUnder18 (string value 'kPPUnder18') - Date on which the cardholder turns 18 years old. (MMDDCCYY format)
    • Optional on AAMVA 05, 06, 07, 08
  • kPPUnder19 (string value 'kPPUnder19') - Date on which the cardholder turns 19 years old. (MMDDCCYY format)
    • Optional on AAMVA 05, 06, 07, 08
  • kPPUnder21 (string value 'kPPUnder21') - Date on which the cardholder turns 21 years old. (MMDDCCYY format)
    • Optional on AAMVA 05, 06, 07, 08
  • kPPSocialSecurityNumber (string value 'kPPSocialSecurityNumber') - The number assigned to an individual by the Social Security Administration.
    • Optional on AAMVA version 01.
  • kPPAKASocialSecurityNumber (string value 'kPPAKASocialSecurityNumber') - Driver 'AKA' Social Security Number. FORMAT SAME AS DRIVER SOC SEC NUM. ALTERNATIVE NUMBERS(S) used as SS NUM.
    • Optional on AAMVA version 01.
  • kPPAKAFullName (string value 'kPPAKAFullName') - Other name by which cardholder is known. ALTERNATIVE NAME(S) of the individual holdingthe Driver License or ID. FORMAT same as defined in ANSI D20 Data Dictionary. (Lastname,Firstname,MI, suffix if any.) This field contains four portions, separated with the ',' delimiter: Last Name (required)
    • , (required)
    • First Name (required)
    • , (required if other name portions follow, otherwise optional)
    • Middle Name(s) (optional)
    • , (required if other name portions follow, otherwise optional)
    • Suffix Code (optional)
    • , (optional)
  • kPPAKAFamilyName (string value 'kPPAKAFamilyName') - Other family name by which cardholder is known.
    • Optional on AAMVA 01, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPAKAMiddleName (string value 'kPPAKAMiddleName') - ALTERNATIVE MIDDLE NAME(s) or INITIALS of the individual holding the Driver License or ID. Hyphenated names acceptable, spaces between names acceptable, but no other use of special symbols
    • Optional on AAMVA 01
  • kPPAKAGivenName (string value 'kPPAKAGivenName') - Other given name by which cardholder is known
    • Optional on AAMVA 01, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPAKAPrefixName (string value 'kPPAKAPrefixName') - ALTERNATIVE PREFIX to Driver Name. Freeform as defined by issuing jurisdiction.
    • Optional on AAMVA 01
  • kPPAKASuffixName (string value 'kPPAKASuffixName') - Other suffix by which cardholder is known. The Suffix Code Portion, if submitted, can contain only the Suffix Codes shown in the following table (e.g., Andrew Johnson, III = JOHNSON,ANDREW,3RD):
    • JR = Junior
    • SR = Senior or Esquire 1ST First
    • 2ND = Second
    • 3RD = Third
    • 4TH = Fourth
    • 5TH = Fifth
    • 6TH = Sixth
    • 7TH = Seventh
    • 8TH = Eighth
    • 9TH = Ninth
  • kPPOrganDonor (string value 'kPPOrganDonor') - Field that indicates that the cardholder is an organ donor = '1'.
    • Optional on AAMVA 06, 07, 08
  • kPPVeteran (string value 'kPPVeteran') - Field that indicates that the cardholder is a veteran = '1'
    • Optional on AAMVA 07, 08
  • kPPAKADateOfBirth (string value 'kPPAKADateOfBirth') - ALTERNATIVE DATES(S) given as date of birth. (MMDDCCYY format)
    • Optional on AAMVA 01
  • kPPImageTimestamp (string value 'kPPImageTimestamp') - Portrait image timestamp
    • Optional on compact encoding.
  • kPPImageType (string value 'kPPImageType') - Type of image
    • Optional on compact encoding.
  • kPPPortraitImage (string value 'kPPPortraitImage') - Portrait image
    • Optional on compact encoding.
  • kPPBDBFormatOwner (string value 'kPPBDBFormatOwner') - BDB format owner
    • Optional on compact encoding.
  • kPPBDBFormatType (string value 'kPPBDBFormatType') - BDB format type
    • Optional on compact encoding.
  • kPPBiometricData (string value 'kPPBiometricData') - Biometric data block
    • Optional on compact encoding.

License data

  • kPPJurisdictionVehicleClassificationDescription (string value 'kPPJurisdictionVehicleClassificationDescription') - Text that explains the jurisdiction-specific code(s) for classifications of vehicles cardholder is authorized to drive.
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPJurisdictionEndorsmentCodeDescription (string value 'kPPJurisdictionEndorsmentCodeDescription') - Text that explains the jurisdiction-specific code(s) that indicates additional driving privileges granted to the cardholder beyond the vehicle class.
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPJurisdictionRestrictionCodeDescription (string value 'kPPJurisdictionRestrictionCodeDescription') - Text describing the jurisdiction-specific restriction code(s) that curtail driving privileges.
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPInventoryControlNumber (string value 'kPPInventoryControlNumber') - A string of letters and/or numbers that is affixed to the raw materials (card stock,laminate, etc.) used in producing driver licenses and ID cards. (DHS recommended field)
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08
  • kPPCardRevisionDate (string value 'kPPCardRevisionDate') - DHS required field that indicates date of the most recent version change ormodification to the visible format of the DL/ID (MMDDCCYY format)
    • Optional on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPLimitedDurationDocument (string value 'kPPLimitedDurationDocument') - DHS required field that indicates that the cardholder has temporary lawful status = '1'.
    • Optional on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPIssueTimestamp (string value 'kPPIssueTimestamp') - Issue Timestamp. A string used by some jurisdictions to validate the document against their data base.
    • Optional on AAMVA version 01.
  • kPPPermitExpirationDate (string value 'kPPPermitExpirationDate') - Driver Permit Expiration Date. MMDDCCYY format. Date permit expires.
    • Optional on AAMVA version 01.
  • kPPPermitIdentifier (string value 'kPPPermitIdentifier') - Type of permit.
    • Optional on AAMVA version 01.
  • kPPPermitIssueDate (string value 'kPPPermitIssueDate') - Driver Permit Issue Date. MMDDCCYY format. Date permit was issued.
    • Optional on AAMVA version 01.
  • kPPNumberOfDuplicates (string value 'kPPNumberOfDuplicates') - Number of duplicate cards issued for a license or ID if any.
    • Optional on AAMVA version 01.
  • kPPAuditInformation (string value 'kPPAuditInformation') - A string of letters and/or numbers that identifies when, where, and by whom a driver license/ID card was made. If audit information is not used on the card or the MRT, it must be included in the driver record.
    • Optional on AAMVA 02, 03, 04, 05, 06, 07, 08 and Compact Encoding
  • kPPComplianceType (string value 'kPPComplianceType') - DHS required field that indicates compliance: 'M' = materially compliant; 'F' = fully compliant; and, 'N' = non-compliant.
    • Optional on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPHAZMATExpirationDate (string value 'kPPHAZMATExpirationDate') - Date on which the hazardous material endorsement granted by the document is no longer valid. (MMDDCCYY format)
    • Optional on AAMVA 04, 05, 06, 07, 08 and Compact Encoding
  • kPPMedicalIndicator (string value 'kPPMedicalIndicator') - Medical Indicator/Codes. STATE SPECIFIC. Freeform; Standard 'TBD'
    • Optional on AAMVA version 01.
  • kPPNonResident (string value 'kPPNonResident') - Non-Resident Indicator. 'Y'. Used by some jurisdictions to indicate holder of the document is a non-resident.
    • Optional on AAMVA version 01.
  • kPPUniqueCustomerId (string value 'kPPUniqueCustomerId') - A number or alphanumeric string used by some jurisdictions to identify a 'customer' across multiple data bases.
    • Optional on AAMVA version 01.
  • kPPDataDiscriminator (string value 'kPPDataDiscriminator') - Document discriminator.
    • Optional on compact encoding.

Keys for accessing raw barcode results

  • kPPPdf417 (string value 'kPPPdf417') - Raw pdf417 result
    • Mandatory for all USDL data
  • kPPCode128 (string value 'kPPCode128') - Raw code128 result
    • Optional, on US driver's licenses which have Code128 barcode printed
  • kPPCode39 (string value 'kPPCode39') - Raw code39 result
    • Optional, on US driver's licenses which have Code39 barcode printed

All of this is fairly straight forward.
1. Scan the back of your license / permit using a medium - high resolution. The resolution should be set so that the 2d barcode is about 2000 pixels long.
2. Open up the image in Photoshop and cut out the 2d barcode. The 2d barcode is the one on the bottom in the picture. Most states use the PDF-417 (Portable Data File, with 17 modules each containing 4 bars and spaces, thus 417). Edit the barcode so that it is exactly 2000 or less pixels long because that is the maximum the program will allow, and save it.
3. Open swipe toolkit pdf417 barcode reader, available to download in the last step, and load your barcode into it. Click decode image, and a window with all your information should pop up. The picture shows the window that I got ( I removed thinks I should probably care about). As you can see, you can view the information processed, in raw bytes, or in hex. An interesting thing to note is if your card contains your social security number, some states put it on and some states don't.

Easy