carllee1983 / newebpay-logistics
NewebPay Logistics Integration PHP SDK. Supports various logistics methods including CVS pickup, home delivery, and more.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 1
pkg:composer/carllee1983/newebpay-logistics
Requires
- php: ^8.1
- ext-json: *
- ext-openssl: *
- guzzlehttp/guzzle: ^7.0
- psr/log: ^3.0
Requires (Dev)
- illuminate/support: ^9.0|^10.0|^11.0
- mockery/mockery: ^1.4
- phpstan/extension-installer: ^1.4
- phpstan/phpstan: ^2.1
- phpstan/phpstan-mockery: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- phpunit/phpunit: ^9.5.10
- squizlabs/php_codesniffer: ^3.7
Suggests
- laravel/framework: Required for Laravel integration features
This package is auto-updated.
Last update: 2025-12-08 13:38:56 UTC
README
A PHP SDK for integrating with the NewebPay Logistics API (藍新金流物流 API). This package simplifies the process of creating transactions, selecting stores (CVS), querying orders, and printing shipping labels.
Features
- Easy Integration: Simple and intuitive API for common logistics operations.
- Framework Agnostic: Works with any PHP project (bundled with Laravel support).
- Type Safety: Utilizes PHP encapsulation to ensure data validity.
- Frontend Friendly: Built-in support for generating HTML forms for frontend frameworks (Vue, React, etc.).
Requirements
- PHP ^8.1
ext-jsonextensionext-opensslextension
Installation
Install via Composer:
composer require carllee1983/newebpay-logistics
Configuration
Initialize the library with your NewebPay Logistics credentials.
use CarlLee\NewebPayLogistics\NewebPayLogistics; $merchantId = 'YOUR_MERCHANT_ID'; $hashKey = 'YOUR_HASH_KEY'; $hashIV = 'YOUR_HASH_IV'; // The last argument is optional for server URL override (defaults to testing env) $logistics = NewebPayLogistics::create($merchantId, $hashKey, $hashIV);
Parameters
| Parameter | Application | Description |
|---|---|---|
$merchantId |
Required | Your Shop ID (商店代號) provided by NewebPay. |
$hashKey |
Required | Hash Key (HashKey) for encryption. |
$hashIV |
Required | Hash IV (HashIV) for encryption. |
$serverUrl |
Optional | API Base URL. Default is testing env: https://ccore.newebpay.com/API/Logistic. |
Laravel Integration
This package includes a Service Provider and Facade for seamless Laravel integration.
1. Installation
Publish the configuration file:
php artisan vendor:publish --tag=newebpay-logistics-config
2. Configuration
Add the following variables to your .env file:
NEWEBPAY_LOGISTICS_MERCHANT_ID=your_merchant_id NEWEBPAY_LOGISTICS_HASH_KEY=your_hash_key NEWEBPAY_LOGISTICS_HASH_IV=your_hash_iv # Optional: Override server URL (default is testing environment) # NEWEBPAY_LOGISTICS_SERVER_URL=https://core.newebpay.com/API/Logistic
3. Usage via Facade
You can use the NewebPayLogistics facade anywhere in your Laravel application.
use NewebPayLogistics; use CarlLee\NewebPayLogistics\Parameter\ShipType; public function map() { $map = NewebPayLogistics::map(); $map->setShipType(ShipType::SEVEN_ELEVEN); // ... return NewebPayLogistics::generateForm($map); }
Usage
1. Map Interface (電子地圖)
Redirect the user to the logistics provider's map interface to select a store (7-11, FamilyMart, etc.).
use CarlLee\NewebPayLogistics\Parameter\LgsType; use CarlLee\NewebPayLogistics\Parameter\ShipType; $map = $logistics->map(); $map->setMerchantTradeNo('TRADE' . time()); $map->setLgsType(LgsType::B2C); $map->setShipType(ShipType::SEVEN_ELEVEN); $map->setIsCollection('N'); // N: No collection, Y: Collection $map->setServerReplyURL('https://example.com/reply'); // Generate auto-submit HTML form echo $logistics->generateForm($map);
1-1. Frontend Integration (Vue/React)
If you are using a decoupled architecture, return the form data as JSON.
$formBuilder = $logistics->getFormBuilder(); $data = $formBuilder->getFormData($map); echo json_encode($data); // Output: {"url": "...", "method": "post", "params": { ... }}
2. Create Order (建立物流訂單)
Create a logistics order for B2C or C2C transactions.
use CarlLee\NewebPayLogistics\Parameter\LgsType; use CarlLee\NewebPayLogistics\Parameter\ShipType; use CarlLee\NewebPayLogistics\Parameter\TradeType; $create = $logistics->createOrder(); $create->setMerchantTradeNo('TRADE' . time()); $create->setLgsType(LgsType::B2C); $create->setShipType(ShipType::SEVEN_ELEVEN); $create->setTradeType(TradeType::PAYMENT); $create->setReceiverName('John Doe'); $create->setReceiverCellPhone('0912345678'); // ... more parameters // This API usually responds with a redirect or direct result depending on the content // But strictly speaking, Create Order in some NewebPay flows is also a form post redirect. // Check official docs for specific flow.
3. Query Order (查詢物流訂單)
Query the status of an existing order.
$query = $logistics->query(); $query->setLogisticsID('LOGISTICS_ID'); $query->setMerchantTradeNo('TRADE_NO'); // This is a direct API call $response = $logistics->send($query); if ($response->isSuccess()) { echo "Status: " . $response->getMessage(); }
Examples
Check the examples/ directory for complete vanilla PHP scripts:
API Reference
For detailed API documentation, please refer to the files in the doc/ directory:
FAQ
Q: How do I change the environment to Production?
A: By default, NewebPayLogistics::create() uses the testing URL. Pass the production URL as the 4th argument, or set NEWEBPAY_LOGISTICS_SERVER_URL in Laravel .env.
Q: Can I use this without Laravel? A: Yes! The package is framework-agnostic. See the Configuration section.
Q: I get a "Validation Validation" error. A: Ensure all required fields are set. The SDK validates the request parameters before generating the payload.
Q: I get a "Check Value Error" or Decryption failure. A: This usually means your Merchant ID, Hash Key, or Hash IV are incorrect. Please double check them. Also ensure there are no extra spaces in your keys. In some cases, ensure your input data doesn't contain encoded characters that might mess up the length calculation.
Development
# Run tests composer test # Check code style composer check # Fix code style composer format
Contributing
Please see CONTRIBUTING.md for details.
Security
If you discover any security related issues, please email carllee1983@gmail.com instead of using the issue tracker.
License
MIT