2

Firstdata の API と統合する支払いフォームを構築しようとしています。XML 文字列をサーバーに投稿する必要があります。また、クライアント側の証明書と http 認証も必要です。現在、私の CURL セットアップは次のようになっています。

function firstdata_send($config_param, $data) {
  $config_default = array(
    'test' => FALSE,
  );
  // settings in $config_param will overwrite settings in $config_default
  $config = (object)array_merge($config_default, $config_param);

  if($config->test) {
    $url = 'https://ws.merchanttest.firstdataglobalgateway.com/fdggwsapi/services/order.wsdl';
  }
  else {
    $url = 'https://ws.firstdataglobalgateway.com/fdggwsapi/services/order.wsdl';
  }

  $ch = curl_init($url);
  curl_setopt($ch, CURLOPT_POST, TRUE);
  curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
  curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
  curl_setopt($ch, CURLOPT_USERPWD, "{$config->username}:{$config->password}");
  curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
  curl_setopt($ch, CURLOPT_SSLCERT, $config->pemfile);
  curl_setopt($ch, CURLOPT_SSLKEY, $config->keyfile);
  curl_setopt($ch, CURLOPT_SSLKEYPASSWD, $config->keypass);
  curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
  curl_setopt($ch, CURLOPT_HEADER, TRUE);
  curl_setopt($ch, CURLOPT_VERBOSE, TRUE);
  $result = curl_exec($ch);
  $result .= curl_error($ch);
  return $result;
}

彼らのサーバーはHTTP/1.1 401 Unauthorized. しかし、投稿オプションをコメントアウトすると:

  //curl_setopt($ch, CURLOPT_POST, TRUE);
  //curl_setopt($ch, CURLOPT_POSTFIELDS, $data);

私は得るHTTP/1.1 200 OK。何が起こっているのかを完全に誤解していない限り、投稿を使用すると認証ヘッダーが何らかの形で干渉するようです。何が欠けているのかわからない。

解決済み:

テスト アカウントが生成した ssl 証明書が不良であることが判明しました。私は彼らの技術サポートに電話する必要があり、システムが証明書を受け入れる前に証明書を 3 回再生成する必要がありました。お時間を無駄にして申し訳ありません。私は最初にそれらを呼び出す必要がありました。興味のある方は、テクニカル サポートの電話番号 (888) 477-3611 に電話してください。私は NomikOS が正しいことに最も近いと思うので、彼を回答としてマークし、残りの人に賛成票を投じます。再度、感謝します。

4

3 に答える 3

2

certificateこのサービスを利用するにはpemフォーマットが必要だと思います....

A. API をダウンロードしますhttps://www.firstdata.com/downloads/customerservice/30006_api_php.zip

B. 非常に多くの例が表示される

販売情報の例

    include"lphp.php";
    $mylphp=new lphp;

    $myorder["host"]       = "secure.linkpt.net";
    $myorder["port"]       = "1129";
    $myorder["keyfile"]    = "./YOURCERT.pem"; # Change this to the name and location of your certificate file 
    $myorder["configfile"] = "1234567";        # Change this to your store number 

    $myorder["ordertype"]    = "SALE";
    $myorder["result"]       = "LIVE"; # For a test, set result to GOOD, DECLINE, or DUPLICATE
    $myorder["cardnumber"]   = "4111-1111-1111-1111";
    $myorder["cardexpmonth"] = "01";
    $myorder["cardexpyear"]  = "05";
    $myorder["chargetotal"]  = "9.99";

    $myorder["addrnum"]   = "123";   # Required for AVS. If not provided, transactions will downgrade.
    $myorder["zip"]       = "12345"; # Required for AVS. If not provided, transactions will downgrade.
//  $myorder["debugging"] = "true";  # for development only - not intended for production use


  # Send transaction. Use one of two possible methods  #
//  $result = $mylphp->process($myorder);       # use shared library model
    $result = $mylphp->curl_process($myorder);  # use curl methods


    if ($result["r_approved"] != "APPROVED")    // transaction failed, print the reason
    {   
        print "Status: $result[r_approved]\n";
        print "Error: $result[r_error]\n";
    }
    else
    {   // success
        print "Status: $result[r_approved]\n";
        print "Code: $result[r_code]\n";
        print "OID: $result[r_ordernum]\n\n";
    }
于 2012-04-26T19:44:57.070 に答える
1

アクセス資格情報 (ユーザー名、パスワード) を確認します

401無許可

リクエストにはユーザー認証が必要です。応答には、要求されたリソースに適用可能なチャレンジを含む WWW-Authenticate ヘッダー フィールド (セクション 14.47) を含める必要があります。クライアントは、適切な Authorization ヘッダー フィールド (セクション 14.8) を使用してリクエストを繰り返すことができます。リクエストに認証資格情報がすでに含まれている場合、401 応答は、それらの資格情報に対する認証が拒否されたことを示します。. 401 応答に前の応答と同じチャレンジが含まれており、ユーザー エージェントが少なくとも 1 回認証を試みている場合、応答で指定されたエンティティをユーザーに提示する必要があります。そのエンティティには関連する診断情報が含まれている可能性があるためです。HTTP アクセス認証については、「HTTP 認証: 基本およびダイジェスト アクセス認証」[43] で説明されています。

ソース: http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.4.2

==

OBS: エラーをチェックするためにこのコードをお勧めします

// check for errors before close
$result = curl_exec($ch);
if ($result === false)
{
    echo curl_error($ch);
}
curl_close($ch);
于 2012-04-26T19:15:52.130 に答える
1

First Data API が SOAP ベースの API であることを確認しました...

wsdl は SOAP 呼び出しを送信するための xml 命令セットにすぎないため、wsdl への URL は GET のみを受け入れます。

PHP ソープクライアント クラス

于 2012-04-26T19:39:24.037 に答える