0

個人用の独自の財務管理アプリケーションを構築する計画があります。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 のダウンロードで追跡サーバーを利用できることを知っています。誰かが提供できる助けをいただければ幸いです。

4

1 に答える 1