Skip to main content
Interwork Corporation
IDR Solutions Product Support Portal
モードの切替 ダーク/ライト/自動 モードの切替 ダーク/ライト/自動 モードの切替 ダーク/ライト/自動

PHPを使用してPDFから画像を抽出する

目次

  1. はじめに
  2. 前提条件
  3. コード例
  4. コールバックURLに結果を返す
  5. 設定オプション
  6. URLによるアップロード
  7. 認証の使用
  8. 詳細情報

はじめに

以下のチュートリアルでは、ホストされたJPedal cloud APIを使用してPDFから画像を抽出する方法を説明します。独自のセルフホスト型JPedalマイクロサービス をセットアップすることもできます。

上記のサービスは通常のHTTPリクエストでアクセスできますが、このチュートリアルでは、REST API のシンプルなPHPラッパーを提供するオープンソースのPHP IDRCloudClient を使用します。

前提条件

composerを使用して、以下のコマンドでidrsolutions-php-clientパッケージ をインストールします。

composer require idrsolutions/idrsolutions-php-client

コード例

PDFから画像を抽出するための基本的なコード例を以下に示します。設定オプションと高度な機能については、以下をご覧ください。

<?php

require_once __DIR__ . "/PATH/TO/vendor/autoload.php";

use IDRsolutions\IDRCloudClient;

$endpoint = "https://my-self-hosted-service.com/" . IDRCloudClient::INPUT_JPEDAL;  
$parameters = array(
    'input' => IDRCloudClient::INPUT_UPLOAD,
    'file' => __DIR__ . 'path/to/file.pdf',
    'settings' => '{"mode":"extractImages","type":"rawImages","format":"png"}'
);

$results = IDRCloudClient::convert(array(
    'endpoint' => $endpoint,
    'parameters' => $parameters
));

IDRCloudClient::downloadOutput($results, __DIR__ . '/');

echo $results['downloadUrl'];

コールバックURLに結果を返す

JPedal Microserviceは、抽出完了時に抽出のステータス を送信するためのコールバックURLを受け付けます。コールバックURLを使用すると、抽出の完了を確認するためにサービスをポーリングする必要がなくなります。
コールバックURLは、以下のようにパラメータ配列に指定できます。

$parameters = array(
    'input' => IDRCloudClient::INPUT_UPLOAD,
    'callbackUrl' => 'http://listener.url',
    'file' => __DIR__ . 'path/to/file.pdf',
    'settings' => '{"mode":"extractImages","type":"rawImages","format":"png"}'
);

設定オプション

JPedal APIは、抽出をカスタマイズするためのキーと値のペアの設定オプションを含む文字列化されたJSONオブジェクトを受け付けます。設定はパラメータ配列に追加する必要があります。PDFから画像を抽出するための設定オプションの完全なリストはこちら で確認できます。

'settings' => '{"key":"value","key":"value"}'

URLによるアップロード

ローカルファイルをアップロードする以外に、JPedal Microserviceがダウンロードして抽出を実行するURLを指定することもできます。これを行うには、パラメータ配列のinputとfileの値を以下のように置き換えます。

'input' => IDRCloudClient.DOWNLOAD
'url' => 'http://exampleURL/exampleFile.pdf'

認証の使用

PDFから画像を抽出するためにユーザー名とパスワードが必要な独自のJPedal Microserviceをデプロイしている場合は、各変換時にそれらを提供する必要があります。これらは、以下のようにusernameとpasswordという名前の2つの変数をパラメータ配列に追加することで提供されます。

'username' => 'Username_If_Required',
'password' => 'Password_If_Required',

この場合、downloadOutputメソッドにも認証値を提供する必要があります。

IDRCloudClient::downloadOutput($results, __DIR__ . '/','newFileName','username','password');

詳細情報

GitHubのIDRCloudClient
PackagistのIDRCloudClient
JPedal Microservice API
JPedal Microserviceの使用方法