定制 tectiv3/bcbp 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tectiv3/bcbp

最新稳定版本:v0.1.0

Composer 安装命令:

composer require tectiv3/bcbp

包简介

Barcoded boarding pass encoder/decoder in PHP

README 文档

README

BCBP PHP is a PHP 8.1+ library for working with IATA barcoded boarding passes. It can decode boarding passes data into structured arrays and re-encode them back into the compact 2D barcode format. The codebase mirrors the reference TypeScript implementation in georgesmith46/bcbp.

Features

  • Decode barcoded boarding pass (BCBP) payloads into passenger metadata and leg details.
  • Encode structured passenger data back into an IATA-conformant BCBP string.
  • Handle conditional sections (A and B), multiple flight legs, and security data blocks.
  • Normalize flight dates relative to issuance dates using the IATA day-of-year convention.

Installation

Install the library via Composer:

composer require tectiv3/bcbp

If you are working from a local clone, ensure dependencies are installed before running tests:

composer install

Quick Start

Decoding a boarding pass

<?php

require __DIR__ . '/vendor/autoload.php';

use function Bcbp\decode;

$barcode = 'M1DESMARAIS/LUC       EABC123 YULFRAAC 0834 226F001A0025 106>60000';
$result = decode($barcode);

print_r($result);

The decoder returns an associative array with a meta section (format code, leg count, version, etc.) and a data section containing passenger fields and an array of legs. Optional fields are omitted when they are not present in the barcode.

You can provide an optional reference year to correctly resolve three-digit day-of-year fields when the boarding pass spans calendar boundaries:

$result = decode($barcode, 2016);

Encoding a boarding pass

<?php

require __DIR__ . '/vendor/autoload.php';

use function Bcbp\encode;

$payload = [
    'data' => [
        'passengerName' => 'DESMARAIS/LUC',
        'legs' => [
            [
                'operatingCarrierPNR' => 'ABC123',
                'departureAirport' => 'YUL',
                'arrivalAirport' => 'FRA',
                'operatingCarrierDesignator' => 'AC',
                'flightNumber' => '0834',
                'flightDate' => new DateTimeImmutable('2016-01-01T00:00:00+00:00'),
                'compartmentCode' => 'F',
                'seatNumber' => '001A',
                'checkInSequenceNumber' => '0025',
                'passengerStatus' => '1',
                'fastTrack' => false,
            ],
        ],
    ],
];

$barcode = encode($payload);

When encoding, fields that are omitted default to spaces so the resulting string respects the IATA fixed-width specification.

Testing

Run the automated test suite with PHPUnit:

composer test

Contributing

Pull requests and issues are welcome. Please include relevant fixtures, outline the steps you used to verify changes, and avoid committing real passenger data.

统计信息

  • 总下载量: 261
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-09-16