드림위버를 이용해 여행 웹사이트를 구축했는데, 고객이 텐페이를 통해 결제를 해달라고 하더군요. 온라인으로 검색해보니 사고 싶거나 돈이 필요해서 직접 작성하게 됐어요.
if(!definated('DEDEINC')) exit('요청 오류!');
/**
*텐페이 인터페이스 강좌
*/
클래스 텐페이
{
var $dsql;
var $mid;
var $reqURL_onLine = "
http://www.tenpay.com";
var $return_url='/plus/carbuyaction.php?dopost=return'; //返回处理地址
/**
* 생성자
*
* @접속공개
* @param
*
* @return 무효
*/
함수 텐페이()
{
글로벌 $dsql;
$this->dsql = $dsql;
}
함수 __construct()
{
$this->tenpay();
}
/**
* * 인터페이스를 설정하면 주소가 전송됩니다
*
* 예: $this->SetReturnUrl($cfg_basehost."/tuangou/control/index.php?ac=pay&orderid=".$p2_Order)
*
* @param string $returnurl이 주소를 보내드립니다
* @return 무효
*/
함수 SetReturnUrl($returnurl='')
{
if (!empty($returnurl))
{
$this->return_url = $returnurl;
}
}
/**
* 결제 코드 생성
* @param array $order 주문정보
* @param array $결제 결제수단 정보
*/
함수 GetCode($주문, $결제)
{
전역 $cfg_basehost,$cfg_cmspath;
//对于이종级目录의 조직
if(!empty($cfg_cmspath)) $cfg_basehost = $cfg_basehost.'/'.$cfg_cmspath;
$partner = $결제['tenpay_account'];
$out_trade_no = $order['out_trade_no'];
$total_fee = floatval($order['price']) * 100;
$body = $order['out_trade_no'];
$attach = '';
$bank_type = 'DEFAULT';
/* 交易类型:2、虚拟交易,1、实物交易 */
$trans_type = 1;
$trade_mode=empty($결제['tenpay_pay_method']) ? '1' : $결제['tenpay_pay_method'];
$매개변수 = 배열(
'파트너' => $파트너
'out_trade_no' => $out_trade_no, //订单号
'total_fee' => $total_fee, //总金额
'notify_url' => $cfg_basehost.$this->return_url."&code=".$결제['code'], //返回地址
'반환_URL' '반환_URL' =>
'본체' '본체' =>
'Bank_type' = & GT; $ Bank_type, // 거래 유형 기본 Tenpay
//사용자 IP
'Spborne_create_ip' = & gt; $ _Server ['remote_addr'], // IP 거래
'fee_type' 'fee_type' => '1', 'fee_type' //통화 1위안
'주제' '주제' =>
//시스템 선택적 매개변수
'sign_type' 'sign_type' => 'MD5', 'sign_type' //암호화 방법
'Service_version' = & gt; '1.0', // 인터페이스 버전 번호 기본값은 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; 날짜("ymdhis"), // 주문 생성 시간 날짜("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 = '
';
$버튼 반환;
/* 장바구니 지우기 */
require_once DEDEINC.'/shopcar.class.php';
$cart = 새로운 MemberShops();
$cart->clearItem();
$cart->MakeOrders();
$버튼 반환;
}
/**
*대응작전
*/
함수 응답()
{
/*구성 파일 소개 */
$code = preg_replace( "#[^0-9a-z-]#i", "", $_GET['code'] );
require_once DEDEDATA.'/결제/'.$code.'.php';
$attach = $_GET['attach'];
$trade_state
$total_fee = $_GET['total_fee'];
$out_trade_no = Trim($_GET['out_trade_no']);
if(preg_match ("/S-P[0-9] RN[0-9]/",$order_sn)) {
//결제 금액이 일치하는지 확인
$row = $this->dsql->GetOne("SELECT * FROM
#@__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=".$결제['tenpay_key'];
if(strtolower(md5($sign))==strtolower($_GET['sign']))
{
if($trade_state==0)
~
> > >
If($this->success_db($out_trade_no))
return $msg = "결제 성공!
홈페이지로 돌아가기 회원 센터";
else return $msg = "결제 실패!
홈페이지로 돌아가기 회원 센터"; 🎜>
~
}
그렇지 않으면{
//return $msg = "결제 실패!
홈페이지로 돌아가기 회원 센터" ;
}
}
/*아이템 거래 처리 중*/
함수 성공_db($order_sn)
{
$time=time();
$mid=$this->mid;
//주문 정보를 얻고 주문의 유효성을 확인합니다
$row = $this->dsql->GetOne("SELECT state,priceCount FROM
#@__shops_orders WHERE oid='$order_sn' ");
If($row['state'] > 0)
{
TRUE를 반환합니다.
~
/* 주문 상태 변경_결제 성공 */
$sql = "업데이트
`#@__shops_orders
` SET `state`='1' WHERE `oid`='$order_sn' AND `userid`='".$this->mid."' ";
If($this->dsql->ExecuteNoneQuery($sql))
{
$this->log_result("verify_success, 주문 번호: ".$order_sn) //확인 결과를 파일에 저장
TRUE를 반환합니다.
} else {
$this->log_result ("verify_failed, 주문 번호: ".$order_sn);//확인 결과를 파일에 저장
FALSE를 반환합니다.
}
}
함수 log_result($word) {
전역 $cfg_cmspath;
$fp = fopen(dirname(__FILE__)."/../../data/paid/log.txt","a");
무리($fp, LOCK_EX) ;
fwrite($fp,$word.",실행 날짜:".strftime("%Y-%m-%d %H:%I:%S",time())."rn");
무리($fp, LOCK_UN);
fclose($fp);
}
}