カスタム App の作成 > 式と関数の使い方 > JSON 関数の使い方
 

JSON 関数の使い方

FileMaker Pro Advanced には、REST API を使用して JSON 形式のデータを転送する Web サービスなど、他のソースの JSON データをソリューションで解析および変更できるようにするテキスト関数がいくつか用意されています。

JSON データ形式の詳細については、json.org を参照してください。

Web サービスからの JSON データの取得

[URL から挿入] スクリプトステップを使用して Web サービスへのアクセス、取得する情報に対する引数指定、HTTP ヘッダの送受信、変数またはフィールドへの結果の保存を行います。

たとえば、あるベーカリーで顧客が購入できる製品の一覧を、REST API を使用して JSON 形式で作成します。次の例では、本日の特売一覧を $$JSON 変数に格納された JSON データとして返します:

変数を設定 [ $url ; "https://bakery.example.com/rest/api/products" ]URL から挿入 [ダイアログあり: オフ; ターゲット: $$JSON ; $url ; SSL 証明書の検証; cURL オプション: "--data 一覧 = 特売"]

$$JSON に格納されて返されるデータについては、JSON データの例を参照してください。

FileMaker Pro Advanced には、一部の REST API で必要な文字エンコードと暗号化署名を処理するユーティリティ関数もいくつか用意されています:

HexDecode 関数

HexEncode 関数

TextDecode 関数

TextEncode 関数

Base64Decode 関数

Base64EncodeRFC 関数

CryptAuthCode 関数

CryptDigest 関数

CryptGenerateSignature 関数

CryptVerifySignature 関数

JSON データの書式設定

JSON データでは要素間のスペースや改行は必要ありません。ただし、問題をデバッグするときにデータを読みやすくするには、JSON データの例に示すようにタブや改行コード文字を追加する JSONFormatElements 関数を使用します。

JSON データの解析

次の JSON 関数を使用して JSON データを解析します。つまり、キー、値、JSON オブジェクト全体 (さらに処理が可能な配列) を取得します:

JSONGetElement – JSON データで要素 (オブジェクト、配列、または値) のクエリーを実行します

JSONListKeys – JSON データ内のオブジェクト名 (キー) または配列索引の一覧を表示します

JSONListValues – JSON データ内の値の一覧を表示します

これらの関数の 1 番目の引数 json では、処理対象の有効な JSON データを含むテキストフィールド、変数、またはテキスト式を指定します。

2 番目の引数キーまたは索引またはパスでは処理対象の JSON データの位置を指定します:

キー – JSON オブジェクト内のキーの名前

索引 – JSON 配列内の要素の索引 (1 番目の要素の索引は 0)

パス – キー名、配列索引、またはこの両方の階層文字列

キーまたは索引またはパス引数では次の構文がサポートされます。

 

キーまたは索引またはパス引数

意味

"."

(オプション) 1 番目の文字である場合はルートレベル

".[n]"

ルートレベルの配列の索引 n の位置にある要素

".名前"

ルートレベルの名前というオブジェクトのキー

".名前 A.名前 B.名前 C"

名前 C というオブジェクト、名前 B および名前 A の子孫

".[3][2][1]名前 A[0]"

名前 A オブジェクトの配列の 1 番目の要素、ネストされた配列セットの 3 番目のレベル

次の例のスクリプトでは JSONListKeys を使用して JSON データの例 ($$JSON 変数に格納されている) 内の製品の数を求め、各製品のレコードを作成して各レコードのフィールドに JSONGetElement を使用して取得した各製品の値を設定しています。

変数を設定 [$ProductCount ; 値:
   ValueCount (
      JSONListKeys ($$JSON ; "ベーカリー.製品")
   )]
変数を設定 [$i ; 値: 0]
If [$ProductCount > 0]
   Loop
      新規レコード/検索条件
      フィールド設定 [製品::ID ;
         JSONGetElement ($$JSON ; "ベーカリー.製品 [" & $i & "] id")]
      フィールド設定 [製品::価格 ;
         JSONGetElement ($$JSON ; "ベーカリー.製品 [" & $i & "] 価格")]
      フィールド設定 [製品::在庫 ;
         JSONGetElement ($$JSON ; "ベーカリー.製品 [" & $i & "] 在庫")]
      レコード/検索条件確定 [ダイアログあり: オフ]
      変数を設定 [$i ; 値 : $i + 1]
      Exit Loop If [$i $ProductCount]
   End Loop
End If

JSON データ要素の変更と追加

JSON データの値を変更する場合や要素を追加をする場合は JSONSetElement 関数を使用します。この関数の json およびキーまたは索引またはパス引数は JSON データの解析で説明したとおりに機能します。キーまたは索引またはパスで既存の要素を指定した場合はその要素の値が変更され、要素が存在しない場合は新しい要素が追加されます。

