DreamWeaver を使用して旅行 Web サイトを作成しました。顧客が Tenpay での支払いを求めてきたので、オンラインで検索したところ、購入したいかお金が必要だったので、自分で作成する必要がありました。
if(!define('DEDEINC')) exit('リクエスト エラー!');
/**
*Tenpayインターフェースクラス
*/
クラステンペイ
{
var $dsql;
var $mid;
var $reqURL_onLine = "http://www.tenpay.com";
var $return_url='/plus/carbuyaction.php?dopost=return' // 処理アドレスを返す
;
/**
* コンストラクター
*
* @アクセス公開
* @param
*
* @return void
*/
関数tenpay()
{
グローバル $dsql;
$this->dsql = $dsql;
}
関数__construct()
{
$this->tenpay();
}
/**
* * アドレスはインターフェース設定時に送信されます
*
* 例: $this->SetReturnUrl($cfg_basehost."/tuangou/control/index.php?ac=pay&orderid=".$p2_Order)
*
* @param string $returnurl はアドレスを送信します
* @return void
*/
関数 SetReturnUrl($returnurl='')
{
if (!empty($returnurl))
{
$this->return_url = $returnurl;
}
}
/**
* 支払いコードを生成します
* @param array $order 注文情報
* @param array $payment お支払い方法情報
*/
関数 GetCode($order, $payment)
{
グローバル $cfg_basehost,$cfg_cmspath;
//セカンダリディレクトリの処理
If(!empty($cfg_cmspath)) $cfg_basehost = $cfg_basehost.'/'.$cfg_cmspath;
$partner = $payment['tenpay_account'];
$out_trade_no = $order['out_trade_no'];
$total_fee = floatval($order['price']) * 100;
$body = $order['out_trade_no'];
$attach = '';
$bank_type = 'デフォルト';
/* トランザクション タイプ: 2. 仮想トランザクション、1. 物理トランザクション */
$trans_type = 1;
$trade_mode=empty($payment['tenpay_pay_method']) '1' : $payment['tenpay_pay_method'];
$parameter = array(
'相棒'
'OUT_TRADE_NO' = & GT $ OUT_TRADE_NO, // 注文番号
;
'total_fee' 'total_fee' => $total_fee, 'total_fee' //合計金額
'notify_url' 'notify_url' => $cfg_basehost.$this->return_url."&code=".$payment['code'], //返信先アドレス
'RETURN_URL' = & GT; $ cfg_basehost. $ This-> $ 支払いアドレス
'本体' '本体' =>
'銀行タイプ' '銀行タイプ' =>
//ユーザーIP
'Spold_create_ip' = & gt; $ _Server ['remote_addr'], // IP を取引します
'fee_type' 'fee_type' => '1', 'fee_type' //通貨 1 RMB
'件名' '件名' =>
//システムのオプションパラメータ
'Sign_type' = & gt5', // 暗号化方式
;
'Service_version' = & gt', // インターフェイスのバージョン番号のデフォルトは 1.0
;
'Input_charset' = & GT 'UTF-8', // システムコード 'gbk'
;
'Sign_key_index' = & gt; '1', // キーのシリアル番号
;
//ビジネスのオプションパラメータ
'Attach' = & gt; $ Attach, // 元のデータは空として返されます
;
'Product_fee' = & gt; '', // 商品コスト
;
'Transport_fee' = & gt; '0', // 物流コスト
;
'Time_start' = & gt; date ("ymdhis"), // 注文生成時刻 date ("ymdhis")
'Time_expire' = & gt; '', // 注文失敗時間
;
'buyer_id' => '', //买方财付通帐号
'goods_tag' => '', //商品标记
'trade_mode' => $trade_mode, //交易模式(1.即时到帐模式,2.中介担保模式,3.后台选择(卖家进入支付中心列表选择))
'transport_desc' => '', //物流说明
'trans_type' => $trans_type, //交易类型
'agentid' => '', //平台ID
'agent_type' => '', //代理模式(0.无代理,1.表示卡易售模式,2.表示网店模式)
'seller_id' => '' //卖家商户号
);
ksort($parameter);
reset($parameter);
$param = '';
$sign = '';
foreach ($parameter AS $key => $val)
{
$param .= "$key=" .urlencode($val). "&";
if("" != $val && "sign" != $key) {
$sign .= "$key=$val&";
}
}
$param = substr($param, 0, -1);
$sign .= "key=".$payment['tenpay_key'];
$sign = strtolower(md5($sign));
$button = '
';
$button を返す;
/* ショッピングカートをクリア */
require_once DEDEINC.'/shopcar.class.php';
$cart = 新しいメンバーショップ();
$cart->clearItem();
$cart->MakeOrders();
$button を返す;
}
/**
*応答操作
*/
関数応答()
{
/*設定ファイルの紹介*/
$code = preg_replace( "#[^0-9a-z-]#i", "", $_GET['code'] );
require_once DEDEDATA.'/payment/'.$code.'.php';
$attach = $_GET['attach'];
$trade_state = $_GET['trade_state'];
$total_fee = $_GET['total_fee'];
$out_trade_no = トリム($_GET['out_trade_no']);
if(preg_match ("/S-P[0-9]+RN[0-9]/",$order_sn)) {
//支払い金額が一致するか確認します
$row = $this->dsql->GetOne("SELECT * FROM dede_shops_orders WHERE oid = '{$order_sn}'");
If ($row['priceCount'] != $_GET['total_fee'])
{
return $msg = "支払いに失敗しました。支払い金額が商品の合計価格と一致しません!";
}
$this->mid = $row['userid'];
/* デジタル署名が正しいかどうかを確認します */
ksort($_GET);
リセット($_GET);
$sign = '';
foreach ($_GET AS $key => $val)
{
If("" != $val && "sign" != $key && $key != 'コード') {
$sign .= "$key=$val&";
}
}
$sign .= "key=".$payment['tenpay_key'];
if(strto lower(md5($sign))==strto lower($_GET['sign']))
{
if($trade_state==0)
に
If($this->success_db($out_trade_no))
return $msg = "支払いが完了しました!
ホームページに戻る メンバー センター";
else return $msg = "支払いに失敗しました!
ホームページに戻る メンバー センター";
}
他{
//return $msg = "支払いに失敗しました!
ホームページに戻る メンバー センター"
}
}
/*アイテムトランザクションを処理中*/
関数 success_db($order_sn)
{
$time=time();
$mid=$this->mid;
//注文情報を取得し、注文の有効性を確認します
$row = $this->dsql->GetOne("SELECT state,priceCount FROM dede_shops_orders WHERE oid='$order_sn' ");
if($row['state'] > 0)
{
TRUE を返します;
/* 注文ステータス変更_支払い成功 */
$sql = "UPDATE `dede_shops_orders` SET `state`='1' WHERE `oid`='$order_sn' AND `userid`='".$this->mid."'";
If($this->dsql->ExecuteNoneQuery($sql))
{
$ this-> log_result( "verify_success、order number:"。$ order_sn);
TRUE を返します;
} else {
$ this-> log_result( "verify_failed、"。$ order_sn);
FALSE を返す;
}
}
関数 log_result($word) {
グローバル $cfg_cmspath;
$fp = fopen(dirname(__FILE__)."/../../data/payment/log.txt","a");
群れ($fp, LOCK_EX) ;
fwrite($fp,$word.",実行日:".strftime("%Y-%m-%d %H:%I:%S",time())."rn");
群れ($fp, LOCK_UN);
fclose($fp);
}
}