source: branches/feature-module-update/html/shopping/convenience.php @ 15079

Revision 15079, 7.2 KB checked in by nanasess, 17 years ago (diff)

svn:mime-type application/x-httpd-php; charset=UTF-8 設定

  • Property svn:mime-type set to application/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8require_once("../require.php");
9
10class LC_Page {
11    function LC_Page() {
12        $this->tpl_mainpage = "shopping/convenience.tpl";
13        $this->tpl_css = URL_DIR.'css/layout/shopping/pay.css';
14        global $arrCONVENIENCE;
15        $this->arrCONVENIENCE = $arrCONVENIENCE;
16        /*
17         session_start時のno-cacheヘッダーを抑制することで
18         「戻る」ボタン使用時の有効期限切れ表示を抑制する。
19         private-no-expire:クライアントのキャッシュを許可する。
20        */
21        session_cache_limiter('private-no-expire');     
22    }
23}
24
25$objPage = new LC_Page;
26$objView = new SC_SiteView;
27$objSiteSess = new SC_SiteSession;
28$objCartSess = new SC_CartSession;
29$objCampaignSess = new SC_CampaignSession();
30$objSiteInfo = $objView->objSiteInfo;
31$objCustomer = new SC_Customer;
32
33$arrInfo = $objSiteInfo->data;
34
35// パラメータ管理クラス
36$objFormParam = new SC_FormParam();
37// パラメータ情報の初期化
38lfInitParam();
39// POST値の取得
40$objFormParam->setParam($_POST);
41
42// アクセスの正当性の判定
43$uniqid = sfCheckNormalAccess($objSiteSess, $objCartSess);
44
45//コンビニの種類で処理ファイルを切り替える
46switch($_POST['mode']) {
47//完了
48case 'complete':
49    //エラーチェック
50    $objPage->arrErr = lfCheckError();
51    if($objPage->arrErr == "") {
52        // マーチャント情報設定ファイルをインクルード
53        //require("merchant.ini");
54        // 決済処理パッケージをインクルード
55        require_once(DATA_PATH . "vtcvsmdk/mdk/lib/BSCVS/Transaction.php");
56        require_once(DATA_PATH . "vtcvsmdk/mdk/lib/BSCVS/Config.php");
57        require_once(DATA_PATH . "vtcvsmdk/mdk/lib/BSCVS/Log.php");
58   
59        // トランザクションインスタンスを作成
60        $objTran = new Transaction;
61       
62        // 設定ファイル cvsgwlib.conf によりインスタンスを初期化
63        $objTran->setServer(DATA_PATH . "vtcvsmdk/mdk/conf/cvsgwlib.conf");
64       
65        // カート集計処理
66        $objPage = sfTotalCart($objPage, $objCartSess, $arrInfo);
67        // 一時受注テーブルの読込
68        $arrData = sfGetOrderTemp($uniqid);
69        // カート集計を元に最終計算
70        $arrPrice = sfTotalConfirm($arrData, $objPage, $objCartSess, $arrInfo, $objCustomer);
71       
72        // ログ出力インスタンスを取得
73        $logger = $objTran->getLogger();
74       
75        // ログ出力(ここから)
76        $logger->logprint('DEBUG', '<<< 支払結果画面処理開始... >>>');
77       
78        //コンビニの種類からCVSタイプを決定する
79        switch($_POST['convenience']) {
80        //セブンイレブン
81        case '1':
82            $cvs_type = '01';
83            break;
84        //ファミリーマート
85        case '2':
86            $cvs_type = '03';
87            break;
88        //サークルKサンクス
89        case '3':
90            $cvs_type = '04';
91            break;
92        //その他
93        case '4':
94        case '5':
95            $cvs_type = '02';
96            break;
97        default:
98            sfDispSiteError(PAGE_ERROR, "", "", "", $objCampaignSess);
99            break;
100        }
101   
102        //リクエスト電文
103        $arrRequest = array(
104            // 取引 ID
105            REQ_ORDER_ID => $uniqid,       
106            // CVSタイプ
107            REQ_CVS_TYPE => $cvs_type,
108            // 金額
109            REQ_AMOUNT => $arrPrice['payment_total'],
110            // 支払期限
111            REQ_PAY_LIMIT => lfGetPayLimit(),
112            // 氏名(注意:ベリトランスコンビニゲートウェイは UTF-8 の文字のみを
113            // 受け付けるため、ゲートウェイ接続の前に UTF-8 コードへ変換)
114            REQ_NAME1 => $objTran->jCode($arrData['order_name01'], ENCODE_UTF8),
115            REQ_NAME2 => $objTran->jCode($arrData['order_name02'], ENCODE_UTF8),
116            REQ_KANA => $objTran->jCode($arrData['order_kana01'].$arrData['order_kana02'], ENCODE_UTF8),
117            // 電話番号
118            REQ_TEL_NO => $arrData['order_tel01']."-".$arrData['order_tel02']."-".$arrData['order_tel03']
119        );
120
121        //ベリトランスコンビニゲートウェイにリクエスト電文を投げ、取引結果を格納
122        $arrResult = $objTran->doTransaction(CMD_ENTRY, $arrRequest);
123        //取引成功
124        if($arrResult[RES_ACTION_CODE] = '010') {
125            //コンビニの種類
126            switch($_POST['convenience']) {
127            //セブンイレブン
128            case '1':
129                $arrRet['cv_type'] = '1';                                       //コンビニの種類
130                $arrRet['cv_payment_url'] = $arrResult[RES_HARAIKOMI_URL];      //払込票URL(PC)
131                $arrRet['cv_receipt_no'] = $arrResult[RES_RECEIPT_NO];          //払込票番号
132                break;
133            //ファミリーマート
134            case '2':
135                $company_code = substr($arrResult[RES_RECEIPT_NO], 0, 5);
136                $order_no = substr($arrResult[RES_RECEIPT_NO], 6, 12);
137                $arrRet['cv_type'] = '2';                       //コンビニの種類
138                $arrRet['cv_company_code'] = $company_code; //企業コード
139                $arrRet['cv_order_no'] = $order_no;         //受付番号
140                break;
141            //サークルKサンクス
142            case '3':
143                $mobile_url = preg_replace("/https:\/\/.+?\/JLPcon/","https://w2.kessai.info/JLM/JLMcon", $arrResult[RES_HARAIKOMI_URL]);
144                $arrRet['cv_type'] = '3';                                       //コンビニの種類
145                $arrRet['cv_payment_url'] = $arrResult[RES_HARAIKOMI_URL];      //払込票URL
146                $arrRet['cv_payment_mobile_url'] = $mobile_url;                 //払込票URL(モバイル)
147                break;
148            //ローソン、セイコーマート
149            case '4':
150                $arrRet['cv_type'] = '4';                                   //コンビニの種類
151                $arrRet['cv_receipt_no'] = $arrResult[RES_RECEIPT_NO];      //払込票番号
152                break;
153            //ミニストップ、デイリーヤマザキ、ヤマザキデイリーストア
154            case '5':
155                $arrRet['cv_type'] = '5';                                       //コンビニの種類
156                $arrRet['cv_payment_url'] = $arrResult[RES_HARAIKOMI_URL];      //払込票URL(PC)
157                break;
158            }
159            //支払期限
160            $arrRet['cv_payment_limit'] = lfGetPayLimit();
161            //コンビニ決済情報を格納
162            $sqlval['conveni_data'] = serialize($arrRet);
163            $objQuery = new SC_Query;
164            $objQuery->update("dtb_order_temp", $sqlval, "order_temp_id = ? ", array($uniqid));
165            // 正常に登録されたことを記録しておく
166            $objSiteSess->setRegistFlag();
167            //購入完了ページへ
168            header("Location: " . URL_SHOP_COMPLETE);
169        //失敗
170        } else {
171            $objPage->arrErr = 'エラーが発生しました。';
172        }
173       
174        # ログ出力(ここまで)
175        $logger->logprint('DEBUG', '<<< 支払結果画面処理終了. >>>');
176   
177    }
178    break;
179//戻る
180case 'return':
181    // 正常に登録されたことを記録しておく
182    $objSiteSess->setRegistFlag();
183    // 確認ページへ移動
184    header("Location: " . URL_SHOP_CONFIRM);
185    exit;
186    break;
187}
188
189$objView->assignobj($objPage);
190// フレームを選択(キャンペーンページから遷移なら変更)
191$objCampaignSess->pageView($objView);
192
193//-------------------------------------------------------------------------------------------------------------
194
195//支払期限の生成
196function lfGetPayLimit() {
197    $date = sprintf("%10s",
198                    date("Y/m/d",mktime(0,0,0,date("m"),
199                    date("d")+CV_PAYMENT_LIMIT,date("Y"))));
200    return $date;
201}
202
203//パラメータの初期化
204function lfInitParam() {
205    global $objFormParam;
206    $objFormParam->addParam("コンビニの種類", "convenience", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
207}
208   
209// 入力内容のチェック
210function lfCheckError() {
211    global $objFormParam;
212    // 入力データを渡す。
213    $arrRet =  $objFormParam->getHashArray();
214    $objErr = new SC_CheckError($arrRet);
215    $objErr->arrErr = $objFormParam->checkError();
216   
217    return $objErr->arrErr;
218}
219
220?>
Note: See TracBrowser for help on using the repository browser.