- Timestamp:
- 2007/07/20 15:58:59 (17 years ago)
- Location:
- branches/feature-module-update
- Files:
-
- 1 edited
- 2 copied
Legend:
- Unmodified
- Added
- Removed
-
branches/feature-module-update
-
Property
svn:ignore
set to
.cache
.settings
.projectOptions
-
Property
svn:ignore
set to
-
branches/feature-module-update/html/admin/system/input.php
r14993 r15078 8 8 9 9 class LC_Page { 10 var $arrErr; // ¥¨¥é¡¼¥á¥Ã¥»¡¼¥¸½ÐÎÏÍÑ11 var $tpl_recv; // ÆþÎϾðÊóPOSTÀè12 var $tpl_onload; // ¥Ú¡¼¥¸Æɤ߹þ¤ß»þ¤Î¥¤¥Ù¥ó¥È13 var $arrForm; // ¥Õ¥©¡¼¥à½ÐÎÏÍÑ14 var $tpl_mode; // ¿·µ¬ºîÀ®:new or ÊÔ½¸:edit15 var $tpl_member_id; // ÊÔ½¸»þ¤Ë»ÈÍѤ¹¤ë¡£10 var $arrErr; // エラーメッセージ出力用 11 var $tpl_recv; // 入力情報POST先 12 var $tpl_onload; // ページ読み込み時のイベント 13 var $arrForm; // フォーム出力用 14 var $tpl_mode; // 新規作成:new or 編集:edit 15 var $tpl_member_id; // 編集時に使用する。 16 16 var $tpl_pageno; 17 var $tpl_onfocus; // ¥Ñ¥¹¥ï¡¼¥É¹àÌÜÁªÂò»þ¤Î¥¤¥Ù¥ó¥ÈÍÑ17 var $tpl_onfocus; // パスワード項目選択時のイベント用 18 18 var $tpl_old_login_id; 19 19 function LC_Page() { … … 32 32 $objView = new SC_AdminView(); 33 33 34 // ǧ¾Ú²ÄÈݤÎȽÄê34 // 認証可否の判定 35 35 $objSess = new SC_Session(); 36 36 sfIsSuccess($objSess); 37 37 38 // member_id ¤¬»ØÄꤵ¤ì¤Æ¤¤¤¿¾ì¹ç¡¢ÊÔ½¸¥â¡¼¥É¤È¤¹¤ë¡£38 // member_idが指定されていた場合、編集モードとする。 39 39 if(sfIsInt($_GET['id'])) { 40 40 $objPage->tpl_mode = 'edit'; 41 41 $objPage->tpl_member_id = $_GET['id']; 42 42 $objPage->tpl_onfocus = "fnClearText(this.name);"; 43 // DB ¤Î¥á¥ó¥Ð¡¼¾ðÊó¤òÆɤ߽Ф¹43 // DBのメンバー情報を読み出す 44 44 $data_list = fnGetMember($conn, $_GET['id']); 45 // ³ºÅö¥æ¡¼¥¶¤òɽ¼¨¤µ¤»¤ë45 // 該当ユーザを表示させる 46 46 $objPage->arrForm = $data_list[0]; 47 // ¥À¥ß¡¼¤Î¥Ñ¥¹¥ï¡¼¥É¤ò¥»¥Ã¥È¤·¤Æ¤ª¤¯¡£47 // ダミーのパスワードをセットしておく。 48 48 $objPage->arrForm['password'] = DUMMY_PASS; 49 // ¥í¥°¥¤¥óID¤òÊݴɤ·¤Æ¤ª¤¯¡£49 // ログインIDを保管しておく。 50 50 $objPage->tpl_old_login_id = $data_list[0]['login_id']; 51 51 52 52 $objPage->tpl_uniqid = $objSess->getUniqId(); 53 53 } else { 54 // ¿·µ¬ºîÀ®¥â¡¼¥É54 // 新規作成モード 55 55 $objPage->tpl_mode = "new"; 56 56 $objPage->arrForm['authority'] = -1; 57 57 } 58 58 59 // ¿·µ¬ºîÀ®¥â¡¼¥É or ÊÔ½¸¥â¡¼¥É59 // 新規作成モード or 編集モード 60 60 if( $_POST['mode'] == 'new' || $_POST['mode'] == 'edit') { 61 // ²èÌÌÁ«°Ü¤ÎÀµÅöÀ¥Á¥§¥Ã¥¯61 // 画面遷移の正当性チェック 62 62 if (sfIsValidTransition($objSess) == false) { 63 63 sfDispError(INVALID_MOVE_ERRORR); 64 64 } 65 // ÆþÎÏ¥¨¥é¡¼¥Á¥§¥Ã¥¯65 // 入力エラーチェック 66 66 $objPage->arrErr = fnErrorCheck($conn); 67 67 68 // ÆþÎϤ¬Àµ¾ï¤Ç¤¢¤Ã¤¿¾ì¹ç¤Ï¡¢DB¤Ë½ñ¤¹þ¤à68 // 入力が正常であった場合は、DBに書き込む 69 69 if(count($objPage->arrErr) == 0) { 70 70 if($_POST['mode'] == 'new') { 71 // ¥á¥ó¥Ð¡¼¤ÎÄɲÃ71 // メンバーの追加 72 72 fnInsertMember(); 73 // ¥ê¥í¡¼¥É¤Ë¤è¤ëÆó½ÅÅÐÏ¿Âкö¤Î¤¿¤á¡¢Æ±¤¸¥Ú¡¼¥¸¤ËÈô¤Ð¤¹¡£73 // リロードによる二重登録対策のため、同じページに飛ばす。 74 74 header("Location: ". $_SERVER['PHP_SELF'] . "?mode=reload"); 75 75 exit; 76 76 } 77 77 if($_POST['mode'] == 'edit') { 78 // ¥á¥ó¥Ð¡¼¤ÎÄɲÃ78 // メンバーの追加 79 79 if(fnUpdateMember($_POST['member_id'])) { 80 // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¸å¡¢¼«¥¦¥£¥ó¥É¥¦¤òÊĤ¸¤ë¡£80 // 親ウィンドウを更新後、自ウィンドウを閉じる。 81 81 $url = URL_SYSTEM_TOP . "?pageno=".$_POST['pageno']; 82 82 $objPage->tpl_onload="fnUpdateParent('".$url."'); window.close();"; 83 83 } 84 84 } 85 // ÆþÎÏ¥¨¥é¡¼¤¬È¯À¸¤·¤¿¾ì¹ç85 // 入力エラーが発生した場合 86 86 } else { 87 // ¥â¡¼¥É¤ÎÀßÄê87 // モードの設定 88 88 $objPage->tpl_mode = $_POST['mode']; 89 89 $objPage->tpl_member_id = $_POST['member_id']; 90 90 $objPage->tpl_old_login_id = $_POST['old_login_id']; 91 // ¤¹¤Ç¤ËÆþÎϤ·¤¿Ãͤòɽ¼¨¤¹¤ë¡£91 // すでに入力した値を表示する。 92 92 $objPage->arrForm = $_POST; 93 // Ä̾ïÆþÎϤΥѥ¹¥ï¡¼¥É¤Ï°ú¤·Ñ¤¬¤Ê¤¤¡£93 // 通常入力のパスワードは引き継がない。 94 94 if($objPage->arrForm['password'] != DUMMY_PASS) { 95 95 $objPage->arrForm['password'] = ''; … … 98 98 } 99 99 100 // ¥ê¥í¡¼¥É¤Î»ØÄ꤬¤¢¤Ã¤¿¾ì¹ç100 // リロードの指定があった場合 101 101 if( $_GET['mode'] == 'reload') { 102 // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¤¹¤ë¤è¤¦¤Ë¥»¥Ã¥È¤¹¤ë¡£102 // 親ウィンドウを更新するようにセットする。 103 103 $url = URL_SYSTEM_TOP; 104 104 $objPage->tpl_onload="fnUpdateParent('".$url."')"; 105 105 } 106 106 107 // ²èÌÌÁ«°Ü¤ÎÀµÅöÀ¥Á¥§¥Ã¥¯ÍѤËuniqid¤òËä¤á¹þ¤à107 // 画面遷移の正当性チェック用にuniqidを埋め込む 108 108 $objPage->tpl_uniqid = $objSess->getUniqId(); 109 109 110 // ¥Æ¥ó¥×¥ì¡¼¥ÈÍÑÊÑ¿ô¤Î³ä¤êÅö¤Æ110 // テンプレート用変数の割り当て 111 111 $objView->assignobj($objPage); 112 112 $objView->display('system/input.tpl'); 113 113 114 /* ÆþÎÏ¥¨¥é¡¼¤Î¥Á¥§¥Ã¥¯*/114 /* 入力エラーのチェック */ 115 115 function fnErrorCheck($conn) { 116 116 … … 120 120 $_POST["department"] = mb_convert_kana($_POST["department"] ,"KV"); 121 121 122 // ̾Á°¥Á¥§¥Ã¥¯123 $objErr->doFunc(array(" ̾Á°",'name'), array("EXIST_CHECK"));124 $objErr->doFunc(array(" ̾Á°",'name',STEXT_LEN,"BIG"), array("MAX_LENGTH_CHECK"));125 126 // ÊÔ½¸¥â¡¼¥É¤Ç¤Ê¤¤¾ì¹ç¤Ï¡¢½ÅÊ£¥Á¥§¥Ã¥¯122 // 名前チェック 123 $objErr->doFunc(array("名前",'name'), array("EXIST_CHECK")); 124 $objErr->doFunc(array("名前",'name',STEXT_LEN,"BIG"), array("MAX_LENGTH_CHECK")); 125 126 // 編集モードでない場合は、重複チェック 127 127 if (!isset($objErr->arrErr['name']) && $_POST['mode'] != 'edit') { 128 128 $sql = "SELECT name FROM dtb_member WHERE del_flg <> 1 AND name = ?"; 129 129 $result = $conn->getOne($sql, array($_POST['name'])); 130 130 if ( $result ) { 131 $objErr->arrErr['name'] = " ´û¤ËÅÐÏ¿¤µ¤ì¤Æ¤¤¤ë̾Á°¤Ê¤Î¤ÇÍøÍѤǤ¤Þ¤»¤ó¡£<br>";131 $objErr->arrErr['name'] = "既に登録されている名前なので利用できません。<br>"; 132 132 } 133 133 } 134 134 135 // ¥í¥°¥¤¥óID¥Á¥§¥Ã¥¯136 $objErr->doFunc(array(" ¥í¥°¥¤¥óID",'login_id'), array("EXIST_CHECK", "ALNUM_CHECK"));137 $objErr->doFunc(array(" ¥í¥°¥¤¥óID",'login_id',ID_MIN_LEN , ID_MAX_LEN) ,array("NUM_RANGE_CHECK"));138 139 // ¿·µ¬¥â¡¼¥É¤â¤·¤¯¤Ï¡¢ÊÔ½¸¥â¡¼¥É¤Ç¥í¥°¥¤¥óID¤¬Êѹ¹¤µ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ï¥Á¥§¥Ã¥¯¤¹¤ë¡£135 // ログインIDチェック 136 $objErr->doFunc(array("ログインID",'login_id'), array("EXIST_CHECK", "ALNUM_CHECK")); 137 $objErr->doFunc(array("ログインID",'login_id',ID_MIN_LEN , ID_MAX_LEN) ,array("NUM_RANGE_CHECK")); 138 139 // 新規モードもしくは、編集モードでログインIDが変更されている場合はチェックする。 140 140 if (!isset($objErr->arrErr['login_id']) && $_POST['mode'] != 'edit' || ($_POST['mode'] == 'edit' && $_POST['login_id'] != $_POST['old_login_id'])) { 141 141 $sql = "SELECT login_id FROM dtb_member WHERE del_flg <> 1 AND login_id = ?"; 142 142 $result = $conn->getOne($sql, array($_POST['login_id'])); 143 143 if ( $result != "" ) { 144 $objErr->arrErr['login_id'] = " ´û¤ËÅÐÏ¿¤µ¤ì¤Æ¤¤¤ëID¤Ê¤Î¤ÇÍøÍѤǤ¤Þ¤»¤ó¡£<br>";145 } 146 } 147 148 // ¥Ñ¥¹¥ï¡¼¥É¥Á¥§¥Ã¥¯(ÊÔ½¸¥â¡¼¥É¤ÇDUMMY_PASS¤¬ÆþÎϤµ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ï¡¢¥¹¥ë¡¼¤¹¤ë)144 $objErr->arrErr['login_id'] = "既に登録されているIDなので利用できません。<br>"; 145 } 146 } 147 148 // パスワードチェック(編集モードでDUMMY_PASSが入力されている場合は、スルーする) 149 149 if(!($_POST['mode'] == 'edit' && $_POST['password'] == DUMMY_PASS)) { 150 $objErr->doFunc(array(" ¥Ñ¥¹¥ï¡¼¥É",'password'), array("EXIST_CHECK", "ALNUM_CHECK"));150 $objErr->doFunc(array("パスワード",'password'), array("EXIST_CHECK", "ALNUM_CHECK")); 151 151 if (!$arrErr['password']) { 152 // ¥Ñ¥¹¥ï¡¼¥É¤Î¥Á¥§¥Ã¥¯153 $objErr->doFunc( array(" ¥Ñ¥¹¥ï¡¼¥É",'password',4 ,15 ) ,array( "NUM_RANGE_CHECK" ) );154 } 155 } 156 157 // ¸¢¸Â¥Á¥§¥Ã¥¯158 $objErr->doFunc(array(" ¸¢¸Â",'authority'),array("EXIST_CHECK"));152 // パスワードのチェック 153 $objErr->doFunc( array("パスワード",'password',4 ,15 ) ,array( "NUM_RANGE_CHECK" ) ); 154 } 155 } 156 157 // 権限チェック 158 $objErr->doFunc(array("権限",'authority'),array("EXIST_CHECK")); 159 159 return $objErr->arrErr; 160 160 } 161 161 162 /* DB ¤Ø¤Î¥Ç¡¼¥¿ÁÞÆþ*/162 /* DBへのデータ挿入 */ 163 163 function fnInsertMember() { 164 // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À164 // クエリークラスの宣言 165 165 $oquery = new SC_Query(); 166 // INSERT ¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£166 // INSERTする値を作成する。 167 167 $sqlval['name'] = $_POST['name']; 168 168 $sqlval['department'] = $_POST['department']; … … 171 171 $sqlval['authority'] = $_POST['authority']; 172 172 $sqlval['rank']= $oquery->max("dtb_member", "rank") + 1; 173 $sqlval['work'] = "1"; // ²ÔƯ¤ËÀßÄê174 $sqlval['del_flg'] = "0"; // ºï½ü¥Õ¥é¥°¤òOFF¤ËÀßÄê173 $sqlval['work'] = "1"; // 稼働に設定 174 $sqlval['del_flg'] = "0"; // 削除フラグをOFFに設定 175 175 $sqlval['creator_id'] = $_SESSION['member_id']; 176 176 $sqlval['create_date'] = "now()"; 177 177 $sqlval['update_date'] = "now()"; 178 // INSERT ¤Î¼Â¹Ô178 // INSERTの実行 179 179 $ret = $oquery->insert("dtb_member", $sqlval); 180 180 return $ret; 181 181 } 182 182 183 /* DB ¤Ø¤Î¥Ç¡¼¥¿¹¹¿·*/183 /* DBへのデータ更新 */ 184 184 function fnUpdateMember($id) { 185 // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À185 // クエリークラスの宣言 186 186 $oquery = new SC_Query(); 187 // INSERT ¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£187 // INSERTする値を作成する。 188 188 $sqlval['name'] = $_POST['name']; 189 189 $sqlval['department'] = $_POST['department']; … … 194 194 $sqlval['authority'] = $_POST['authority']; 195 195 $sqlval['update_date'] = "now()"; 196 // UPDATE ¤Î¼Â¹Ô196 // UPDATEの実行 197 197 $where = "member_id = " . $id; 198 198 $ret = $oquery->update("dtb_member", $sqlval, $where); … … 200 200 } 201 201 202 /* DB ¤«¤é¥Ç¡¼¥¿¤ÎÆɤ߹þ¤ß*/202 /* DBからデータの読み込み */ 203 203 function fnGetMember($conn, $id) { 204 204 $sqlse = "SELECT name,department,login_id,authority FROM dtb_member WHERE member_id = ?";
Note: See TracChangeset
for help on using the changeset viewer.