承接 zarpay/zarpay-php 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

zarpay/zarpay-php

最新稳定版本:v1.1.0

Composer 安装命令:

composer require zarpay/zarpay-php

包简介

Official PHP SDK for the ZarPay payment gateway

README 文档

README

Official PHP SDK for the ZarPay payment gateway.

Installation

composer require zarpay/zarpay-php

Quick Start

<?php
require 'vendor/autoload.php';

$zarpay = new \ZarPay\ZarPay('sk_sandbox_xxxxxxxxxxxxx');

$payment = $zarpay->payments->create([
    'merchant_order_id' => 'ORD-123',
    'amount' => 1500,
    'channel_id' => 1,
    'customer_phone' => '03001234567',
]);

echo $payment['data']['status'];
echo $payment['data']['payment_method_label'];

Payments

// Create a payment
$payment = $zarpay->payments->create([
    'merchant_order_id' => 'ORD-456',
    'amount' => 2500,
    'channel_id' => 1,
    'customer_phone' => '03001234567',
    'metadata' => ['customer_name' => 'Ahmed Khan'],
    'idempotency_key' => 'unique-key-456',
]);

// Get by ZarPay ID
$payment = $zarpay->payments->get('ZP_abc123def456');

// Get by your order ID
$payment = $zarpay->payments->getByOrderId('ORD-456');

Refunds

$refund = $zarpay->refunds->create([
    'zarpay_id' => 'ZP_abc123def456',
    'amount' => 500,
    'reason' => 'Customer requested refund',
]);

echo $refund['data']['status']; // 'pending' — requires admin approval

Balance

$balance = $zarpay->balance->get();

echo 'Available: ' . $balance['data']['available'];
echo 'Settled: ' . $balance['data']['settled'];
echo 'Unsettled: ' . $balance['data']['unsettled'];
echo 'Pending: ' . $balance['data']['pending'];

Settlements

$settlements = $zarpay->settlements->list([
    'status' => 'PAID',
    'page' => 1,
    'limit' => 10,
]);

foreach ($settlements['data']['settlements'] as $s) {
    echo "#{$s['id']}: PKR {$s['net_amount']} ({$s['status']})\n";
}

Channels

$channels = $zarpay->channels->list();

foreach ($channels['data']['channels'] as $ch) {
    echo "{$ch['id']}: {$ch['label']} ({$ch['wallet_type']})\n";
    echo "{$ch['logo_url']}\n";
}

Verify Webhooks

$rawBody = file_get_contents('php://input');
$signature = $_SERVER['HTTP_X_ZARPAY_SIGNATURE'] ?? '';

try {
    $event = \ZarPay\ZarPay::verifyWebhook(
        $rawBody,
        $signature,
        'whsec_your_webhook_secret'
    );

    switch ($event['event']) {
        case 'payment.completed':
            // Fulfill the order
            break;
        case 'refund.completed':
            // Update order status
            break;
        case 'settlement.paid':
            // Record settlement
            break;
    }

    http_response_code(200);
} catch (\Exception $e) {
    http_response_code(400);
}

Error Handling

use ZarPay\ZarPayAPIError;

try {
    $payment = $zarpay->payments->create([...]);
} catch (ZarPayAPIError $e) {
    echo $e->statusCode;  // 400, 401, 409, etc.
    echo $e->error;       // Human-readable error
}

Configuration

$zarpay = new \ZarPay\ZarPay('sk_sandbox_xxx', [
    'base_url' => 'http://localhost:3550/api/v1',
    'timeout' => 60,
]);

API Reference

Resource Method Endpoint
$payments->create() POST /payments
$payments->get() GET /payments/:id
$payments->getByOrderId() GET /payments/by-order/:id
$refunds->create() POST /refunds
$balance->get() GET /balance
$settlements->list() GET /settlements
$channels->list() GET /channels
ZarPay::verifyWebhook() Verify webhook signature

Requirements

  • PHP 7.4+
  • ext-curl
  • ext-json

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-11

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固