first commit 2
This commit is contained in:
@@ -0,0 +1,2 @@
|
||||
<?php
|
||||
include_once('../../common.php');
|
||||
@@ -0,0 +1,116 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
|
||||
if($od['od_pg'] != 'lg') return;
|
||||
|
||||
if($default['de_card_test']) {
|
||||
$mid = 'tsi_'.$config['cf_lg_mid'];
|
||||
$service_url = "https://pgweb.tosspayments.com:9091/pg/wmp/mertadmin/jsp/escrow/rcvdlvinfo.jsp";
|
||||
} else {
|
||||
$mid = 'si_'.$config['cf_lg_mid'];
|
||||
$service_url = "https://pgweb.tosspayments.com/pg/wmp/mertadmin/jsp/escrow/rcvdlvinfo.jsp";
|
||||
}
|
||||
|
||||
// 택배사코드
|
||||
$dlvcomcode = array(
|
||||
'대한통운' => 'KE',
|
||||
'로젠택배' => 'LG',
|
||||
'아주택배' => 'AJ',
|
||||
'KG옐로우캡택배' => 'YC',
|
||||
'우체국' => 'PO',
|
||||
'이젠택배' => 'EZ',
|
||||
'트라넷' => 'TN',
|
||||
'한진택배' => 'HJ',
|
||||
'현대택배' => 'HD',
|
||||
'동부택배' => 'FE',
|
||||
'Bell Express' => 'BE',
|
||||
'CJ대한통운' => 'CJ',
|
||||
'HTH' => 'SS',
|
||||
'KGB택배' => 'KB',
|
||||
'KT로지스택배' => 'KT',
|
||||
'SC로지스택배' => 'SC',
|
||||
'일양로지스' => 'IY',
|
||||
'이노지스택배' => 'IN',
|
||||
'하나로택배' => 'HN',
|
||||
'대신택배' => 'DS',
|
||||
'우편등기' => 'RP'
|
||||
);
|
||||
|
||||
// 발송정보
|
||||
$oid = $od['od_id']; // 주문번호
|
||||
$productid = ''; // 상품ID
|
||||
$dlvtype = '03'; // 등록내용구분
|
||||
$rcvdate = ''; // 실수령일자
|
||||
$rcvname = ''; // 실수령인명
|
||||
$rcvrelation = ''; // 관계
|
||||
$dlvdate = date("YmdHi", G5_SERVER_TIME); // 발송일자
|
||||
$dlvcompcode = $dlvcomcode[$escrow_corp]; // 배송회사코드
|
||||
$dlvcomp = str_replace(' ', '||', $escrow_corp); // 배송회사명
|
||||
$dlvno = str_replace(' ', '||', $escrow_numb); // 운송장번호
|
||||
$dlvworker = ''; // 배송자명
|
||||
$dlvworkertel = ''; // 배송자전화번호
|
||||
|
||||
$mertkey = $config['cf_lg_mert_key']; // 각 상점의 테스트용 상점키와 서비스용 상점키
|
||||
|
||||
$hashdate; // 인증키
|
||||
$datasize = 1; // 여러건 전송일대 상점셋팅
|
||||
|
||||
$hashdata = md5($mid.$oid.$dlvdate.$dlvcompcode.$dlvno.$mertkey);
|
||||
|
||||
|
||||
// LG유플러스의 배송결과등록페이지를 호출하여 배송정보등록함
|
||||
/*
|
||||
* 아래 URL 을 호출시 파라메터의 값에 공백이 발생하면 해당 URL이 비정상적으로 호출됩니다.
|
||||
* 배송사명등을 파라메터로 등록시 공백을 "||" 으로 변경하여 주시기 바랍니다.
|
||||
*/
|
||||
$str_url = $service_url."?mid=$mid&oid=$oid&productid=$productid&orderdate=$orderdate&dlvtype=$dlvtype&rcvdate=$rcvdate&rcvname=$rcvname&rcvrelation=$rcvrelation&dlvdate=$dlvdate&dlvcompcode=$dlvcompcode&dlvno=$dlvno&dlvworker=$dlvworker&dlvworkertel=$dlvworkertel&hashdata=$hashdata";
|
||||
|
||||
/*
|
||||
$ch = curl_init();
|
||||
|
||||
curl_setopt ($ch, CURLOPT_URL, $str_url);
|
||||
curl_setopt ($ch, CURLOPT_COOKIEJAR, COOKIE_FILE_PATH);
|
||||
curl_setopt ($ch, CURLOPT_COOKIEFILE, COOKIE_FILE_PATH);
|
||||
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||
|
||||
$fp = curl_exec ($ch);
|
||||
|
||||
if(curl_errno($ch)){
|
||||
// 연결실패시 DB 처리 로직 추가
|
||||
}else{
|
||||
if(trim($fp)=="OK"){
|
||||
// 정상처리되었을때 DB 처리
|
||||
}else{
|
||||
// 비정상처리 되었을때 DB 처리
|
||||
}
|
||||
}
|
||||
curl_close($ch);
|
||||
*/
|
||||
/*
|
||||
* fopen 방식
|
||||
* php 4.3 버전 이전에서 사용가능
|
||||
*/
|
||||
|
||||
$fp = @fopen($str_url,"r");
|
||||
|
||||
if(!$fp)
|
||||
{
|
||||
// 연결실패시 DB 처리 로직 추가
|
||||
}
|
||||
else
|
||||
{
|
||||
// 해당 페이지 return값 읽기
|
||||
while(!feof($fp))
|
||||
{
|
||||
$res .= fgets($fp,3000);
|
||||
}
|
||||
|
||||
if(trim($res) == "OK")
|
||||
{
|
||||
// 정상처리되었을때 DB 처리
|
||||
}
|
||||
else
|
||||
{
|
||||
// 비정상처리 되었을때 DB 처리
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,70 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
|
||||
// 전자결제를 사용할 때만 실행
|
||||
if($default['de_iche_use'] || $default['de_vbank_use'] || $default['de_hp_use'] || $default['de_card_use'] || $default['de_easy_pay_use']) {
|
||||
?>
|
||||
|
||||
<?php if ($default['de_card_test']) { // 테스트 결제시 ?>
|
||||
<script language="javascript" src="https://js.tosspayments.com/xpay_crossplatform/sandbox/v1" type="text/javascript"></script>
|
||||
<?php } else { //실 결제시 ?>
|
||||
<script language="javascript" src="https://xpay.tosspayments.com/xpay/js/xpay_crossplatform.js" type="text/javascript"></script>
|
||||
<?php } ?>
|
||||
|
||||
<script type="text/javascript">
|
||||
|
||||
/*
|
||||
* 수정불가.
|
||||
*/
|
||||
var LGD_window_type = "<?php echo $LGD_WINDOW_TYPE; ?>";
|
||||
|
||||
/*
|
||||
* 수정불가
|
||||
*/
|
||||
function launchCrossPlatform(frm) {
|
||||
$.ajax({
|
||||
url: g5_url+"/shop/lg/xpay_request.php",
|
||||
type: "POST",
|
||||
data: $("#LGD_PAYREQUEST input").serialize(),
|
||||
dataType: "json",
|
||||
async: false,
|
||||
cache: false,
|
||||
success: function(data) {
|
||||
frm.LGD_HASHDATA.value = data.LGD_HASHDATA;
|
||||
|
||||
lgdwin = openXpay(frm, '<?php echo $CST_PLATFORM; ?>', LGD_window_type, null, "", "");
|
||||
},
|
||||
error: function(data) {
|
||||
console.log(data);
|
||||
}
|
||||
});
|
||||
}
|
||||
/*
|
||||
* FORM 명만 수정 가능
|
||||
*/
|
||||
function getFormObject() {
|
||||
return document.getElementById("forderform");
|
||||
}
|
||||
|
||||
/*
|
||||
* 인증결과 처리
|
||||
*/
|
||||
function payment_return() {
|
||||
var fDoc;
|
||||
|
||||
fDoc = lgdwin.contentWindow || lgdwin.contentDocument;
|
||||
|
||||
if (fDoc.document.getElementById('LGD_RESPCODE').value == "0000") {
|
||||
document.getElementById("LGD_PAYKEY").value = fDoc.document.getElementById('LGD_PAYKEY').value;
|
||||
document.getElementById("forderform").target = "_self";
|
||||
document.getElementById("forderform").action = "<?php echo $order_action_url; ?>";
|
||||
document.getElementById("forderform").submit();
|
||||
} else {
|
||||
document.getElementById("forderform").target = "_self";
|
||||
document.getElementById("forderform").action = "<?php echo $order_action_url; ?>";
|
||||
alert("LGD_RESPCODE (결과코드) : " + fDoc.document.getElementById('LGD_RESPCODE').value + "\n" + "LGD_RESPMSG (결과메시지): " + fDoc.document.getElementById('LGD_RESPMSG').value);
|
||||
closeIframe();
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<?php }
|
||||
@@ -0,0 +1,61 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
|
||||
$LGD_CUSTOM_PROCESSTYPE = 'TWOTR';
|
||||
?>
|
||||
|
||||
<div id="LGD_PAYREQUEST">
|
||||
<input type="hidden" name="CST_PLATFORM" id="CST_PLATFORM" value="<?php echo $CST_PLATFORM; ?>"> <!-- 테스트, 서비스 구분 -->
|
||||
<input type="hidden" name="CST_MID" id="CST_MID" value="<?php echo $CST_MID; ?>"> <!-- 상점아이디 -->
|
||||
<input type="hidden" name="LGD_MID" id="LGD_MID" value="<?php echo $LGD_MID; ?>"> <!-- 상점아이디 -->
|
||||
<input type="hidden" name="LGD_OID" id="LGD_OID" value="<?php echo $od_id; ?>"> <!-- 주문번호 -->
|
||||
<input type="hidden" name="LGD_BUYER" id="LGD_BUYER" value=""> <!-- 구매자 -->
|
||||
<input type="hidden" name="LGD_PRODUCTINFO" id="LGD_PRODUCTINFO" value="<?php echo $goods; ?>"> <!-- 상품정보 -->
|
||||
<input type="hidden" name="LGD_AMOUNT" id="LGD_AMOUNT" value=""> <!-- 결제금액 -->
|
||||
<input type="hidden" name="LGD_CUSTOM_FIRSTPAY" id="LGD_CUSTOM_FIRSTPAY" value=""> <!-- 결제수단 -->
|
||||
<input type="hidden" name="LGD_BUYEREMAIL" id="LGD_BUYEREMAIL" value=""> <!-- 구매자 이메일 -->
|
||||
<input type="hidden" name="LGD_CUSTOM_SKIN" id="LGD_CUSTOM_SKIN" value="<?php echo $LGD_CUSTOM_SKIN; ?>"> <!-- 결제창 SKIN -->
|
||||
<input type="hidden" name="LGD_WINDOW_VER" id="LGD_WINDOW_VER" value="<?php echo $LGD_WINDOW_VER; ?>"> <!-- 결제창버전정보 (삭제하지 마세요) -->
|
||||
<input type="hidden" name="LGD_CUSTOM_PROCESSTYPE" id="LGD_CUSTOM_PROCESSTYPE" value="<?php echo $LGD_CUSTOM_PROCESSTYPE; ?>"> <!-- 트랜잭션 처리방식 -->
|
||||
<input type="hidden" name="LGD_TIMESTAMP" id="LGD_TIMESTAMP" value="<?php echo $LGD_TIMESTAMP; ?>"> <!-- 타임스탬프 -->
|
||||
<input type="hidden" name="LGD_HASHDATA" id="LGD_HASHDATA" value=""> <!-- MD5 해쉬암호값 -->
|
||||
<input type="hidden" name="LGD_PAYKEY" id="LGD_PAYKEY"> <!-- LG유플러스 PAYKEY(인증후 자동셋팅)-->
|
||||
<input type="hidden" name="LGD_VERSION" id="LGD_VERSION" value="<?php echo $LGD_VERSION; ?>"> <!-- 버전정보 (삭제하지 마세요) -->
|
||||
<input type="hidden" name="LGD_TAXFREEAMOUNT" id="LGD_TAXFREEAMOUNT" value="<?php echo $comm_free_mny; ?>"> <!-- 결제금액 중 면세금액 -->
|
||||
<input type="hidden" name="LGD_BUYERIP" id="LGD_BUYERIP" value="<?php echo $LGD_BUYERIP; ?>"> <!-- 구매자IP -->
|
||||
<input type="hidden" name="LGD_BUYERID" id="LGD_BUYERID" value="<?php echo $LGD_BUYERID; ?>"> <!-- 구매자ID -->
|
||||
<input type="hidden" name="LGD_CUSTOM_USABLEPAY" id="LGD_CUSTOM_USABLEPAY" value="<?php echo $LGD_CUSTOM_USABLEPAY; ?>"> <!-- 결제가능수단 -->
|
||||
<input type="hidden" name="LGD_CASHRECEIPTYN" id="LGD_CASHRECEIPTYN" value="N"> <!-- 현금영수증 사용 설정 -->
|
||||
<input type="hidden" name="LGD_BUYERADDRESS" id="LGD_BUYERADDRESS" value=""> <!-- 구매자 주소 -->
|
||||
<input type="hidden" name="LGD_BUYERPHONE" id="LGD_BUYERPHONE" value=""> <!-- 구매자 휴대폰번호 -->
|
||||
<input type="hidden" name="LGD_RECEIVER" id="LGD_RECEIVER" value=""> <!-- 수취인 -->
|
||||
<input type="hidden" name="LGD_RECEIVERPHONE" id="LGD_RECEIVERPHONE" value=""> <!-- 수취인 휴대폰번호 -->
|
||||
<input type="hidden" name="LGD_EASYPAY_ONLY" id="LGD_EASYPAY_ONLY" value=""> <!-- 페이나우 결제 호출 -->
|
||||
|
||||
<?php if($default['de_escrow_use']) { ?>
|
||||
<input type="hidden" name="LGD_ESCROW_ZIPCODE" id="LGD_ESCROW_ZIPCODE" value=""> <!-- 에스크로배송지우편번호 -->
|
||||
<input type="hidden" name="LGD_ESCROW_ADDRESS1" id="LGD_ESCROW_ADDRESS1" value=""> <!-- 에스크로배송지우편번호 -->
|
||||
<input type="hidden" name="LGD_ESCROW_ADDRESS2" id="LGD_ESCROW_ADDRESS2" value=""> <!-- 에스크로배송지주소동까지 -->
|
||||
<input type="hidden" name="LGD_ESCROW_BUYERPHONE" id="LGD_ESCROW_BUYERPHONE" value=""> <!-- 에스크로배송지주소상세 -->
|
||||
<?php } ?>
|
||||
|
||||
<!-- 가상계좌(무통장) 결제연동을 하시는 경우 할당/입금 결과를 통보받기 위해 반드시 LGD_CASNOTEURL 정보를 LG 유플러스에 전송해야 합니다 . -->
|
||||
<input type="hidden" name="LGD_CASNOTEURL" id="LGD_CASNOTEURL" value="<?php echo $LGD_CASNOTEURL ?>"> <!-- 가상계좌 NOTEURL -->
|
||||
|
||||
<input type="hidden" name="LGD_RETURNURL" id="LGD_RETURNURL" value="<?php echo $LGD_RETURNURL; ?>"> <!-- 응답수신페이지 -->
|
||||
|
||||
<input type="hidden" name="LGD_ENCODING" id="LGD_ENCODING" value="UTF-8">
|
||||
<input type="hidden" name="LGD_ENCODING_RETURNURL" id="LGD_ENCODING_RETURNURL" value="UTF-8">
|
||||
|
||||
<?php /* 주문폼 자바스크립트 에러 방지를 위해 추가함 */ ?>
|
||||
<input type="hidden" name="good_mny" value="<?php echo $tot_price; ?>">
|
||||
<?php
|
||||
if($default['de_tax_flag_use']) {
|
||||
?>
|
||||
<input type="hidden" name="comm_tax_mny" value="<?php echo $comm_tax_mny; ?>"> <!-- 과세금액 -->
|
||||
<input type="hidden" name="comm_vat_mny" value="<?php echo $comm_vat_mny; ?>"> <!-- 부가세 -->
|
||||
<input type="hidden" name="comm_free_mny" value="<?php echo $comm_free_mny; ?>"> <!-- 비과세 금액 -->
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
@@ -0,0 +1,16 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
?>
|
||||
|
||||
<div id="display_pay_button" class="btn_confirm" style="display:none">
|
||||
<input type="button" value="주문하기" class="btn_submit" onclick="forderform_check(this.form);"/>
|
||||
<a href="javascript:history.go(-1);" class="btn01">취소</a>
|
||||
</div>
|
||||
<div id="display_pay_process" style="display:none">
|
||||
<img src="<?php echo G5_URL; ?>/shop/img/loading.gif" alt="">
|
||||
<span>주문완료 중입니다. 잠시만 기다려 주십시오.</span>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
document.getElementById("display_pay_button").style.display = "" ;
|
||||
</script>
|
||||
@@ -0,0 +1,2 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가;
|
||||
@@ -0,0 +1,99 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
|
||||
if($od['od_pg'] != 'lg') return;
|
||||
|
||||
include_once(G5_SHOP_PATH.'/settle_lg.inc.php');
|
||||
|
||||
/*
|
||||
* [결제 부분취소 요청 페이지]
|
||||
*
|
||||
* LG유플러스으로 부터 내려받은 거래번호(LGD_TID)를 가지고 취소 요청을 합니다.(파라미터 전달시 POST를 사용하세요)
|
||||
* (승인시 LG유플러스으로 부터 내려받은 PAYKEY와 혼동하지 마세요.)
|
||||
*/
|
||||
|
||||
$LGD_TID = $od['od_tno']; //LG유플러스으로 부터 내려받은 거래번호(LGD_TID)
|
||||
$LGD_CANCELAMOUNT = (int)$tax_mny; //부분취소 금액
|
||||
$LGD_REMAINAMOUNT = (int)$od['od_receipt_price'] - (int)$od['od_refund_price']; //취소전 남은금액
|
||||
|
||||
$LGD_CANCELTAXFREEAMOUNT = (int)$free_mny; //면세대상 부분취소 금액 (과세/면세 혼용상점만 적용)
|
||||
$LGD_CANCELREASON = $mod_memo; //취소사유
|
||||
$LGD_RFACCOUNTNUM = $_POST['LGD_RFACCOUNTNUM']; //환불계좌 번호(가상계좌 환불인경우만 필수)
|
||||
$LGD_RFBANKCODE = $_POST['LGD_RFBANKCODE']; //환불계좌 은행코드(가상계좌 환불인경우만 필수)
|
||||
$LGD_RFCUSTOMERNAME = $_POST['LGD_RFCUSTOMERNAME']; //환불계좌 예금주(가상계좌 환불인경우만 필수)
|
||||
$LGD_RFPHONE = $_POST['LGD_RFPHONE']; //요청자 연락처(가상계좌 환불인경우만 필수)
|
||||
|
||||
$xpay = new XPay($configPath, $CST_PLATFORM);
|
||||
|
||||
// Mert Key 설정
|
||||
$xpay->set_config_value('t'.$LGD_MID, $config['cf_lg_mert_key']);
|
||||
$xpay->set_config_value($LGD_MID, $config['cf_lg_mert_key']);
|
||||
|
||||
$xpay->Init_TX($LGD_MID);
|
||||
|
||||
$xpay->Set("LGD_TXNAME", "PartialCancel");
|
||||
$xpay->Set("LGD_TID", $LGD_TID);
|
||||
$xpay->Set("LGD_CANCELAMOUNT", $LGD_CANCELAMOUNT);
|
||||
$xpay->Set("LGD_REMAINAMOUNT", $LGD_REMAINAMOUNT);
|
||||
$xpay->Set("LGD_CANCELTAXFREEAMOUNT", $LGD_CANCELTAXFREEAMOUNT);
|
||||
$xpay->Set("LGD_CANCELREASON", $LGD_CANCELREASON);
|
||||
$xpay->Set("LGD_RFACCOUNTNUM", $LGD_RFACCOUNTNUM);
|
||||
$xpay->Set("LGD_RFBANKCODE", $LGD_RFBANKCODE);
|
||||
$xpay->Set("LGD_RFCUSTOMERNAME", $LGD_RFCUSTOMERNAME);
|
||||
$xpay->Set("LGD_RFPHONE", $LGD_RFPHONE);
|
||||
$xpay->Set("LGD_REQREMAIN", "0");
|
||||
$xpay->Set("LGD_ENCODING", "UTF-8");
|
||||
|
||||
/*
|
||||
* 1. 결제 부분취소 요청 결과처리
|
||||
*
|
||||
*/
|
||||
if ($xpay->TX()) {
|
||||
//1)결제 부분취소결과 화면처리(성공,실패 결과 처리를 하시기 바랍니다.)
|
||||
/*
|
||||
echo "결제 부분취소 요청이 완료되었습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
$keys = $xpay->Response_Names();
|
||||
foreach($keys as $name) {
|
||||
echo $name . " = " . $xpay->Response($name, 0) . "<br>";
|
||||
}
|
||||
echo "<p>";
|
||||
*/
|
||||
|
||||
if( '0000' == $xpay->Response_Code() ) {
|
||||
// 환불금액기록
|
||||
$tno = $xpay->Response("LGD_TID", 0);
|
||||
$mod_mny = (int)$tax_mny + (int)$free_mny;
|
||||
|
||||
$sql = " update {$g5['g5_shop_order_table']}
|
||||
set od_refund_price = od_refund_price + '$mod_mny',
|
||||
od_shop_memo = concat(od_shop_memo, \"$mod_memo\")
|
||||
where od_id = '{$od['od_id']}'
|
||||
and od_tno = '$tno' ";
|
||||
sql_query($sql);
|
||||
|
||||
// 미수금 등의 정보 업데이트
|
||||
$info = get_order_info($od_id);
|
||||
|
||||
$sql = " update {$g5['g5_shop_order_table']}
|
||||
set od_misu = '{$info['od_misu']}',
|
||||
od_tax_mny = '{$info['od_tax_mny']}',
|
||||
od_vat_mny = '{$info['od_vat_mny']}',
|
||||
od_free_mny = '{$info['od_free_mny']}'
|
||||
where od_id = '$od_id' ";
|
||||
sql_query($sql);
|
||||
} else {
|
||||
alert($xpay->Response_Msg().' 코드 : '.$xpay->Response_Code());
|
||||
}
|
||||
} else {
|
||||
//2)API 요청 실패 화면처리
|
||||
/*
|
||||
echo "결제 부분취소 요청이 실패하였습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
*/
|
||||
|
||||
alert('결제 부분취소 요청이 실패하였습니다.\\n\\n'.$xpay->Response_Code().' : '.$xpay->Response_Msg());
|
||||
}
|
||||
@@ -0,0 +1,54 @@
|
||||
<?php
|
||||
include_once('./_common.php');
|
||||
|
||||
/*
|
||||
payreq_crossplatform 에서 세션에 저장했던 파라미터 값이 유효한지 체크
|
||||
세션 유지 시간(로그인 유지시간)을 적당히 유지 하거나 세션을 사용하지 않는 경우 DB처리 하시기 바랍니다.
|
||||
*/
|
||||
if(!isset($_SESSION['PAYREQ_MAP'])){
|
||||
echo '세션이 만료 되었거나 유효하지 않은 요청 입니다.';
|
||||
return;
|
||||
}
|
||||
|
||||
$payReqMap = $_SESSION['PAYREQ_MAP'];//결제 요청시, Session에 저장했던 파라미터 MAP
|
||||
?>
|
||||
<html>
|
||||
<head>
|
||||
<script type="text/javascript">
|
||||
|
||||
function setLGDResult() {
|
||||
parent.payment_return();
|
||||
try {
|
||||
} catch (e) {
|
||||
alert(e.message);
|
||||
}
|
||||
}
|
||||
|
||||
</script>
|
||||
</head>
|
||||
<body onload="setLGDResult()">
|
||||
<?php
|
||||
$LGD_RESPCODE = isset($_POST['LGD_RESPCODE']) ? clean_xss_tags(strip_tags($_POST['LGD_RESPCODE'])) : '';
|
||||
$LGD_RESPMSG = isset($_POST['LGD_RESPMSG']) ? clean_xss_tags(strip_tags($_POST['LGD_RESPMSG'])) : '';
|
||||
$LGD_PAYKEY = '';
|
||||
|
||||
$payReqMap['LGD_RESPCODE'] = $LGD_RESPCODE;
|
||||
$payReqMap['LGD_RESPMSG'] = $LGD_RESPMSG;
|
||||
|
||||
if($LGD_RESPCODE == "0000"){
|
||||
$LGD_PAYKEY = $_POST['LGD_PAYKEY'];
|
||||
$payReqMap['LGD_PAYKEY'] = $LGD_PAYKEY;
|
||||
}
|
||||
else{
|
||||
echo "LGD_RESPCODE:" . $LGD_RESPCODE . " ,LGD_RESPMSG:" . $LGD_RESPMSG; //인증 실패에 대한 처리 로직 추가
|
||||
}
|
||||
?>
|
||||
<form method="post" name="LGD_RETURNINFO" id="LGD_RETURNINFO">
|
||||
<?php
|
||||
foreach ($payReqMap as $key => $value) {
|
||||
echo "<input type='hidden' name='".get_text($key)."' id='".get_text($key)."' value='".get_text($value)."'>";
|
||||
}
|
||||
?>
|
||||
</form>
|
||||
</body>
|
||||
</html>
|
||||
@@ -0,0 +1,189 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
?>
|
||||
|
||||
<script>
|
||||
// 현금영수증 MAIN FUNC
|
||||
function jsf__pay_cash( form )
|
||||
{
|
||||
jsf__show_progress(true);
|
||||
|
||||
if ( jsf__chk_cash( form ) == false )
|
||||
{
|
||||
jsf__show_progress(false);
|
||||
return;
|
||||
}
|
||||
|
||||
form.submit();
|
||||
}
|
||||
|
||||
// 진행 바
|
||||
function jsf__show_progress( show )
|
||||
{
|
||||
if ( show == true )
|
||||
{
|
||||
window.show_pay_btn.style.display = "none";
|
||||
window.show_progress.style.display = "inline";
|
||||
}
|
||||
else
|
||||
{
|
||||
window.show_pay_btn.style.display = "inline";
|
||||
window.show_progress.style.display = "none";
|
||||
}
|
||||
}
|
||||
|
||||
// 포맷 체크
|
||||
function jsf__chk_cash( form )
|
||||
{
|
||||
if ( form.tr_code[0].checked )
|
||||
{
|
||||
if ( form.id_info.value.length != 10 &&
|
||||
form.id_info.value.length != 11 &&
|
||||
form.id_info.value.length != 13 )
|
||||
{
|
||||
alert("주민번호 또는 휴대폰번호를 정확히 입력해 주시기 바랍니다.");
|
||||
form.id_info.select();
|
||||
form.id_info.focus();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else if ( form.tr_code[1].checked )
|
||||
{
|
||||
if ( form.id_info.value.length != 10 )
|
||||
{
|
||||
alert("사업자번호를 정확히 입력해 주시기 바랍니다.");
|
||||
form.id_info.select();
|
||||
form.id_info.focus();
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
function jsf__chk_tr_code( form )
|
||||
{
|
||||
var span_tr_code_0 = document.getElementById( "span_tr_code_0" );
|
||||
var span_tr_code_1 = document.getElementById( "span_tr_code_1" );
|
||||
|
||||
if ( form.tr_code[0].checked )
|
||||
{
|
||||
span_tr_code_0.style.display = "block";
|
||||
span_tr_code_1.style.display = "none";
|
||||
}
|
||||
else if (form.tr_code[1].checked )
|
||||
{
|
||||
span_tr_code_0.style.display = "none";
|
||||
span_tr_code_1.style.display = "block";
|
||||
}
|
||||
}
|
||||
|
||||
</script>
|
||||
|
||||
<div id="scash" class="new_win">
|
||||
<h1 id="win_title"><?php echo $g5['title']; ?></h1>
|
||||
|
||||
<section>
|
||||
<h2>주문정보</h2>
|
||||
|
||||
<div class="tbl_head01 tbl_wrap">
|
||||
<table>
|
||||
<colgroup>
|
||||
<col class="grid_3">
|
||||
<col>
|
||||
</colgroup>
|
||||
<tbody>
|
||||
<tr>
|
||||
<th scope="row">주문 번호</th>
|
||||
<td><?php echo $od_id; ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">상품 정보</th>
|
||||
<td><?php echo $goods_name; ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">주문자 이름</th>
|
||||
<td><?php echo $od_name; ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">주문자 E-Mail</th>
|
||||
<td><?php echo $od_email; ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">주문자 전화번호</th>
|
||||
<td><?php echo $od_tel; ?></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
</section>
|
||||
|
||||
<section>
|
||||
<h2>현금영수증 발급 정보</h2>
|
||||
|
||||
<form method="post" id="LGD_PAYINFO" action="<?php echo G5_SHOP_URL; ?>/lg/taxsave_result.php">
|
||||
<input type="hidden" name="tx" value="<?php echo $tx; ?>">
|
||||
<input type="hidden" name="od_id" value="<?php echo $od_id; ?>">
|
||||
<div class="tbl_head01 tbl_wrap">
|
||||
<table>
|
||||
<colgroup>
|
||||
<col class="grid_3">
|
||||
<col>
|
||||
</colgroup>
|
||||
<tbody>
|
||||
<tr>
|
||||
<th scope="row">원 거래 시각</th>
|
||||
<td><?php echo $trad_time; ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">발행 용도</th>
|
||||
<td>
|
||||
<input type="radio" name="tr_code" value="1" id="tr_code1" onClick="jsf__chk_tr_code( this.form )" checked>
|
||||
<label for="tr_code1">소득공제용</label>
|
||||
<input type="radio" name="tr_code" value="2" id="tr_code2" onClick="jsf__chk_tr_code( this.form )">
|
||||
<label for="tr_code2">지출증빙용</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">
|
||||
<label for="id_info">
|
||||
<span id="span_tr_code_0" style="display:inline">주민(휴대폰)번호</span>
|
||||
<span id="span_tr_code_1" style="display:none">사업자번호</span>
|
||||
</label>
|
||||
</th>
|
||||
<td>
|
||||
<input type="text" name="id_info" id="id_info" class="frm_input" size="16" maxlength="13"> ("-" 생략)
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">거래금액 총합</th>
|
||||
<td><?php echo number_format($amt_tot); ?>원</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">공급가액</th>
|
||||
<td><?php echo number_format($amt_sup); ?>원<!-- ((거래금액 총합 * 10) / 11) --></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">봉사료</th>
|
||||
<td><?php echo number_format($amt_svc); ?>원</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">부가가치세</th>
|
||||
<td><?php echo number_format($amt_tax); ?>원<!-- 거래금액 총합 - 공급가액 - 봉사료 --></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div id="scash_apply">
|
||||
<span id="show_pay_btn">
|
||||
<button type="button" onclick="jsf__pay_cash( this.form )">등록요청</button>
|
||||
</span>
|
||||
<span id="show_progress" style="display:none">
|
||||
<b>등록 진행중입니다. 잠시만 기다려주십시오</b>
|
||||
</span>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
</section>
|
||||
|
||||
</div>
|
||||
@@ -0,0 +1,260 @@
|
||||
<?php
|
||||
include_once('./_common.php');
|
||||
|
||||
require_once(G5_SHOP_PATH.'/settle_lg.inc.php');
|
||||
|
||||
$od_id = isset($_REQUEST['od_id']) ? safe_replace_regex($_REQUEST['od_id'], 'od_id') : '';
|
||||
$tx = isset($_REQUEST['tx']) ? clean_xss_tags($_REQUEST['tx'], 1, 1) : '';
|
||||
|
||||
if($tx == 'personalpay') {
|
||||
$od = sql_fetch(" select * from {$g5['g5_shop_personalpay_table']} where pp_id = '$od_id' ");
|
||||
if (!$od)
|
||||
die('<p id="scash_empty">개인결제 내역이 존재하지 않습니다.</p>');
|
||||
|
||||
$od_tno = $od['pp_tno'];
|
||||
$goods_name = $od['pp_name'].'님 개인결제';
|
||||
$settle_case = $od['pp_settle_case'];
|
||||
$order_price = $od['pp_receipt_price'];
|
||||
$od_casseqno = $od['pp_casseqno'];
|
||||
} else {
|
||||
$od = sql_fetch(" select * from {$g5['g5_shop_order_table']} where od_id = '$od_id' ");
|
||||
if (!$od)
|
||||
die('<p id="scash_empty">주문서가 존재하지 않습니다.</p>');
|
||||
|
||||
$od_tno = $od['od_tno'];
|
||||
$goods = get_goods($od['od_id']);
|
||||
$goods_name = $goods['full_name'];
|
||||
$settle_case = $od['od_settle_case'];
|
||||
$order_price = $od['od_tax_mny'] + $od['od_vat_mny'] + $od['od_free_mny'];
|
||||
$od_casseqno = $od['od_casseqno'];
|
||||
}
|
||||
|
||||
switch($settle_case) {
|
||||
case '가상계좌':
|
||||
$pay_type = 'SC0040';
|
||||
break;
|
||||
case '계좌이체':
|
||||
$pay_type = 'SC0030';
|
||||
break;
|
||||
case '무통장':
|
||||
$pay_type = 'SC0100';
|
||||
break;
|
||||
default:
|
||||
die('<p id="scash_empty">현금영수증은 무통장, 가상계좌, 계좌이체에 한해 발급요청이 가능합니다.</p>');
|
||||
break;
|
||||
}
|
||||
|
||||
$LGD_METHOD = 'AUTH'; //메소드('AUTH':승인, 'CANCEL' 취소)
|
||||
$LGD_OID = $od_id; //주문번호(상점정의 유니크한 주문번호를 입력하세요)
|
||||
$LGD_PAYTYPE = $pay_type; //결제수단 코드 (SC0030:계좌이체, SC0040:가상계좌, SC0100:무통장입금 단독)
|
||||
$LGD_AMOUNT = $order_price; //금액("," 를 제외한 금액을 입력하세요)
|
||||
$LGD_PRODUCTINFO = $goods_name; //상품명
|
||||
$LGD_TID = $od_tno; //LG유플러스 거래번호
|
||||
$LGD_CUSTOM_MERTNAME = $default['de_admin_company_name']; //상점명
|
||||
$LGD_CUSTOM_CEONAME = $default['de_admin_company_owner']; //대표자명
|
||||
$LGD_CUSTOM_BUSINESSNUM = $default['de_admin_company_saupja_no']; //사업자등록번호
|
||||
$LGD_CUSTOM_MERTPHONE = $default['de_admin_company_tel']; //상점 전화번호
|
||||
$LGD_CASHCARDNUM = $_POST['id_info']; //발급번호(주민등록번호,현금영수증카드번호,휴대폰번호 등등)
|
||||
$LGD_CASHRECEIPTUSE = $_POST['tr_code']; //현금영수증발급용도('1':소득공제, '2':지출증빙)
|
||||
|
||||
$xpay = new XPay($configPath, $CST_PLATFORM);
|
||||
|
||||
// Mert Key 설정
|
||||
$xpay->set_config_value('t'.$LGD_MID, $config['cf_lg_mert_key']);
|
||||
$xpay->set_config_value($LGD_MID, $config['cf_lg_mert_key']);
|
||||
|
||||
$xpay->Init_TX($LGD_MID);
|
||||
$xpay->Set("LGD_TXNAME", "CashReceipt");
|
||||
$xpay->Set("LGD_METHOD", $LGD_METHOD);
|
||||
$xpay->Set("LGD_PAYTYPE", $LGD_PAYTYPE);
|
||||
|
||||
if ($LGD_METHOD == "AUTH") { // 현금영수증 발급 요청
|
||||
$xpay->Set("LGD_OID", $LGD_OID);
|
||||
$xpay->Set("LGD_AMOUNT", $LGD_AMOUNT);
|
||||
$xpay->Set("LGD_CASHCARDNUM", $LGD_CASHCARDNUM);
|
||||
$xpay->Set("LGD_CUSTOM_MERTNAME", $LGD_CUSTOM_MERTNAME);
|
||||
$xpay->Set("LGD_CUSTOM_CEONAME", $LGD_CUSTOM_CEONAME);
|
||||
$xpay->Set("LGD_CUSTOM_BUSINESSNUM", $LGD_CUSTOM_BUSINESSNUM);
|
||||
$xpay->Set("LGD_CUSTOM_MERTPHONE", $LGD_CUSTOM_MERTPHONE);
|
||||
$xpay->Set("LGD_CASHRECEIPTUSE", $LGD_CASHRECEIPTUSE);
|
||||
$xpay->Set("LGD_ENCODING", "UTF-8");
|
||||
|
||||
if(isset($od['od_tax_flag']) && $od['od_tax_flag'] && $od['od_free_mny'] > 0) {
|
||||
$xpay->Set("LGD_TAXFREEAMOUNT", $od['od_free_mny']); //비과세 금액
|
||||
}
|
||||
|
||||
if ($LGD_PAYTYPE == "SC0030"){ //기결제된 계좌이체건 현금영수증 발급요청시 필수
|
||||
$xpay->Set("LGD_TID", $LGD_TID);
|
||||
}
|
||||
else if ($LGD_PAYTYPE == "SC0040"){ //기결제된 가상계좌건 현금영수증 발급요청시 필수
|
||||
$xpay->Set("LGD_TID", $LGD_TID);
|
||||
$xpay->Set("LGD_SEQNO", $od_casseqno);
|
||||
}
|
||||
else { //무통장입금 단독건 발급요청
|
||||
$xpay->Set("LGD_PRODUCTINFO", $LGD_PRODUCTINFO);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* 1. 현금영수증 발급/취소 요청 결과처리
|
||||
*
|
||||
* 결과 리턴 파라미터는 연동메뉴얼을 참고하시기 바랍니다.
|
||||
*/
|
||||
if ($xpay->TX()) {
|
||||
//1)현금영수증 발급/취소결과 화면처리(성공,실패 결과 처리를 하시기 바랍니다.)
|
||||
/*
|
||||
echo "현금영수증 발급/취소 요청처리가 완료되었습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
echo "결과코드 : " . $xpay->Response("LGD_RESPCODE",0) . "<br>";
|
||||
echo "결과메세지 : " . $xpay->Response("LGD_RESPMSG",0) . "<br>";
|
||||
echo "거래번호 : " . $xpay->Response("LGD_TID",0) . "<p>";
|
||||
|
||||
$keys = $xpay->Response_Names();
|
||||
foreach($keys as $name) {
|
||||
echo $name . " = " . $xpay->Response($name, 0) . "<br>";
|
||||
}
|
||||
*/
|
||||
|
||||
if($xpay->Response_Code() == '0000') {
|
||||
$LGD_OID = $xpay->Response("LGD_OID",0);
|
||||
$cash_no = $xpay->Response("LGD_CASHRECEIPTNUM",0);
|
||||
|
||||
$cash = array();
|
||||
$cash['LGD_TID'] = $xpay->Response("LGD_TID",0);
|
||||
$cash['LGD_TIMESTAMP'] = $xpay->Response("LGD_TIMESTAMP",0);
|
||||
$cash['LGD_RESPDATE'] = $xpay->Response("LGD_RESPDATE",0);
|
||||
$cash_info = serialize($cash);
|
||||
|
||||
if($tx == 'personalpay') {
|
||||
$sql = " update {$g5['g5_shop_personalpay_table']}
|
||||
set pp_cash = '1',
|
||||
pp_cash_no = '$cash_no',
|
||||
pp_cash_info = '$cash_info'
|
||||
where pp_id = '$LGD_OID' ";
|
||||
} else {
|
||||
$sql = " update {$g5['g5_shop_order_table']}
|
||||
set od_cash = '1',
|
||||
od_cash_no = '$cash_no',
|
||||
od_cash_info = '$cash_info'
|
||||
where od_id = '$LGD_OID' ";
|
||||
}
|
||||
|
||||
$result = sql_query($sql, false);
|
||||
|
||||
if(!$result) { // DB 정보갱신 실패시 취소
|
||||
$xpay->Set("LGD_TXNAME", "CashReceipt");
|
||||
$xpay->Set("LGD_METHOD", "CANCEL");
|
||||
$xpay->Set("LGD_PAYTYPE", $LGD_PAYTYPE);
|
||||
$xpay->Set("LGD_TID", $LGD_TID);
|
||||
|
||||
if ($LGD_PAYTYPE == "SC0040"){ //가상계좌건 현금영수증 발급취소시 필수
|
||||
$xpay->Set("LGD_SEQNO", $od_casseqno);
|
||||
}
|
||||
|
||||
if ($xpay->TX()) {
|
||||
/*
|
||||
echo "현금영수증 취소 요청처리가 완료되었습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
echo "결과코드 : " . $xpay->Response("LGD_RESPCODE",0) . "<br>";
|
||||
echo "결과메세지 : " . $xpay->Response("LGD_RESPMSG",0) . "<br>";
|
||||
echo "거래번호 : " . $xpay->Response("LGD_TID",0) . "<p>";
|
||||
*/
|
||||
} else {
|
||||
$msg = '현금영수증 취소 요청처리가 정상적으로 완료되지 않았습니다.';
|
||||
if(!$is_admin)
|
||||
$msg .= '쇼핑몰 관리자에게 문의해 주십시오.';
|
||||
|
||||
alert_close($msg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
} else {
|
||||
//2)API 요청 실패 화면처리
|
||||
/*
|
||||
echo "현금영수증 발급/취소 요청처리가 실패되었습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
*/
|
||||
|
||||
$msg = '현금영수증 발급 요청처리가 정상적으로 완료되지 않았습니다.';
|
||||
$msg .= '\\nTX Response_code = '.$xpay->Response_Code();
|
||||
$msg .= '\\nTX Response_msg = '.$xpay->Response_Msg();
|
||||
|
||||
alert($msg);
|
||||
}
|
||||
|
||||
$g5['title'] = '';
|
||||
include_once(G5_PATH.'/head.sub.php');
|
||||
|
||||
if($default['de_card_test']) {
|
||||
echo '<script language="JavaScript" src="'.SHOP_TOSSPAYMENTS_CASHRECEIPT_TEST_JS.'"></script>'.PHP_EOL;
|
||||
} else {
|
||||
echo '<script language="JavaScript" src="'.SHOP_TOSSPAYMENTS_CASHRECEIPT_REAL_JS.'"></script>'.PHP_EOL;
|
||||
}
|
||||
|
||||
switch($LGD_PAYTYPE) {
|
||||
case 'SC0030':
|
||||
$trade_type = 'BANK';
|
||||
break;
|
||||
case 'SC0040':
|
||||
$trade_type = 'CAS';
|
||||
break;
|
||||
default:
|
||||
$trade_type = 'CR';
|
||||
break;
|
||||
}
|
||||
?>
|
||||
|
||||
<div id="lg_req_tx" class="new_win">
|
||||
<h1 id="win_title">현금영수증 - 토스페이먼츠 eCredit</h1>
|
||||
|
||||
<div class="tbl_head01 tbl_wrap">
|
||||
<table>
|
||||
<colgroup>
|
||||
<col class="grid_4">
|
||||
<col>
|
||||
</colgroup>
|
||||
<tbody>
|
||||
<tr>
|
||||
<th scope="row">결과코드</th>
|
||||
<td><?php echo $xpay->Response_Code(); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">결과 메세지</th>
|
||||
<td><?php echo $xpay->Response_Msg(); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">현금영수증 거래번호</th>
|
||||
<td><?php echo $xpay->Response("LGD_TID",0); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">현금영수증 승인번호</th>
|
||||
<td><?php echo $xpay->Response("LGD_CASHRECEIPTNUM",0); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">승인시간</th>
|
||||
<td><?php echo preg_replace("/([0-9]{4})([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})/", "\\1-\\2-\\3 \\4:\\5:\\6",$xpay->Response("LGD_RESPDATE",0)); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th scope="row">현금영수증 URL</th>
|
||||
<td>
|
||||
<button type="button" name="receiptView" class="btn_frmline" onClick="javascript:showCashReceipts('<?php echo $LGD_MID; ?>','<?php echo $LGD_OID; ?>','<?php echo $od_casseqno; ?>','<?php echo $trade_type; ?>','<?php echo $CST_PLATFORM; ?>');">영수증 확인</button>
|
||||
<p>영수증 확인은 실 등록의 경우에만 가능합니다.</p>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td colspan="2"></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<?php
|
||||
include_once(G5_PATH.'/tail.sub.php');
|
||||
@@ -0,0 +1,19 @@
|
||||
<?php
|
||||
//최종결제요청 결과 성공 DB처리 실패시 Rollback 처리
|
||||
$isDBOK = false; //DB처리 실패시 false로 변경해 주세요.
|
||||
if( !$isDBOK ) {
|
||||
if( isset($xpay) && method_exists($xpay, 'Rollback')) {
|
||||
$xpay->Rollback($cancel_msg . " [TID:" . $xpay->Response("LGD_TID",0) . ",MID:" . $xpay->Response("LGD_MID",0) . ",OID:" . $xpay->Response("LGD_OID",0) . "]");
|
||||
}
|
||||
|
||||
/*
|
||||
echo "TX Rollback Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Rollback Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
if( "0000" == $xpay->Response_Code() ) {
|
||||
echo "자동취소가 정상적으로 완료 되었습니다.<br>";
|
||||
}else{
|
||||
echo "자동취소가 정상적으로 처리되지 않았습니다.<br>";
|
||||
}
|
||||
*/
|
||||
}
|
||||
@@ -0,0 +1,90 @@
|
||||
<?php
|
||||
include_once('./_common.php');
|
||||
|
||||
// LG유플러스 공통 설정
|
||||
require_once(G5_SHOP_PATH.'/settle_lg.inc.php');
|
||||
|
||||
/*
|
||||
* 1. 기본결제 인증요청 정보 변경
|
||||
*
|
||||
* 기본정보를 변경하여 주시기 바랍니다.(파라미터 전달시 POST를 사용하세요)
|
||||
*/
|
||||
$LGD_OID = isset($_POST['LGD_OID']) ? $_POST['LGD_OID'] : ''; //주문번호(상점정의 유니크한 주문번호를 입력하세요)
|
||||
$LGD_AMOUNT = isset($_POST['LGD_AMOUNT']) ? $_POST['LGD_AMOUNT'] : 0; //결제금액("," 를 제외한 결제금액을 입력하세요)
|
||||
$LGD_TIMESTAMP = isset($_POST['LGD_TIMESTAMP']) ? $_POST['LGD_TIMESTAMP'] : ''; //타임스탬프
|
||||
$LGD_BUYER = isset($_POST['LGD_BUYER']) ? $_POST['LGD_BUYER'] : ''; //구매자명
|
||||
$LGD_PRODUCTINFO = isset($_POST['LGD_PRODUCTINFO']) ? $_POST['LGD_PRODUCTINFO'] : ''; //상품명
|
||||
$LGD_BUYEREMAIL = isset($_POST['LGD_BUYEREMAIL']) ? $_POST['LGD_BUYEREMAIL'] : ''; //구매자 이메일
|
||||
$LGD_CUSTOM_FIRSTPAY = isset($_POST['LGD_CUSTOM_FIRSTPAY']) ? $_POST['LGD_CUSTOM_FIRSTPAY'] : ''; //상점정의 초기결제수단
|
||||
$LGD_CUSTOM_SKIN = 'red'; //상점정의 결제창 스킨
|
||||
$LGD_CUSTOM_USABLEPAY = isset($_POST['LGD_CUSTOM_USABLEPAY']) ? $_POST['LGD_CUSTOM_USABLEPAY'] : ''; //디폴트 결제수단 (해당 필드를 보내지 않으면 결제수단 선택 UI 가 노출됩니다.)
|
||||
$LGD_WINDOW_VER = '2.5'; //결제창 버젼정보
|
||||
$LGD_WINDOW_TYPE = $LGD_WINDOW_TYPE; //결제창 호출방식 (수정불가)
|
||||
$LGD_CUSTOM_SWITCHINGTYPE = $LGD_CUSTOM_SWITCHINGTYPE; //신용카드 카드사 인증 페이지 연동 방식 (수정불가)
|
||||
$LGD_CUSTOM_PROCESSTYPE = 'TWOTR'; //수정불가
|
||||
|
||||
/*
|
||||
*************************************************
|
||||
* 2. MD5 해쉬암호화 (수정하지 마세요) - BEGIN
|
||||
*
|
||||
* MD5 해쉬암호화는 거래 위변조를 막기위한 방법입니다.
|
||||
*************************************************
|
||||
*
|
||||
* 해쉬 암호화 적용( LGD_MID + LGD_OID + LGD_AMOUNT + LGD_TIMESTAMP + LGD_MERTKEY )
|
||||
* LGD_MID : 상점아이디
|
||||
* LGD_OID : 주문번호
|
||||
* LGD_AMOUNT : 금액
|
||||
* LGD_TIMESTAMP : 타임스탬프
|
||||
* LGD_MERTKEY : 상점MertKey (mertkey는 상점관리자 -> 계약정보 -> 상점정보관리에서 확인하실수 있습니다)
|
||||
*
|
||||
* MD5 해쉬데이터 암호화 검증을 위해
|
||||
* LG유플러스에서 발급한 상점키(MertKey)를 환경설정 파일(lgdacom/conf/mall.conf)에 반드시 입력하여 주시기 바랍니다.
|
||||
*/
|
||||
|
||||
$xpay = new XPay($configPath, $CST_PLATFORM);
|
||||
|
||||
// Mert Key 설정
|
||||
$xpay->set_config_value('t'.$LGD_MID, $config['cf_lg_mert_key']);
|
||||
$xpay->set_config_value($LGD_MID, $config['cf_lg_mert_key']);
|
||||
|
||||
$xpay->Init_TX($LGD_MID);
|
||||
$LGD_HASHDATA = md5($LGD_MID.$LGD_OID.$LGD_AMOUNT.$LGD_TIMESTAMP.$xpay->config[$LGD_MID]);
|
||||
/*
|
||||
*************************************************
|
||||
* 2. MD5 해쉬암호화 (수정하지 마세요) - END
|
||||
*************************************************
|
||||
*/
|
||||
|
||||
$payReqMap['CST_PLATFORM'] = $CST_PLATFORM; // 테스트, 서비스 구분
|
||||
$payReqMap['LGD_WINDOW_TYPE'] = $LGD_WINDOW_TYPE; // 수정불가
|
||||
$payReqMap['CST_MID'] = $CST_MID; // 상점아이디
|
||||
$payReqMap['LGD_MID'] = $LGD_MID; // 상점아이디
|
||||
$payReqMap['LGD_OID'] = $LGD_OID; // 주문번호
|
||||
$payReqMap['LGD_BUYER'] = $LGD_BUYER; // 구매자
|
||||
$payReqMap['LGD_PRODUCTINFO'] = $LGD_PRODUCTINFO; // 상품정보
|
||||
$payReqMap['LGD_AMOUNT'] = $LGD_AMOUNT; // 결제금액
|
||||
$payReqMap['LGD_BUYEREMAIL'] = $LGD_BUYEREMAIL; // 구매자 이메일
|
||||
$payReqMap['LGD_CUSTOM_SKIN'] = $LGD_CUSTOM_SKIN; // 결제창 SKIN
|
||||
$payReqMap['LGD_CUSTOM_PROCESSTYPE'] = $LGD_CUSTOM_PROCESSTYPE; // 트랜잭션 처리방식
|
||||
$payReqMap['LGD_TIMESTAMP'] = $LGD_TIMESTAMP; // 타임스탬프
|
||||
$payReqMap['LGD_HASHDATA'] = $LGD_HASHDATA; // MD5 해쉬암호값
|
||||
$payReqMap['LGD_RETURNURL'] = $LGD_RETURNURL; // 응답수신페이지
|
||||
$payReqMap['LGD_VERSION'] = $LGD_VERSION; // 버전정보 (삭제하지 마세요)
|
||||
$payReqMap['LGD_CUSTOM_USABLEPAY'] = $LGD_CUSTOM_USABLEPAY; // 디폴트 결제수단
|
||||
$payReqMap['LGD_CUSTOM_SWITCHINGTYPE'] = $LGD_CUSTOM_SWITCHINGTYPE; // 신용카드 카드사 인증 페이지 연동 방식
|
||||
$payReqMap['LGD_WINDOW_VER'] = $LGD_WINDOW_VER;
|
||||
$payReqMap['LGD_ENCODING'] = 'UTF-8';
|
||||
$payReqMap['LGD_ENCODING_RETURNURL'] = 'UTF-8';
|
||||
|
||||
|
||||
// 가상계좌(무통장) 결제연동을 하시는 경우 할당/입금 결과를 통보받기 위해 반드시 LGD_CASNOTEURL 정보를 LG 유플러스에 전송해야 합니다 .
|
||||
$payReqMap['LGD_CASNOTEURL'] = $LGD_CASNOTEURL; // 가상계좌 NOTEURL
|
||||
|
||||
//Return URL에서 인증 결과 수신 시 셋팅될 파라미터 입니다.*/
|
||||
$payReqMap['LGD_RESPCODE'] = '';
|
||||
$payReqMap['LGD_RESPMSG'] = '';
|
||||
$payReqMap['LGD_PAYKEY'] = '';
|
||||
|
||||
$_SESSION['PAYREQ_MAP'] = $payReqMap;
|
||||
|
||||
die(json_encode(array('LGD_HASHDATA' => $LGD_HASHDATA, 'error' => '')));
|
||||
@@ -0,0 +1,121 @@
|
||||
<?php
|
||||
if (!defined("_GNUBOARD_")) exit; // 개별 페이지 접근 불가
|
||||
|
||||
// LG유플러스 공통 설정
|
||||
require_once(G5_SHOP_PATH.'/settle_lg.inc.php');
|
||||
|
||||
/*
|
||||
* [최종결제요청 페이지(STEP2-2)]
|
||||
*
|
||||
* LG유플러스으로 부터 내려받은 LGD_PAYKEY(인증Key)를 가지고 최종 결제요청.(파라미터 전달시 POST를 사용하세요)
|
||||
*/
|
||||
|
||||
/* ※ 중요
|
||||
* 환경설정 파일의 경우 반드시 외부에서 접근이 가능한 경로에 두시면 안됩니다.
|
||||
* 해당 환경파일이 외부에 노출이 되는 경우 해킹의 위험이 존재하므로 반드시 외부에서 접근이 불가능한 경로에 두시기 바랍니다.
|
||||
* 예) [Window 계열] C:\inetpub\wwwroot\lgdacom ==> 절대불가(웹 디렉토리)
|
||||
*/
|
||||
|
||||
/*
|
||||
*************************************************
|
||||
* 1.최종결제 요청 - BEGIN
|
||||
* (단, 최종 금액체크를 원하시는 경우 금액체크 부분 주석을 제거 하시면 됩니다.)
|
||||
*************************************************
|
||||
*/
|
||||
$LGD_PAYKEY = isset($_POST['LGD_PAYKEY']) ? $_POST['LGD_PAYKEY'] : '';
|
||||
|
||||
$xpay = new XPay($configPath, $CST_PLATFORM);
|
||||
|
||||
// Mert Key 설정
|
||||
$xpay->set_config_value('t'.$LGD_MID, $config['cf_lg_mert_key']);
|
||||
$xpay->set_config_value($LGD_MID, $config['cf_lg_mert_key']);
|
||||
|
||||
$xpay->Init_TX($LGD_MID);
|
||||
|
||||
$xpay->Set('LGD_TXNAME', 'PaymentByKey');
|
||||
$xpay->Set('LGD_PAYKEY', $LGD_PAYKEY);
|
||||
|
||||
//금액을 체크하시기 원하는 경우 아래 주석을 풀어서 이용하십시요.
|
||||
//$DB_AMOUNT = "DB나 세션에서 가져온 금액"; //반드시 위변조가 불가능한 곳(DB나 세션)에서 금액을 가져오십시요.
|
||||
//$xpay->Set('LGD_AMOUNTCHECKYN', 'Y');
|
||||
//$xpay->Set('LGD_AMOUNT', $DB_AMOUNT);
|
||||
|
||||
/*
|
||||
*************************************************
|
||||
* 1.최종결제 요청(수정하지 마세요) - END
|
||||
*************************************************
|
||||
*/
|
||||
|
||||
/*
|
||||
* 2. 최종결제 요청 결과처리
|
||||
*
|
||||
* 최종 결제요청 결과 리턴 파라미터는 연동메뉴얼을 참고하시기 바랍니다.
|
||||
*/
|
||||
if ($xpay->TX()) {
|
||||
//1)결제결과 화면처리(성공,실패 결과 처리를 하시기 바랍니다.)
|
||||
/*
|
||||
echo "결제요청이 완료되었습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
echo "거래번호 : " . $xpay->Response("LGD_TID",0) . "<br>";
|
||||
echo "상점아이디 : " . $xpay->Response("LGD_MID",0) . "<br>";
|
||||
echo "상점주문번호 : " . $xpay->Response("LGD_OID",0) . "<br>";
|
||||
echo "결제금액 : " . $xpay->Response("LGD_AMOUNT",0) . "<br>";
|
||||
echo "결과코드 : " . $xpay->Response("LGD_RESPCODE",0) . "<br>";
|
||||
echo "결과메세지 : " . $xpay->Response("LGD_RESPMSG",0) . "<p>";
|
||||
|
||||
$keys = $xpay->Response_Names();
|
||||
foreach($keys as $name) {
|
||||
echo $name . " = " . $xpay->Response($name, 0) . "<br>";
|
||||
}
|
||||
|
||||
echo "<p>";
|
||||
exit;
|
||||
*/
|
||||
|
||||
if( '0000' == $xpay->Response_Code() ) {
|
||||
//최종결제요청 결과 성공 DB처리
|
||||
$tno = $xpay->Response('LGD_TID',0);
|
||||
$amount = $xpay->Response('LGD_AMOUNT',0);
|
||||
$app_time = $xpay->Response('LGD_PAYDATE',0);
|
||||
$bank_name = $bankname = $xpay->Response('LGD_FINANCENAME',0);
|
||||
$depositor = $xpay->Response('LGD_PAYER',0);
|
||||
$account = $xpay->Response('LGD_ACCOUNTNUM',0).' '.$xpay->Response('LGD_SAOWNER',0);
|
||||
$commid = $xpay->Response('LGD_FINANCENAME',0);
|
||||
$mobile_no = $xpay->Response('LGD_TELNO',0);
|
||||
$app_no = $od_app_no = $xpay->Response('LGD_FINANCEAUTHNUM',0);
|
||||
$card_name = $xpay->Response('LGD_FINANCENAME',0);
|
||||
$pay_type = $xpay->Response('LGD_PAYTYPE',0);
|
||||
$escw_yn = $xpay->Response('LGD_ESCROWYN',0);
|
||||
} else {
|
||||
//최종결제요청 결과 실패 DB처리
|
||||
//echo "최종결제요청 결과 실패 DB처리하시기 바랍니다.<br>";
|
||||
|
||||
if(G5_IS_MOBILE) {
|
||||
if(isset($_POST['pp_id']) && $_POST['pp_id']) {
|
||||
$page_return_url = G5_SHOP_URL.'/personalpayform.php?pp_id='.get_session('ss_personalpay_id');
|
||||
} else {
|
||||
$page_return_url = G5_SHOP_URL.'/orderform.php';
|
||||
if(get_session('ss_direct'))
|
||||
$page_return_url .= '?sw_direct=1';
|
||||
}
|
||||
|
||||
alert($xpay->Response_Msg().' 코드 : '.$xpay->Response_Code(), $page_return_url);
|
||||
} else {
|
||||
alert($xpay->Response_Msg().' 코드 : '.$xpay->Response_Code());
|
||||
}
|
||||
}
|
||||
} else {
|
||||
//2)API 요청실패 화면처리
|
||||
/*
|
||||
echo "결제요청이 실패하였습니다. <br>";
|
||||
echo "TX Response_code = " . $xpay->Response_Code() . "<br>";
|
||||
echo "TX Response_msg = " . $xpay->Response_Msg() . "<p>";
|
||||
|
||||
//최종결제요청 결과 실패 DB처리
|
||||
echo "최종결제요청 결과 실패 DB처리하시기 바랍니다.<br>";
|
||||
*/
|
||||
|
||||
alert($xpay->Response_Msg().' 코드 : '.$xpay->Response_Code());
|
||||
}
|
||||
Reference in New Issue
Block a user