source: branches/version-2_5-dev/data/class/pages/shopping/LC_Page_Shopping.php @ 19939

Revision 19939, 19.9 KB checked in by spiritofof, 10 years ago (diff)

#790(非会員購入時カナチェック追加)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id Revision Date
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2010 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24// {{{ requires
25require_once(CLASS_REALDIR . "pages/LC_Page.php");
26
27/**
28 * ショッピングログインのページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Shopping extends LC_Page {
35
36    // {{{ properties
37
38    /** フォームパラメータ */
39    var $objFormParam;
40
41    /** 年 */
42    var $year;
43
44    // }}}
45    // {{{ functions
46
47    /**
48     * Page を初期化する.
49     *
50     * @return void
51     */
52    function init() {
53        parent::init();
54        $this->tpl_title = 'ログイン';
55        $masterData = new SC_DB_MasterData();
56        $this->arrPref = $masterData->getMasterData('mtb_pref');
57        $this->arrSex = $masterData->getMasterData("mtb_sex");
58        $this->arrJob = $masterData->getMasterData("mtb_job");
59        $this->tpl_onload = 'fnCheckInputDeliv();';
60        $this->httpCacheControl('nocache');
61    }
62
63    /**
64     * Page のプロセス.
65     *
66     * @return void
67     */
68    function process() {
69        parent::process();
70        $this->action();
71        $this->sendResponse();
72    }
73
74    /**
75     * Page のプロセス.
76     *
77     * @return void
78     */
79    function action() {
80        $objSiteSess = new SC_SiteSession();
81        $objCartSess = new SC_CartSession();
82        $objCustomer = new SC_Customer();
83        $objCookie = new SC_Cookie();
84        $objPurchase = new SC_Helper_Purchase_Ex();
85        $this->objFormParam = new SC_FormParam();            // フォーム用
86        $this->lfInitParam();                                // パラメータ情報の初期化
87        $this->objFormParam->setParam($_POST);            // POST値の取得
88
89        $uniqid = $objSiteSess->getUniqId();
90        $objPurchase->verifyChangeCart($uniqid, $objCartSess);
91
92        $this->tpl_uniqid = $uniqid;
93
94        $this->cartKey = $objCartSess->getKey();
95
96        // ログインチェック
97        if($objCustomer->isLoginSuccess(true)) {
98
99            switch ($this->cartKey) {
100            // ダウンロード商品の場合は支払方法設定画面に転送
101            case PRODUCT_TYPE_DOWNLOAD:
102                // 会員情報の住所を受注一時テーブルに書き込む
103                $objPurchase->saveOrderTemp($uniqid, array(), $objCustomer);
104                // 正常に登録されたことを記録しておく
105                $objSiteSess->setRegistFlag();
106                SC_Response_Ex::sendRedirect('payment.php');
107                exit;
108                break;
109
110            case PRODUCT_TYPE_NORMAL:
111            default:
112                // お届け先設定画面に転送
113                SC_Response_Ex::sendRedirect('deliv.php');
114                exit;
115            }
116        }
117
118        if ($_SERVER["REQUEST_METHOD"] == "POST") {
119            if (!SC_Helper_Session_Ex::isValidToken()) {
120                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
121            }
122        }
123
124        if (!isset($_POST['mode'])) $_POST['mode'] = "";
125
126        switch($_POST['mode']) {
127        case 'nonmember_confirm':
128            $this->tpl_mainpage = 'shopping/nonmember_input.tpl';
129            $this->tpl_title = 'お客様情報入力';
130            //非会員のダウンロード商品を含んだ買い物はNG
131            if ($this->cartKey == PRODUCT_TYPE_DOWNLOAD) {
132                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, $objSiteSess, false,
133                                             "ダウンロード商品を含むお買い物は、会員登録が必要です。<br/>お手数ですが、会員登録をお願いします。");
134            }
135            // ※breakなし
136        case 'confirm':
137            $this->arrErr = $this->lfCheckError();
138
139            // 入力エラーなし
140            if(count($this->arrErr) == 0) {
141                // DBへのデータ登録
142                $this->lfRegistData($uniqid, $objPurchase, $objCustomer, $this->cartKey);
143                // 正常に登録されたことを記録しておく
144                $objSiteSess->setRegistFlag();
145                // お支払い方法選択ページへ移動
146                SC_Response_Ex::sendRedirect(SHOPPING_PAYMENT_URL_PATH);
147                exit;
148            }
149
150            break;
151        // 前のページに戻る
152        case 'return':
153            // 確認ページへ移動
154            SC_Response_Ex::sendRedirect(CART_URL_PATH);
155            exit;
156            break;
157
158        case 'multiple':
159            $this->arrErr = $this->lfCheckError();
160
161            // 入力エラーなし
162            if(count($this->arrErr) == 0) {
163                // DBへのデータ登録
164                $this->lfRegistData($uniqid, $objPurchase, $objCustomer, $this->cartKey, true);
165                // 正常に登録されたことを記録しておく
166                $objSiteSess->setRegistFlag();
167
168                SC_Response_Ex::sendRedirect(MULTIPLE_URL_PATH);
169                exit;
170            }
171            // breakなし
172
173        case 'nonmember':
174            $this->tpl_mainpage = 'shopping/nonmember_input.tpl';
175            $this->tpl_title = 'お客様情報入力';
176            //非会員のダウンロード商品を含んだ買い物はNG
177            if ($this->cartKey == PRODUCT_TYPE_DOWNLOAD) {
178                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, $objSiteSess, false,
179                                             "ダウンロード商品を含むお買い物は、会員登録が必要です。<br/>お手数ですが、会員登録をお願いします。");
180            }
181            // ※breakなし
182        default:
183            if(isset($_GET['from']) && $_GET['from'] == 'nonmember') {
184                $this->tpl_mainpage = 'shopping/nonmember_input.tpl';
185                $this->tpl_title = 'お客様情報入力';
186            }
187            $arrOrderTemp = $objPurchase->getOrderTemp($uniqid);
188            if (empty($arrOrderTemp)) $arrOrderTemp = array('order_email' => "",
189                                                            'order_birth' => "");
190            $arrShippingTemp = $objPurchase->getShippingTemp();
191            // DB値の取得
192            $this->objFormParam->setParam($arrOrderTemp);
193            /*
194             * count($arrShippingTemp) > 1 は複数配送であり,
195             * $arrShippingTemp[0] は注文者が格納されている
196             */
197            if (count($arrShippingTemp) > 1) {
198                $this->objFormParam->setParam($arrShippingTemp[1]);
199            } else {
200                $this->objFormParam->setParam($arrShippingTemp[0]);
201            }
202            $this->objFormParam->setValue('order_email02', $arrOrderTemp['order_email']);
203            $this->objFormParam->setDBDate($arrOrderTemp['order_birth']);
204            $objPurchase->unsetShippingTemp();
205        }
206
207        // クッキー判定
208        $this->tpl_login_email = $objCookie->getCookie('login_email');
209        if($this->tpl_login_email != "") {
210            $this->tpl_login_memory = "1";
211        }
212
213        // 生年月日選択肢の取得
214        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
215        $this->arrYear = $objDate->getYear('', 1950, '');
216        $this->arrMonth = $objDate->getMonth(true);
217        $this->arrDay = $objDate->getDay(true);
218
219        // 入力値の取得
220        $this->arrForm = $this->objFormParam->getFormParamList();
221
222        $this->transactionid = SC_Helper_Session_Ex::getToken();
223
224        // 携帯端末IDが一致する会員が存在するかどうかをチェックする。
225        if(Net_UserAgent_Mobile::isMobile() === true) {
226            $this->tpl_valid_phone_id = $objCustomer->checkMobilePhoneId();
227        }
228    }
229
230    /**
231     * Page のプロセス(モバイル).
232     *
233     * @return void
234     */
235    function mobileAction() {
236        $objView = new SC_MobileView();
237        $objSiteSess = new SC_SiteSession();
238        $objCartSess = new SC_CartSession();
239        $objCustomer = new SC_Customer();
240        $objCookie = new SC_Cookie();
241        $this->objFormParam = new SC_FormParam();            // フォーム用
242        $helperMobile = new SC_Helper_Mobile_Ex();
243        $objDb = new SC_Helper_DB_Ex();
244        $this->lfInitParam();                                // パラメータ情報の初期化
245        $this->objFormParam->setParam($_POST);            // POST値の取得
246
247        // ユーザユニークIDの取得と購入状態の正当性をチェック
248        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
249
250        $this->tpl_uniqid = $uniqid;
251
252        //ダウンロード商品判定
253        $this->cartdown = $objDb->chkCartDown($objCartSess);
254
255        // ログインチェック
256        if($objCustomer->isLoginSuccess(true)) {
257            // すでにログインされている場合
258            if ($this->cartdown == 2) {
259                // 会員情報の住所を受注一時テーブルに書き込む
260                $objDb->sfRegistDelivData($uniqid, $objCustomer);
261                // 正常に登録されたことを記録しておく
262                $objSiteSess->setRegistFlag();
263                //カート内が全てダウンロード商品の場合は支払方法設定画面に転送
264                SC_Response_Ex::sendRedirect('payment.php');
265            } else {
266                // お届け先設定画面に転送
267                SC_Response_Ex::sendRedirect('deliv.php');
268            }
269            exit;
270        }
271
272        // 携帯端末IDが一致する会員が存在するかどうかをチェックする。
273        $this->tpl_valid_phone_id = $objCustomer->checkMobilePhoneId();
274
275        // クッキー判定
276        $this->tpl_login_email = $objCookie->getCookie('login_email');
277        if($this->tpl_login_email != "") {
278            $this->tpl_login_memory = "1";
279        }
280    }
281
282    /**
283     * デストラクタ.
284     *
285     * @return void
286     */
287    function destroy() {
288        parent::destroy();
289    }
290
291    /* パラメータ情報の初期化 */
292    function lfInitParam() {
293        $this->objFormParam->addParam("お名前(姓)", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
294        $this->objFormParam->addParam("お名前(名)", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
295        $this->objFormParam->addParam("お名前(フリガナ・姓)", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "KANA_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
296        $this->objFormParam->addParam("お名前(フリガナ・名)", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "KANA_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
297        $this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
298        $this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
299        $this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
300        $this->objFormParam->addParam("住所1", "order_addr01", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
301        $this->objFormParam->addParam("住所2", "order_addr02", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
302        $this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
303        $this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
304        $this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
305        $this->objFormParam->addParam("FAX番号1", "order_fax01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
306        $this->objFormParam->addParam("FAX番号2", "order_fax02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
307        $this->objFormParam->addParam("FAX番号3", "order_fax03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
308        $this->objFormParam->addParam("メールアドレス", "order_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
309        $this->objFormParam->addParam("メールアドレス(確認)", "order_email02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"), "", false);
310        $this->objFormParam->addParam("年", "year", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
311        $this->objFormParam->addParam("月", "month", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
312        $this->objFormParam->addParam("日", "day", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
313        $this->objFormParam->addParam("性別", "order_sex", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
314        $this->objFormParam->addParam("職業", "order_job", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
315        $this->objFormParam->addParam("別のお届け先", "deliv_check", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
316        $this->objFormParam->addParam("お名前(姓)", "shipping_name01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
317        $this->objFormParam->addParam("お名前(名)", "shipping_name02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
318        $this->objFormParam->addParam("お名前(フリガナ・姓)", "shipping_kana01", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
319        $this->objFormParam->addParam("お名前(フリガナ・名)", "shipping_kana02", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
320        $this->objFormParam->addParam("郵便番号1", "shipping_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
321        $this->objFormParam->addParam("郵便番号2", "shipping_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
322        $this->objFormParam->addParam("都道府県", "shipping_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
323        $this->objFormParam->addParam("住所1", "shipping_addr01", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
324        $this->objFormParam->addParam("住所2", "shipping_addr02", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
325        $this->objFormParam->addParam("電話番号1", "shipping_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
326        $this->objFormParam->addParam("電話番号2", "shipping_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
327        $this->objFormParam->addParam("電話番号3", "shipping_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
328        $this->objFormParam->addParam("メールマガジン", "mail_flag", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), 1);
329    }
330
331    /* DBへデータの登録 */
332    function lfRegistData($uniqid, &$objPurchase, &$objCustomer, $productTypeId, $isMultiple = false) {
333        $params = $this->objFormParam->getHashArray();
334        $sqlval = $this->objFormParam->getDbArray();
335        // 登録データの作成
336        $sqlval['order_birth'] = SC_Utils_Ex::sfGetTimestamp($params['year'], $params['month'], $params['day']);
337        $sqlval['update_date'] = 'Now()';
338        $sqlval['customer_id'] = '0';
339
340        // お届け先を指定しない場合、
341        if ($params['deliv_check'] != '1') {
342            // order_* を shipping_* へコピー
343            $objPurchase->copyFromOrder($sqlval, $params);
344        }
345
346        $deliv_id = $objPurchase->getDeliv($productTypeId);
347        $order_val = array('deliv_id' => $deliv_id);
348        $shipping_val = array('deliv_id' => $deliv_id);
349
350        /*
351         * order_* と shipping_* をそれぞれ $_SESSION['shipping'][$shipping_id]
352         * に, shipping_* というキーで保存
353         */
354        foreach ($sqlval as $key => $val) {
355            if (preg_match('/^order_/', $key)) {
356                $order_val['shipping_' . str_replace('order_', '', $key)] = $val;
357            } elseif (preg_match('/^shipping_/', $key)) {
358                $shipping_val[$key] = $val;
359            }
360        }
361
362        if ($isMultiple) {
363            $objPurchase->saveShippingTemp($order_val, 0);
364            if ($params['deliv_check'] == '1') {
365                $objPurchase->saveShippingTemp($shipping_val, 1);
366            }
367        } else {
368            if ($params['deliv_check'] == '1') {
369                $objPurchase->saveShippingTemp($shipping_val, 0);
370            } else {
371                $objPurchase->saveShippingTemp($order_val, 0);
372            }
373        }
374        $objPurchase->saveOrderTemp($uniqid, $sqlval, $objCustomer);
375    }
376
377    /* 入力内容のチェック */
378    function lfCheckError() {
379        // 入力値の変換
380        $this->objFormParam->convParam();
381        $this->objFormParam->toLower('order_mail');
382        $this->objFormParam->toLower('order_mail_check');
383
384        // 入力データを渡す。
385        $arrRet = $this->objFormParam->getHashArray();
386        $objErr = new SC_CheckError($arrRet);
387        $objErr->arrErr = $this->objFormParam->checkError();
388
389        // 別のお届け先チェック
390        if(isset($_POST['deliv_check']) && $_POST['deliv_check'] == "1") {
391            $objErr->doFunc(array("お名前(姓)", "shipping_name01"), array("EXIST_CHECK"));
392            $objErr->doFunc(array("お名前(名)", "shipping_name02"), array("EXIST_CHECK"));
393            $objErr->doFunc(array("お名前(フリガナ・姓)", "shipping_kana01"), array("EXIST_CHECK"));
394            $objErr->doFunc(array("お名前(フリガナ・名)", "shipping_kana02"), array("EXIST_CHECK"));
395            $objErr->doFunc(array("郵便番号1", "shipping_zip01"), array("EXIST_CHECK"));
396            $objErr->doFunc(array("郵便番号2", "shipping_zip02"), array("EXIST_CHECK"));
397            $objErr->doFunc(array("都道府県", "shipping_pref"), array("EXIST_CHECK"));
398            $objErr->doFunc(array("住所1", "shipping_addr01"), array("EXIST_CHECK"));
399            $objErr->doFunc(array("住所2", "shipping_addr02"), array("EXIST_CHECK"));
400            $objErr->doFunc(array("電話番号1", "shipping_tel01"), array("EXIST_CHECK"));
401            $objErr->doFunc(array("電話番号2", "shipping_tel02"), array("EXIST_CHECK"));
402            $objErr->doFunc(array("電話番号3", "shipping_tel03"), array("EXIST_CHECK"));
403        }
404
405        // 複数項目チェック
406        $objErr->doFunc(array("TEL", "order_tel01", "order_tel02", "order_tel03"), array("TEL_CHECK"));
407        $objErr->doFunc(array("FAX", "order_fax01", "order_fax02", "order_fax03"), array("TEL_CHECK"));
408        $objErr->doFunc(array("郵便番号", "order_zip01", "order_zip02"), array("ALL_EXIST_CHECK"));
409        $objErr->doFunc(array("TEL", "shipping_tel01", "shipping_tel02", "shipping_tel03"), array("TEL_CHECK"));
410        $objErr->doFunc(array("郵便番号", "shipping_zip01", "shipping_zip02"), array("ALL_EXIST_CHECK"));
411        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_BIRTHDAY"));
412        $objErr->doFunc(array("メールアドレス", "メールアドレス(確認)", "order_email", "order_email02"), array("EQUAL_CHECK"));
413
414        return $objErr->arrErr;
415    }
416}
417?>
Note: See TracBrowser for help on using the repository browser.