php-vision/ya-ocr-sdk
最新稳定版本:0.0.2
Composer 安装命令:
composer require php-vision/ya-ocr-sdk
包简介
HTTP client for Yandex Cloud Vision OCR (sync/async)
README 文档
README
HTTP client for Yandex Cloud Vision OCR (sync + async). Designed as a small, predictable, PSR-friendly Composer library with clear errors, DTOs, and optional concurrency via a runner interface.
Features
- Sync OCR (
recognizeText) - Async OCR (
startTextRecognition+ polling withwait/waitMany) - PSR-18 transport + PSR-17 factories
- Deterministic DTOs with raw payload/meta
- Typed exceptions
- No hard dependency on event loops (optional concurrency via runner)
Requirements
- PHP 8.4+
- PSR-18 HTTP client
- PSR-17 factories
Installation
composer require php-vision/ya-ocr-vision-client
You must also install a PSR-18 client and PSR-17 factories, for example:
composer require guzzlehttp/guzzle nyholm/psr7
Authentication
Two options:
- IAM Token
UseAuthorization: Bearer <IAM_TOKEN>. - API Key
UseAuthorization: Api-Key <API_KEY>(nofolderIdheader).
This library only signs requests and forwards headers; it does not call IAM endpoints.
Quick Start (Sync)
<?php declare(strict_types=1); use GuzzleHttp\Client as GuzzleClient; use Nyholm\Psr7\Factory\Psr17Factory; use PhpVision\YandexVision\Auth\ApiKeyCredentialProvider; use PhpVision\YandexVision\Ocr\Enum\LanguageCode; use PhpVision\YandexVision\Ocr\OcrOptions; use PhpVision\YandexVision\Ocr\OcrService; use PhpVision\YandexVision\Transports\HttpTransport; use PhpVision\YandexVision\YandexVisionClient; require __DIR__ . '/vendor/autoload.php'; $httpClient = new GuzzleClient(); $psr17Factory = new Psr17Factory(); $transport = new HttpTransport($httpClient); $credentials = new ApiKeyCredentialProvider('YOUR_API_KEY'); $ocr = new OcrService($transport, $credentials, $psr17Factory, $psr17Factory); $client = new YandexVisionClient($ocr); $bytes = file_get_contents(__DIR__ . '/image.png'); $options = OcrOptions::create()->withLanguageCodes(LanguageCode::RU, LanguageCode::EN); $response = $client->ocr()->recognizeText($bytes, 'image/png', $options); var_dump($response->getPayload());
Async OCR (Start + Poll)
<?php declare(strict_types=1); use GuzzleHttp\Client as GuzzleClient; use Nyholm\Psr7\Factory\Psr17Factory; use PhpVision\YandexVision\Auth\ApiKeyCredentialProvider; use PhpVision\YandexVision\Ocr\OcrService; use PhpVision\YandexVision\Transports\HttpTransport; use PhpVision\YandexVision\YandexVisionClient; require __DIR__ . '/vendor/autoload.php'; $httpClient = new GuzzleClient(); $psr17Factory = new Psr17Factory(); $transport = new HttpTransport($httpClient); $credentials = new ApiKeyCredentialProvider('YOUR_API_KEY'); $ocr = new OcrService($transport, $credentials, $psr17Factory, $psr17Factory); $client = new YandexVisionClient($ocr); $handle = $client->ocr()->startTextRecognitionFromFile(__DIR__ . '/image.png'); $result = $client->ocr()->wait($handle->getOperationId(), 60); var_dump($result->getPayload());
Options
Every OCR call accepts an OcrOptions object:
languageCodes(array ofLanguageCodeenums)model(OcrModelenum, default ispage)requestId(string, forwarded asx-request-id)
Concurrency (waitMany)
waitMany() uses a runner to execute waits. Default is sequential:
$results = $client->ocr()->waitMany(['op-1', 'op-2'], 60);
You can provide a custom runner that performs concurrent execution.
Error Handling
Exceptions are thrown for common failures:
ApiException— non-2xx responses or operation errorsHttpException— transport failuresValidationException— invalid input or JSONTimeoutException— async polling timed out
License
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.
统计信息
- 总下载量: 3
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-01-06