個人用の独自の財務管理アプリケーションを構築する計画があります。Chase を介してダイレクト コネクト サービスを有効にしましたが、サーバーからの応答に問題があります。これが私が使用しているコードです。他の人が使用できるように、誰かがこれを別のフォーラムに投稿してくれました。
<?php
// this function is just used to generate a random transaction id below
function getRandomString($length = 40, $charset = 'alphanum') {
$alpha = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
$num = '0123456789';
switch ($charset) {
case 'alpha':
$chars = $alpha;
break;
case 'alphanum':
$chars = $alpha . $num;
break;
case 'num':
$chars = $num;
break;
}
$randstring='';
$maxvalue=strlen($chars)-1;
for ($i = 0; $i < $length; $i++)
$randstring .= substr($chars, rand(0, $maxvalue), 1);
return $randstring;
}
// user login info
$user = 'username';
$pass = 'password';
// account info
$accnt_num = '00000000';
$accnt_type = 'CHECKING';
// date and a random unique transaction id
$txn_id = getRandomString(6);
$tz_offset = date('Z')/3600;
$date = date("YmdHis[$tz_offset:T]");
// Chase info
$org = 'B1';
$fid = '10898';
$bank_id = '122100024';
// transaction retrieval date range
$start_date = '20090101000000'; // from date, to..
$end_date = date('YmdHis'); // now
$xml = "
<OFX>
<SIGNONMSGSRQV1>
<SONRQ>
<DTCLIENT>$date</DTCLIENT>
<USERID>$user</USERID>
<USERPASS>$pass</USERPASS>
<LANGUAGE>ENG</LANGUAGE>
<FI>
<ORG>$org</ORG>
<FID>$fid</FID>
</FI>
<APPID>QWIN</APPID>
<APPVER>2200</APPVER>
</SONRQ>
</SIGNONMSGSRQV1>
<BANKMSGSRQV1>
<STMTTRNRQ>
<TRNUID>$txn_id</TRNUID>
<STMTRQ>
<BANKACCTFROM>
<BANKID>$bank_id</BANKID>
<ACCTID>$accnt_num</ACCTID>
<ACCTTYPE>$accnt_type</ACCTTYPE>
</BANKACCTFROM>
<INCTRAN>
<DTSTART>$start_date</DTSTART>
<DTEND>$end_date</DTEND>
<INCLUDE>Y</INCLUDE>
</INCTRAN>
</STMTRQ>
</STMTTRNRQ>
</BANKMSGSRQV1>
</OFX>";
$ch = curl_init();
$ch1 = curl_setopt($ch, CURLOPT_URL, 'https://ofx.chase.com');
$ch2 = curl_setopt($ch, CURLOPT_POST, 1);
$ch3 = curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: text/xml'));
$ch4 = curl_setopt($ch, CURLOPT_POSTFIELDS, $xml);
$ch5 = curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$ch6 = curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
$result = curl_exec($ch);
if ($result) {
echo $result;
}
else
echo "<pre>CURL ERROR: " . curl_error($ch) . "</pre>";
curl_close ($ch);
?>
これをブラウザから実行しようとすると、次のメッセージが表示されます。
CURL ERROR: SSL read: error:00000000:lib(0):func(0):reason(0), errno 0
別の投稿で、cacert.pem 証明書を更新する必要があるかもしれないと見たので、新しい証明書をダウンロードして、これを php.ini ファイルに追加しましたが、役に立ちませんでした。
curl.cainfo = "C:\xampp\PHP\cacert.pem"
curl_error の代わりに curl_errno を使用すると、CURLE_RECV_ERROR (56) ネットワーク データの受信に失敗した 56 のカール エラー コードが表示されます。
GNUCash ファイナンシャル マネージャーから銀行情報を取得できるので、OFX のダウンロードで追跡サーバーを利用できることを知っています。誰かが提供できる助けをいただければ幸いです。