The Best Image OCR SDK For BAT.
專案地址 https://github.com/godruoyi/ocr
今天是星期二,是釋出輪子的好日子。@overtrue
Feature
- 自定義快取支援;
- 符合 PSR 標準,可以很方便的與你的框架結合;
- 命名不那麼亂七八糟;
- 支援目前市面多家服務商
Support
Requirement
- PHP > 5.6
- composer
Installation
composer require godruoyi/ocr
Usage
基本使用(以百度OCR為例)
use Godruoyi\OCR\Application;
$app = new Application([
'ocrs' => [
'baidu' => [
'app_key' => 'app_key',
'secret_key' => 'secret_key'
],
]
]);
//身份證識別
$result = $app->baidu->idcard($filePath);
返回結果
{
"log_id": 530427582,
"image_status": "normal",
"words_result_num": 6,
"words_result": {
"住址": {
"words": "上海市閔行區華漕鎮紅衛村宗家巷1號"
},
"出生": {
"words": "19870723"
},
"姓名": {
"words": "鹿晗"
},
"公民身份號碼": {
"words": "123456789123456132X"
},
"性別": {
"words": "男"
},
"民族": {
"words": "漢"
}
}
}
各平臺支援的方法
詳情請參考官方文件
所有平臺支援的方法中,都滿足以下結構:
$app->platform->$method($files, $options = [])
$files
的值可以為
- 檔案路徑(完整)
SplFileInfo
物件Resource
- 線上圖片地址(部分服務商不支援)
-
Array
注:
options
的值都是可選的
百度OCR
目前採用 AccessToken
作為 API
認證方式,檢視鑑權認證機制
通用文字識別
$app->baidu->generalBasic($file, [
'language_type' => 'CHN_ENG', //支援的語言,預設為CHN_ENG(中英文混合)
'detect_direction' => false, //是否檢測影像朝向
'detect_language' => false, //是否檢測語言,預設不檢測
'probability' => false, //是否返回識別結果中每一行的置信度
]);
通用文字識別(高精度版)
$app->baidu->accurateBasic($file, [
'detect_direction' => false, //是否檢測影像朝向
'probability' => false, //是否返回識別結果中每一行的置信度
]);
通用文字識別(含位置資訊版)
$app->baidu->general($file, [
'recognize_granularity' => 'big', //是否定位單字元位置
'language_type' => 'CHN_ENG', //CHN_ENG:中英文混合;預設為CHN_ENG
'detect_direction' => false, //是否檢測影像朝向
'detect_language' => false, //是否檢測語言,預設不檢測
'vertexes_location' => false, //是否返回文字外接多邊形頂點位置,不支援單字位置。預設為false
'probability' => false, //是否返回識別結果中每一行的置信度
]);
通用文字識別(含位置高精度版)
$app->baidu->accurate($file, [
'recognize_granularity' => 'big', //是否定位單字元位置
'detect_direction' => false, //是否檢測影像朝向
'vertexes_location' => false, //是否返回文字外接多邊形頂點位置,不支援單字位置。預設為false
'probability' => false, //是否返回識別結果中每一行的置信度
]);
通用文字識別(含生僻字版)
$app->baidu->generalEnhanced($file, [
'language_type' => 'CHN_ENG', //CHN_ENG:中英文混合;預設為CHN_ENG
'detect_direction' => false, //是否檢測影像朝向
'vertexes_location' => false, //是否返回文字外接多邊形頂點位置,不支援單字位置。預設為false
'probability' => false, //是否返回識別結果中每一行的置信度
]);
網路圖片文字識別
$app->baidu->webimage($file, [
'detect_direction' => false, //是否檢測影像朝向
'detect_language' => false, //是否檢測語言,預設不檢測
]);
身份證識別
$app->baidu->idcard($file, [
'detect_direction' => false, //是否檢測影像朝向
'id_card_side' => 'front', //front:身份證正面;back:身份證背面 (注意,該引數必選)
'detect_risk' => false, //是否開啟身份證風險型別功能,預設false
]);
銀行卡識別
$app->baidu->bankcard($file, [
]);
駕駛證識別
$app->baidu->drivingLicense($file, [
'detect_direction' => false, //是否檢測影像朝向
]);
行駛證識別
$app->baidu->vehicleLicense($file, [
'detect_direction' => false, //是否檢測影像朝向
'accuracy' => 'normal' // normal 使用快速服務,1200ms左右時延,預設或其它值使用高精度服務,1600ms左右時延
]);
車牌識別
$app->baidu->licensePlate($file, [
'multi_detect' => false, //是否檢測多張車牌,預設為false
]);
營業執照識別
$app->baidu->businessLicense($file, [
]);
通用票據識別
$app->baidu->receipt($file, [
'recognize_granularity' => 'big', //是否定位單字元位置
'probability' => false, //是否返回識別結果中每一行的置信度
'accuracy' => 'normal' // normal 使用快速服務,1200ms左右時延,預設或其它值使用高精度服務,1600ms左右時延
'detect_direction' => false, //是否檢測影像朝向
]);
Aliyun OCR
目前採用 APPCODE
作為 API
認證方式,檢視我的APPCODE
use Godruoyi\OCR\Application;
$app = new Application([
'ocrs' => [
'aliyun' => [
'appcode' => '40bc103c7fe6417b87152f6f68bead2f',
]
]
]);
阿里雲OCR不支援線上圖片地址
身份證識別
$app->aliyun->idcard($file, [
'side' => 'face', //身份證正反面型別:face/back
]);
行駛證識別
$app->aliyun->vehicle($file, [
]);
駕駛證識別
$app->aliyun->driverLicense($file, [
'side' => 'face', //駕駛證首頁/副頁:face/back
]);
門店識別
$app->aliyun->shopSign($file, [
]);
英文識別
$app->aliyun->english($file, [
]);
營業執照識別
$app->aliyun->businessLicense($file, [
]);
銀行卡識別
$app->aliyun->bankCard($file, [
]);
名片識別
$app->aliyun->businessCard($file, [
]);
火車票識別
$app->aliyun->trainTicket($file, [
]);
車牌識別
$app->aliyun->vehiclePlate($file, [
'multi_crop' => false, //當設成true時,會做多crop預測,只有當多crop返回的結果一致,並且置信度>0.9時,才返回結果
]);
通用文字識別
$app->aliyun->general($file, [
'min_size' => 16, //圖片中文字的最小高度,
'output_prob' => false, //是否輸出文字框的概率,
]);
Tencent OCR
use Godruoyi\OCR\Application;
$app = new Application([
'ocrs' => [
'tencent' => [
'app_id' => '1254032478',
'secret_id' => 'AKIDzODdB1nOELz0T8CEjTEkgKJOob3t2Tso',
'secret_key' => '6aHHkz236LOYu0nRuBwn5PwT0x3km7EL',
'bucket' => 'test1'
],
]
]);
Tencent OCR 暫不支援線上圖片地址
名片識別
$app->tencent->namecard($file, [
'ret_image' => 0, //0 不返回圖片,1 返回圖片,
]);
身份證識別
$app->tencent->idcard($file, [
'card_type' => 0, //0 為身份證有照片的一面,1為身份證有國徽的一面
]);
行駛證駕駛證識別
$app->tencent->drivingLicence($file, [
'type' => 0, //識別型別,0表示行駛證,1表示駕駛證,
]);
通用印刷體識別
$app->tencent->general($file, [
]);
本作品採用《CC 協議》,轉載必須註明作者和本文連結