模擬串接服務 - eDDA已核印查詢

經銷商『eDDA已核印查詢』請求欄位
Id Name Description Type Additional Information
1 agent_uid 經銷商商務代號
string 必填
2 service 服務名稱
string 必填
{ "service_name": "api", "cmd": "api\/eddaauthorizationquery" }
JSON格式,AES256加密資料
3 encry_data 『eDDA已核印查詢』欄位資料 string 必填
『eDDA已核印查詢』欄位參考
JSON格式,AES256加密資料
特約商店『eDDA已核印查詢』請求欄位
Id Name Description Type Additional Information
1 store_uid 特約商店商務代號
string 必填
2 service 服務名稱
string 必填
{ "service_name": "api", "cmd": "api\/eddaauthorizationquery" }
JSON格式,AES256加密資料
3 encry_data 『eDDA已核印查詢』欄位資料 string 必填
『eDDA已核印查詢』欄位參考
JSON格式,AES256加密資料
eDDA已核印查詢』欄位
Id Name Description Type Additional Information
1 store_uid 特約商店商務代號 string 必填
2 user_id 特約商店帳號 string 必填
3 tix 核印交易代碼 integer 必填
eDDA已核印查詢』回傳欄位
Id Name Description Type Additional Information
1 code 執行結果(B200,B500,100) string
2 msg 執行結果訊息 string
3 rows 查詢資料清單 array 每筆『eDDA 核印資訊』欄位參考
eDDA 核印資訊』欄位
Id Name Description Type Additional Information
1 tix 交易代碼 integer
2 tix_name 交易代碼名稱 string
3 bank_uid 銀行代碼 string
4 bank_name 銀行名稱 string
5 bank_account 銀行帳號 string
6 cellphone_code 手機國碼 integer
7 cellphone 手機號碼 integer
AES256資料加密方式說明

1、所有的API送出HTTPs請求之欄位中,service 和 encry_data 欄位皆進行 AES256+BASE64 加密處理。
2、AES加密,格式為CBC,長度為256bits,金鑰長度32,IV長度16,傳遞內文為加密後組合IV並經過Base64轉換後傳出。

方式:
使用自訂的AES256函式將JSON資料加密後,再將IV資料和此AES256加密後的JSON資料串聯後,使用base64再進行加密成ASCII字串即可完成加密。

    PHP加密示意:
    AesEncrypt -> base64_ecode($IV . $JSON)

    C#加密示意:
    AesEncrypt -> (bytes)IV+(bytes)Json -> toBase64

    Java加密示意:
    AesEncrypt -> (bytes)IV+(bytes)Json -> toBase64

    Node.js加密示意:
    AesEncrypt -> concat([IV,JSON], [IV_SIZE,JSON_SIZE]) -> toString('base64')
    Python加密示意:
    AesEncrypt -> (bytes)IV+(bytes)Json -> base64.b64encode

範例程式碼