source: branches/comu-ver2/data/class/pages/mypage/LC_Page_Mypage_DeliveryAddr.php @ 18638

Revision 18638, 9.9 KB checked in by Seasoft, 14 years ago (diff)

#717(電話番号の判定のパラメータ(文字数制限)誤り) 改修

  • 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-2007 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_PATH . "pages/LC_Page.php");
26
27/**
28 * お届け先追加 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Mypage_DeliveryAddr extends LC_Page {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = TEMPLATE_DIR . 'mypage/delivery_addr.tpl';
47        $this->tpl_title = "お届け先の追加・変更";
48        $masterData = new SC_DB_MasterData_Ex();
49        $this->arrPref= $masterData->getMasterData("mtb_pref",
50                            array("pref_id", "pref_name", "rank"));
51        $this->httpCacheControl('nocache');
52    }
53
54    /**
55     * Page のプロセス.
56     *
57     * @return void
58     */
59    function process() {
60        $objView = new SC_SiteView(false);
61        $objQuery = new SC_Query();
62        $objCustomer = new SC_Customer();
63        $ParentPage = MYPAGE_DELIVADDR_URL;
64
65        // GETでページを指定されている場合には指定ページに戻す
66        if (isset($_GET['page'])) {
67            $ParentPage = htmlspecialchars($_GET['page'],ENT_QUOTES);
68        }else if(isset($_POST['ParentPage'])) {
69            $ParentPage = htmlspecialchars($_POST['ParentPage'],ENT_QUOTES);
70        }
71        $this->ParentPage = $ParentPage;
72
73        //ログイン判定
74        if (!$objCustomer->isLoginSuccess()){
75            SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
76        }
77
78        if (!isset($_POST['mode'])) $_POST['mode'] = "";
79        if (!isset($_GET['other_deliv_id'])) $_GET['other_deliv_id'] = "";
80
81        if ($_POST['mode'] == ""){
82            $_SESSION['other_deliv_id'] = $_GET['other_deliv_id'];
83        }
84
85        if ($_GET['other_deliv_id'] != ""){
86            //不正アクセス判定
87            $flag = $objQuery->count("dtb_other_deliv", "customer_id=? AND other_deliv_id=?", array($objCustomer->getValue("customer_id"), $_SESSION['other_deliv_id']));
88            if (!$objCustomer->isLoginSuccess() || $flag == 0){
89                SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
90            }
91        }
92
93        //別のお届け先DB登録用カラム配列
94        $arrRegistColumn = array(
95                                 array("column" => "name01",    "convert" => "aKV"),
96                                 array("column" => "name02",    "convert" => "aKV"),
97                                 array("column" => "kana01",    "convert" => "CKV"),
98                                 array("column" => "kana02",    "convert" => "CKV"),
99                                 array("column" => "zip01",     "convert" => "n"),
100                                 array("column" => "zip02",     "convert" => "n"),
101                                 array("column" => "pref",      "convert" => "n"),
102                                 array("column" => "addr01",    "convert" => "aKV"),
103                                 array("column" => "addr02",    "convert" => "aKV"),
104                                 array("column" => "tel01",     "convert" => "n"),
105                                 array("column" => "tel02",     "convert" => "n"),
106                                 array("column" => "tel03",     "convert" => "n"),
107                                 );
108
109
110        if ($_GET['other_deliv_id'] != ""){
111            //別のお届け先情報取得
112            $arrOtherDeliv = $objQuery->select("*", "dtb_other_deliv", "other_deliv_id=? ", array($_SESSION['other_deliv_id']));
113            $this->arrForm = $arrOtherDeliv[0];
114        }
115
116        switch ($_POST['mode']) {
117            case 'edit':
118                $_POST = $this->lfConvertParam($_POST,$arrRegistColumn);
119                $this->arrErr = $this->lfErrorCheck($_POST);
120                if ($this->arrErr){
121                    foreach ($_POST as $key => $val){
122                        if ($val != "") $this->arrForm[$key] = $val;
123                    }
124                } else {
125                   
126                    if ($_POST['ParentPage'] == MYPAGE_DELIVADDR_URL || $_POST['ParentPage'] == URL_DELIV_TOP) {
127                        $this->tpl_onload = "fnUpdateParent('". $this->getLocation($_POST['ParentPage']) ."'); window.close();";
128                    } else {
129                        SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
130                    }
131                   
132                    $this->lfRegistData($_POST, $arrRegistColumn, $objCustomer);
133                }
134                break;
135        }
136
137        $objView->assignobj($this);
138        $objView->display($this->tpl_mainpage);
139    }
140
141    /**
142     * デストラクタ.
143     *
144     * @return void
145     */
146    function destroy() {
147        parent::destroy();
148    }
149
150    /* エラーチェック */
151    function lfErrorCheck() {
152        $objErr = new SC_CheckError();
153
154        $objErr->doFunc(array("お名前(姓)", 'name01', STEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
155        $objErr->doFunc(array("お名前(名)", 'name02', STEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK", "MAX_LENGTH_CHECK"));
156        $objErr->doFunc(array("フリガナ(姓)", 'kana01', STEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK"));
157        $objErr->doFunc(array("フリガナ(名)", 'kana02', STEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK", "MAX_LENGTH_CHECK", "KANA_CHECK"));
158        $objErr->doFunc(array("郵便番号1", "zip01", ZIP01_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
159        $objErr->doFunc(array("郵便番号2", "zip02", ZIP02_LEN ) ,array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
160        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
161        $objErr->doFunc(array("都道府県", 'pref'), array("SELECT_CHECK","NUM_CHECK"));
162        $objErr->doFunc(array("住所(1)", "addr01", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
163        $objErr->doFunc(array("住所(2)", "addr02", MTEXT_LEN), array("EXIST_CHECK","SPTAB_CHECK","MAX_LENGTH_CHECK"));
164        $objErr->doFunc(array("電話番号1", 'tel01'), array("EXIST_CHECK","NUM_CHECK"));
165        $objErr->doFunc(array("電話番号2", 'tel02'), array("EXIST_CHECK","NUM_CHECK"));
166        $objErr->doFunc(array("電話番号3", 'tel03'), array("EXIST_CHECK","NUM_CHECK"));
167        $objErr->doFunc(array("電話番号", "tel01", "tel02", "tel03") ,array("TEL_CHECK"));
168        return $objErr->arrErr;
169
170    }
171
172    /* 登録実行 */
173    function lfRegistData($array, $arrRegistColumn, &$objCustomer) {
174        $objConn = new SC_DBConn();
175        $objQuery = new SC_Query();
176        foreach ($arrRegistColumn as $data) {
177            if (strlen($array[ $data["column"] ]) > 0) {
178                $arrRegist[ $data["column"] ] = $array[ $data["column"] ];
179            }
180        }
181
182        $arrRegist['customer_id'] = $objCustomer->getvalue('customer_id');
183
184        // 追加
185        if (strlen($_POST['other_deliv_id'] == 0)) {
186            // 別のお届け先登録数の取得
187            $deliv_count = $objQuery->count("dtb_other_deliv", "customer_id=?", array($objCustomer->getValue('customer_id')));
188            // 別のお届け先最大登録数に達している場合、エラー
189            if ($deliv_count >= DELIV_ADDR_MAX) {
190                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, "", false, '別のお届け先最大登録数に達しています。');
191            }
192           
193            // 実行
194            $objConn->autoExecute("dtb_other_deliv", $arrRegist);
195           
196        // 変更
197        } else {
198            $deliv_count = $objQuery->count("dtb_other_deliv","customer_id=? and other_deliv_id = ?" ,array($objCustomer->getValue('customer_id'), $_POST['other_deliv_id']));
199            if ($deliv_count != 1) {
200                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, "", false, '一致する別のお届け先がありません。');
201            }
202           
203            // 実行
204            $objConn->autoExecute("dtb_other_deliv", $arrRegist,
205                                  "other_deliv_id = "
206                                  . SC_Utils_Ex::sfQuoteSmart($array["other_deliv_id"]));
207        }
208    }
209
210    //---- 取得文字列の変換
211    function lfConvertParam($array, $arrRegistColumn) {
212        /*
213         *  文字列の変換
214         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
215         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
216         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
217         *  n :  「全角」数字を「半角(ハンカク)」に変換
218         *  a :  全角英数字を半角英数字に変換する
219         */
220        // カラム名とコンバート情報
221        foreach ($arrRegistColumn as $data) {
222            $arrConvList[ $data["column"] ] = $data["convert"];
223        }
224
225        // 文字変換
226        foreach ($arrConvList as $key => $val) {
227            // POSTされてきた値のみ変換する。
228            if(strlen(($array[$key])) > 0) {
229                $array[$key] = mb_convert_kana($array[$key] ,$val);
230            }
231        }
232        return $array;
233    }
234}
235?>
Note: See TracBrowser for help on using the repository browser.