承接 banguncode/php-icare 相关项目开发

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

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

banguncode/php-icare

Composer 安装命令:

composer require banguncode/php-icare

包简介

A simple PHP library for accessing the healthcare history of JKN participants.

README 文档

README

A simple PHP library for accessing the healthcare history of JKN (Jaminan Kesehatan Nasional) participants via BPJS Kesehatan Icare API.
This library also supports fetching verification and approval data from the Mobile Faskes API.

Features

  • Access healthcare history of JKN participants by NIK or BPJS Participant Number.
  • Automatic API signature generation (HMAC-SHA256).
  • Response decryption using AES-256-CBC and LZString compression.
  • Retrieve verification and approval status from Mobile Faskes.
  • Retry mechanism for API responses with delay instructions.
  • Simple logging example included.

Requirements

  • PHP >= 5.5
  • Composer
  • PHP extensions:
    • ext-curl
    • ext-openssl

Installation

Install via Composer:

composer require banguncode/php-icare

Usage Example

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

use PHPIcare\Icare;

// Set your BPJS API credentials
defined("JKN_API_CONSID")  or define("JKN_API_CONSID", "your_consid");
defined("JKN_API_SECRET")  or define("JKN_API_SECRET", "your_secret");
defined("JKN_API_USERKEY") or define("JKN_API_USERKEY", "your_userkey");

// Initialize
$icare = (new Icare())->init(JKN_API_CONSID, JKN_API_SECRET, JKN_API_USERKEY);

// Example data
$data = [
    ['param' => '1234567890000000', 'kodedokter' => '12345'],
    ['param' => '0000012345678',    'kodedokter' => '67890'],
];

$total = count($data);
echo "Total data: {$total}\n";

// Log file setup
$logDir = __DIR__ . '/logs';
if (!is_dir($logDir)) {
    mkdir($logDir, 0777, true);
}
$logFile = $logDir . '/' . date('Y-m-d') . '.log';

foreach ($data as $key => $row) {
    printf("%d/%d\n", $key + 1, $total);

    $param = !empty($row['param']) && preg_match('/^\d+$/', $row['param']) ? $row['param'] : null;
    $kodedokter = isset($row['kodedokter']) ? $row['kodedokter'] : null;

    $response = $icare->getIcareHistory($param, $kodedokter);

    $logMsg = '';
    if ($response) {
        if (is_int($response)) {
            $time = $response;
            while ($time > 0) {
                echo "Retry in {$time} s\n";
                sleep(1);
                $time--;
            }
            $response = $icare->getIcareHistory($param, $kodedokter);
        }

        $verif = $icare->getCekVerifikasi3($response);
        $approval = $icare->postApprovalIC($response);

        $logMsg .= "Request {$param} - {$kodedokter} success!\n";
        $logMsg .= "[REFERER] {$response}\n";
        $logMsg .= "[VERIF] {$verif}\n";
        $logMsg .= "[APPROVAL] {$approval}\n";
    } else {
        $logMsg .= "Request {$param} - {$kodedokter} failed!\n";
    }

    $logMsg .= "\n";
    echo $logMsg;

    file_put_contents($logFile, $logMsg, FILE_APPEND);

    sleep(5);
}

echo "Done!";

Reference

init(string $consId, string $secret, string $userKey): self

Initialize the library with your BPJS API credentials.

getIcareHistory(string $param, string $kodedokter): string|int|null|false

Fetch healthcare history data from Icare.

  • Returns a URL string on success.
  • Returns an integer (seconds to wait) if API requests a retry.
  • Returns null if no valid response.
  • Returns false if an error occurs.

getCekVerifikasi3(string $referer): array|null|false

Fetch verification data from Mobile Faskes using a referer URL.

postApprovalIC(string $referer): string|null|false

Submit an approval request to Mobile Faskes using a referer URL.

wsDecrypt(string $string): string|null

Decrypts AES-256-CBC encoded and LZString-compressed API data.

License

MIT License © 2025

Disclaimer

This library is not affiliated with BPJS Kesehatan. You must be an authorized user with valid credentials to use the BPJS Kesehatan API, and you are responsible for complying with all applicable regulations.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-13