JSONSetElement は指定された要素に引数を設定します。単純な文字列や数値から複雑なオブジェクトや配列まで、すべての有効な JSON 値を指定できます。

タイプ引数ではのデータタイプを指定して、JSON パーサが各データタイプを扱うときの厳格なルールに従うようにします。サポートされるデータタイプについては JSONSetElement 関数を参照してください。有効な JSON 要素としてすでにフォーマット済みの json にデータを挿入するには、typeJSONRaw に設定します。

次の例では新製品のキー/値ペアを空の JSON オブジェクトに追加します。次に新しいオブジェクトを $$JSON 変数の製品配列の末尾に追加します (JSON データの例を参照してください)。

変数を設定 [$NewProduct ; 値 :
   JSONSetElement ("{}" ;
      ["id" ; "FB4" ; JSONString] ;
      ["名前" ; "バニラケーキ" ; JSONString] ;
      ["価格" ; 17.5 ; JSONNumber] ;
      ["在庫" ; 12 ; JSONNumber] ;
      ["カテゴリ" ; "ケーキ" ; JSONString] ;
      ["特売" ; true ; JSONBoolean]
   )]
変数を設定 [$NextIndex ; 値 :
   ValueCount (
      JSONListKeys ($$JSON ; "ベーカリー.製品")
   )]
変数を設定 [$$JSON ; 値 :
   JSONSetElement (
      $$JSON ; "ベーカリー.製品 [" & $NextIndex & "] " ; $NewProduct ;
      JSONObject
   )]

JSON データ要素の削除

要素を削除するには JSONDeleteElement 関数を使用します。この関数の json およびキーまたは索引またはパス引数は JSON データの解析で説明したとおりに機能します。キーまたは索引またはパス引数では json の既存の要素を指定する必要があります。

次の例では $$JSON 変数の "ID" キーの値が "FB3" の製品配列の要素を削除します (JSON データの例を参照してください)。

変数を設定 [$ProductCount ; 値:
   ValueCount (
      JSONListKeys ($$JSON ; "ベーカリー.製品")
   )]
変数を設定 [$i ; 値 : 0]
If [$ProductCount > 0]
   Loop
      変数を設定 [$ID ; 値 :
         JSONGetElement ($$JSON ; "ベーカリー.製品 [" & $i & "] id")]
      If [$ID = "FB3"]
         変数を設定 [$$JSON ; 値 :
            JSONDeleteElement ($$JSON ; "ベーカリー.製品 [" & $i & "] ")]
         現在のスクリプト終了 [テキスト結果: 0]
      End If
      変数を設定 [$i ; 値 : $i + 1]
      Exit Loop If [$i $ProductCount]
   End Loop
End If

JSON データのエラー処理

json 引数の解析中にエラーが発生した場合は、JSON 関数は「?」に続けて JSON パーサからのエラーメッセージを返します。

たとえば、JSON データの例の「ベーカリー」キーの後に「:」が見つからない場合は、計算式

JSONGetElement ($$JSON ; "ベーカリー.製品 [0] id")

は次のエラーメッセージを返します:

? * Line 3, Column 2
  Missing ':' after object member name
* Line 13, Column 5
  Extra non-whitespace after JSON value.

JSON データを使用する前に有効かどうかを判定するには、JSONFormatElements 関数を使用して先頭の文字が「?」であるかどうかをテストします。次に例を示します:

変数を設定 [$result ; 値 : JSONFormatElements ($$JSON)]
If [Left ($result ; 1) = "?"]
   # $$JSON に無効な JSON データが含まれています。
End If

JSON データの例

次の例では、JSON データに「ベーカリー」オブジェクトが含まれています。「ベーカリー」オブジェクトは 3 つの「製品」オブジェクトを含み、それぞれがキー/値ペアを複数持ちます。

{
"ベーカリー" :
{
"製品" :
[
{
"id" : "FB1",
"名前" : "ドーナツ",
"価格" : 1.99,
"在庫" : 43,
"カテゴリ" : "パン",
"特売" : true
},
{
"id" : "FB2",
"価格" : 22.5,
"名前" : "チョコレートケーキ",
"在庫" : 23,
"カテゴリ" : "ケーキ",
"特売" : true
},
{
"id" : "FB3",
"価格" : 3.95,
"名前" : "バゲット",
"在庫" : 34,
"カテゴリ" : "パン",
"特売" : true
}
]
}
}

メモ 

JSON パーサは配列内の要素の順序は維持しますが、オブジェクト内の要素の順序は維持しません。そのため、JSON 関数は指定した順序とは異なる順序でオブジェクトの要素を返すことがあります。

関連項目 

テキスト関数

オブジェクト関数