Changeset 11730 for branches/comu/html/admin/system/input.php
- Timestamp:
- 2007/03/11 06:27:25 (19 years ago)
- File:
-
- 1 edited
-
branches/comu/html/admin/system/input.php (modified) (7 diffs)
Legend:
- Unmodified
- Added
- Removed
-
branches/comu/html/admin/system/input.php
r11729 r11730 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 } else { 52 // 新規作成モード52 // ¿·µ¬ºîÀ®¥â¡¼¥É 53 53 $objPage->tpl_mode = "new"; 54 54 $objPage->arrForm['authority'] = -1; 55 55 } 56 56 57 // 新規作成モード or 編集モード57 // ¿·µ¬ºîÀ®¥â¡¼¥É or ÊÔ½¸¥â¡¼¥É 58 58 if( $_POST['mode'] == 'new' || $_POST['mode'] == 'edit') { 59 // 入力エラーチェック59 // ÆþÎÏ¥¨¥é¡¼¥Á¥§¥Ã¥¯ 60 60 $objPage->arrErr = fnErrorCheck($conn); 61 61 62 // 入力が正常であった場合は、DBに書き込む62 // ÆþÎϤ¬Àµ¾ï¤Ç¤¢¤Ã¤¿¾ì¹ç¤Ï¡¢DB¤Ë½ñ¤¹þ¤à 63 63 if(count($objPage->arrErr) == 0) { 64 64 if($_POST['mode'] == 'new') { 65 // メンバーの追加65 // ¥á¥ó¥Ð¡¼¤ÎÄɲà 66 66 fnInsertMember(); 67 // リロードによる二重登録対策のため、同じページに飛ばす。67 // ¥ê¥í¡¼¥É¤Ë¤è¤ëÆó½ÅÅÐÏ¿Âкö¤Î¤¿¤á¡¢Æ±¤¸¥Ú¡¼¥¸¤ËÈô¤Ð¤¹¡£ 68 68 header("Location: ". $_SERVER['PHP_SELF'] . "?mode=reload"); 69 69 exit; 70 70 } 71 71 if($_POST['mode'] == 'edit') { 72 // メンバーの追加72 // ¥á¥ó¥Ð¡¼¤ÎÄɲà 73 73 if(fnUpdateMember($_POST['member_id'])) { 74 // 親ウィンドウを更新後、自ウィンドウを閉じる。74 // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¸å¡¢¼«¥¦¥£¥ó¥É¥¦¤òÊĤ¸¤ë¡£ 75 75 $url = URL_SYSTEM_TOP . "?pageno=".$_POST['pageno']; 76 76 $objPage->tpl_onload="fnUpdateParent('".$url."'); window.close();"; 77 77 } 78 78 } 79 // 入力エラーが発生した場合79 // ÆþÎÏ¥¨¥é¡¼¤¬È¯À¸¤·¤¿¾ì¹ç 80 80 } else { 81 // モードの設定81 // ¥â¡¼¥É¤ÎÀßÄê 82 82 $objPage->tpl_mode = $_POST['mode']; 83 83 $objPage->tpl_member_id = $_POST['member_id']; 84 84 $objPage->tpl_old_login_id = $_POST['old_login_id']; 85 // すでに入力した値を表示する。85 // ¤¹¤Ç¤ËÆþÎϤ·¤¿Ãͤòɽ¼¨¤¹¤ë¡£ 86 86 $objPage->arrForm = $_POST; 87 // 通常入力のパスワードは引き継がない。87 // Ä̾ïÆþÎϤΥѥ¹¥ï¡¼¥É¤Ï°ú¤·Ñ¤¬¤Ê¤¤¡£ 88 88 if($objPage->arrForm['password'] != DUMMY_PASS) { 89 89 $objPage->arrForm['password'] = ''; … … 92 92 } 93 93 94 // リロードの指定があった場合94 // ¥ê¥í¡¼¥É¤Î»ØÄ꤬¤¢¤Ã¤¿¾ì¹ç 95 95 if( $_GET['mode'] == 'reload') { 96 // 親ウィンドウを更新するようにセットする。96 // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¤¹¤ë¤è¤¦¤Ë¥»¥Ã¥È¤¹¤ë¡£ 97 97 $url = URL_SYSTEM_TOP; 98 98 $objPage->tpl_onload="fnUpdateParent('".$url."')"; 99 99 } 100 100 101 // テンプレート用変数の割り当て101 // ¥Æ¥ó¥×¥ì¡¼¥ÈÍÑÊÑ¿ô¤Î³ä¤êÅö¤Æ 102 102 $objView->assignobj($objPage); 103 103 $objView->display('system/input.tpl'); 104 104 105 /* 入力エラーのチェック*/105 /* ÆþÎÏ¥¨¥é¡¼¤Î¥Á¥§¥Ã¥¯ */ 106 106 function fnErrorCheck($conn) { 107 107 … … 111 111 $_POST["department"] = mb_convert_kana($_POST["department"] ,"KV"); 112 112 113 // 名前チェック114 $objErr->doFunc(array(" 名前",'name'), array("EXIST_CHECK"));115 $objErr->doFunc(array(" 名前",'name',STEXT_LEN,"BIG"), array("MAX_LENGTH_CHECK"));113 // ̾Á°¥Á¥§¥Ã¥¯ 114 $objErr->doFunc(array("̾Á°",'name'), array("EXIST_CHECK")); 115 $objErr->doFunc(array("̾Á°",'name',STEXT_LEN,"BIG"), array("MAX_LENGTH_CHECK")); 116 116 117 // 編集モードでない場合は、重複チェック117 // ÊÔ½¸¥â¡¼¥É¤Ç¤Ê¤¤¾ì¹ç¤Ï¡¢½ÅÊ£¥Á¥§¥Ã¥¯ 118 118 if (!isset($objErr->arrErr['name']) && $_POST['mode'] != 'edit') { 119 119 $sql = "SELECT name FROM dtb_member WHERE del_flg <> 1 AND name = ?"; 120 120 $result = $conn->getOne($sql, array($_POST['name'])); 121 121 if ( $result ) { 122 $objErr->arrErr['name'] = " 既に登録されている名前なので利用できません。<br>";122 $objErr->arrErr['name'] = "´û¤ËÅÐÏ¿¤µ¤ì¤Æ¤¤¤ë̾Á°¤Ê¤Î¤ÇÍøÍѤǤ¤Þ¤»¤ó¡£<br>"; 123 123 } 124 124 } 125 125 126 // ログインIDチェック127 $objErr->doFunc(array(" ログインID",'login_id'), array("EXIST_CHECK", "ALNUM_CHECK"));128 $objErr->doFunc(array(" ログインID",'login_id',ID_MIN_LEN , ID_MAX_LEN) ,array("NUM_RANGE_CHECK"));126 // ¥í¥°¥¤¥óID¥Á¥§¥Ã¥¯ 127 $objErr->doFunc(array("¥í¥°¥¤¥óID",'login_id'), array("EXIST_CHECK", "ALNUM_CHECK")); 128 $objErr->doFunc(array("¥í¥°¥¤¥óID",'login_id',ID_MIN_LEN , ID_MAX_LEN) ,array("NUM_RANGE_CHECK")); 129 129 130 // 新規モードもしくは、編集モードでログインIDが変更されている場合はチェックする。130 // ¿·µ¬¥â¡¼¥É¤â¤·¤¯¤Ï¡¢ÊÔ½¸¥â¡¼¥É¤Ç¥í¥°¥¤¥óID¤¬Êѹ¹¤µ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ï¥Á¥§¥Ã¥¯¤¹¤ë¡£ 131 131 if (!isset($objErr->arrErr['login_id']) && $_POST['mode'] != 'edit' || ($_POST['mode'] == 'edit' && $_POST['login_id'] != $_POST['old_login_id'])) { 132 132 $sql = "SELECT login_id FROM dtb_member WHERE del_flg <> 1 AND login_id = ?"; 133 133 $result = $conn->getOne($sql, array($_POST['login_id'])); 134 134 if ( $result != "" ) { 135 $objErr->arrErr['login_id'] = " 既に登録されているIDなので利用できません。<br>";135 $objErr->arrErr['login_id'] = "´û¤ËÅÐÏ¿¤µ¤ì¤Æ¤¤¤ëID¤Ê¤Î¤ÇÍøÍѤǤ¤Þ¤»¤ó¡£<br>"; 136 136 } 137 137 } 138 138 139 // パスワードチェック(編集モードでDUMMY_PASSが入力されている場合は、スルーする)139 // ¥Ñ¥¹¥ï¡¼¥É¥Á¥§¥Ã¥¯(ÊÔ½¸¥â¡¼¥É¤ÇDUMMY_PASS¤¬ÆþÎϤµ¤ì¤Æ¤¤¤ë¾ì¹ç¤Ï¡¢¥¹¥ë¡¼¤¹¤ë) 140 140 if(!($_POST['mode'] == 'edit' && $_POST['password'] == DUMMY_PASS)) { 141 $objErr->doFunc(array(" パスワード",'password'), array("EXIST_CHECK", "ALNUM_CHECK"));141 $objErr->doFunc(array("¥Ñ¥¹¥ï¡¼¥É",'password'), array("EXIST_CHECK", "ALNUM_CHECK")); 142 142 if (!$arrErr['password']) { 143 // パスワードのチェック144 $objErr->doFunc( array(" パスワード",'password',4 ,15 ) ,array( "NUM_RANGE_CHECK" ) );143 // ¥Ñ¥¹¥ï¡¼¥É¤Î¥Á¥§¥Ã¥¯ 144 $objErr->doFunc( array("¥Ñ¥¹¥ï¡¼¥É",'password',4 ,15 ) ,array( "NUM_RANGE_CHECK" ) ); 145 145 } 146 146 } 147 147 148 // 権限チェック149 $objErr->doFunc(array(" 権限",'authority'),array("EXIST_CHECK"));148 // ¸¢¸Â¥Á¥§¥Ã¥¯ 149 $objErr->doFunc(array("¸¢¸Â",'authority'),array("EXIST_CHECK")); 150 150 return $objErr->arrErr; 151 151 } 152 152 153 /* DB へのデータ挿入*/153 /* DB¤Ø¤Î¥Ç¡¼¥¿ÁÞÆþ */ 154 154 function fnInsertMember() { 155 // クエリークラスの宣言155 // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À 156 156 $oquery = new SC_Query(); 157 // INSERT する値を作成する。157 // INSERT¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£ 158 158 $sqlval['name'] = $_POST['name']; 159 159 $sqlval['department'] = $_POST['department']; … … 162 162 $sqlval['authority'] = $_POST['authority']; 163 163 $sqlval['rank']= $oquery->max("dtb_member", "rank") + 1; 164 $sqlval['work'] = "1"; // 稼働に設定165 $sqlval['del_flg'] = "0"; // 削除フラグをOFFに設定164 $sqlval['work'] = "1"; // ²ÔƯ¤ËÀßÄê 165 $sqlval['del_flg'] = "0"; // ºï½ü¥Õ¥é¥°¤òOFF¤ËÀßÄê 166 166 $sqlval['creator_id'] = $_SESSION['member_id']; 167 167 $sqlval['create_date'] = "now()"; 168 168 $sqlval['update_date'] = "now()"; 169 // INSERT の実行169 // INSERT¤Î¼Â¹Ô 170 170 $ret = $oquery->insert("dtb_member", $sqlval); 171 171 return $ret; 172 172 } 173 173 174 /* DB へのデータ更新*/174 /* DB¤Ø¤Î¥Ç¡¼¥¿¹¹¿· */ 175 175 function fnUpdateMember($id) { 176 // クエリークラスの宣言176 // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À 177 177 $oquery = new SC_Query(); 178 // INSERT する値を作成する。178 // INSERT¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£ 179 179 $sqlval['name'] = $_POST['name']; 180 180 $sqlval['department'] = $_POST['department']; … … 185 185 $sqlval['authority'] = $_POST['authority']; 186 186 $sqlval['update_date'] = "now()"; 187 // UPDATE の実行187 // UPDATE¤Î¼Â¹Ô 188 188 $where = "member_id = " . $id; 189 189 $ret = $oquery->update("dtb_member", $sqlval, $where); … … 191 191 } 192 192 193 /* DB からデータの読み込み*/193 /* DB¤«¤é¥Ç¡¼¥¿¤ÎÆÉ¤ß¹þ¤ß */ 194 194 function fnGetMember($conn, $id) { 195 195 $sqlse = "SELECT name,department,login_id,authority FROM dtb_member WHERE member_id = ?";
Note: See TracChangeset
for help on using the changeset viewer.
