Re: [請益] 歐付寶金流串接

作者: rickysu (Ricky)   2014-04-17 09:17:08
歐付寶是採用 AES 128Bit CBC 模式加密,
加密資料如果長度不是 16 Bytes 整數倍時會出問題。
必須透過 Padding 方式補齊。歐付寶是採用 PKCS17 Padding。
這邊自己寫了一個 Library 用 mcrpt 來做加解密。
class AESCrypt
{
protected $iv;
protected $key;
protected $blockSize;
public function __construct($key, $iv = null, $mode = MCRYPT_MODE_CBC)
{
if($iv === null){
$size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, $mode);
$iv = mcrypt_create_iv($size, MCRYPT_DEV_RANDOM);
}
$this->key = $key;
$this->iv = $iv;
$this->blockSize = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, $mode);
}
protected function addPadding($data)
{
$paddingSize = $this->blockSize - (strlen($data) % $this->blockSize);
$data .= str_repeat(chr($paddingSize), $paddingSize);
return $data;
}
protected function removePadding($data)
{
$len = strlen($data);
$paddingSize = ord($data[$len-1]);
return substr($data, 0, $len - $paddingSize);
}
public function encrypt($plainData)
{
return mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $this->key,
$this->addPadding($plainData), MCRYPT_MODE_CBC, $this->iv);
}
public function decrypt($encryptData)
{
$decryptData = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $this->key,
$encryptData, MCRYPT_MODE_CBC, $this->iv);
return $this->removePadding($decryptData);
}
}
使用方式
$aesCrypt = new AESCrypt($key, $iv);
$encryptedData = $aesCrypt->encrypt('Plain Data');
$plainData = $aesCrypt->decrypt($encryptedData);
注意這邊的資料是使用 raw data。
如果要放在 XML 傳輸,請記得將 $encryptedData 做 base64_encode。
作者: olctw (k.olc.tw)   2014-04-17 11:11:00
推看樣子很多人都轉用 allpay 了,免年費真的很吸引人吧 XD
作者: alog (A肉哥)   2014-04-17 13:36:00
就整合過五六家以上的金流業者的系統...allpay 的 document 算很齊全跟清楚了XDDD
作者: rickysu (Ricky)   2014-04-17 17:07:00
不過他們的系統穩定度有點糟糕曾經好幾次系統回應取號成功,可是內容卻是空的。更別提returnUrl放入localhost對方系統就當場噴了。
作者: alog (A肉哥)   2014-04-17 19:15:00
XDD
作者: olctw (k.olc.tw)   2014-04-18 01:00:00
還有, webatm 的測試介面有些銀行根本無法測試 XD
作者: rickysu (Ricky)   2014-04-18 09:22:00
另外API也設計很差,都走SSL了為什麼還要將資料再加密一次
作者: alog (A肉哥)   2014-04-18 12:16:00
log service 也許會記錄到ssl 雖然是加密 但只保障傳輸層的安全我個人是覺得這無所謂,加一層還可以不過 api 的確是有點差 (但跟其他顏色跟老金流比較算好了)
作者: rickysu (Ricky)   2014-04-18 13:22:00
剛剛又遇到一個無言的問題,callback資料XML竟然把base64編碼的資料中+號轉換成空白,還得自己手動轉回來不然使用base64_decode會出問題
作者: alog (A肉哥)   2014-04-18 20:54:00
他api文件印象有提到Xd

Links booklink

Contact Us: admin [ a t ] ucptt.com