Ignore:
Timestamp:
2007/07/20 15:58:59 (17 years ago)
Author:
nanasess
Message:

r15064 から svn cp
とりあえず暫定コミット.

  • UTF-8 に変更
  • slib.php, glib.php のクラス化
  • LC_Page の抽象化(一部)
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
  • branches/feature-module-update/html/admin/system/input.php

    r14993 r15078  
    88 
    99class LC_Page { 
    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; // ÊÔ½¸»þ¤Ë»ÈÍѤ¹¤ë¡£ 
     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; // 編集時に使用する。 
    1616    var $tpl_pageno; 
    17     var $tpl_onfocus;   // ¥Ñ¥¹¥ï¡¼¥É¹àÌÜÁªÂò»þ¤Î¥¤¥Ù¥ó¥ÈÍÑ 
     17    var $tpl_onfocus;   // パスワード項目選択時のイベント用 
    1818    var $tpl_old_login_id; 
    1919    function LC_Page() { 
     
    3232$objView = new SC_AdminView(); 
    3333 
    34 // ǧ¾Ú²ÄÈݤÎȽÄê 
     34// 認証可否の判定 
    3535$objSess = new SC_Session(); 
    3636sfIsSuccess($objSess); 
    3737 
    38 // member_id¤¬»ØÄꤵ¤ì¤Æ¤¤¤¿¾ì¹ç¡¢ÊÔ½¸¥â¡¼¥É¤È¤¹¤ë¡£ 
     38// member_idが指定されていた場合、編集モードとする。 
    3939if(sfIsInt($_GET['id'])) { 
    4040    $objPage->tpl_mode = 'edit'; 
    4141    $objPage->tpl_member_id = $_GET['id']; 
    4242    $objPage->tpl_onfocus = "fnClearText(this.name);"; 
    43     // DB¤Î¥á¥ó¥Ð¡¼¾ðÊó¤òÆɤ߽Ф¹ 
     43    // DBのメンバー情報を読み出す 
    4444    $data_list = fnGetMember($conn, $_GET['id']); 
    45     // ³ºÅö¥æ¡¼¥¶¤òɽ¼¨¤µ¤»¤ë 
     45    // 該当ユーザを表示させる 
    4646    $objPage->arrForm = $data_list[0]; 
    47     // ¥À¥ß¡¼¤Î¥Ñ¥¹¥ï¡¼¥É¤ò¥»¥Ã¥È¤·¤Æ¤ª¤¯¡£ 
     47    // ダミーのパスワードをセットしておく。 
    4848    $objPage->arrForm['password'] = DUMMY_PASS; 
    49     // ¥í¥°¥¤¥óID¤òÊݴɤ·¤Æ¤ª¤¯¡£ 
     49    // ログインIDを保管しておく。 
    5050    $objPage->tpl_old_login_id = $data_list[0]['login_id']; 
    5151     
    5252    $objPage->tpl_uniqid = $objSess->getUniqId(); 
    5353} else { 
    54     // ¿·µ¬ºîÀ®¥â¡¼¥É 
     54    // 新規作成モード 
    5555    $objPage->tpl_mode = "new"; 
    5656    $objPage->arrForm['authority'] = -1; 
    5757} 
    5858 
    59 // ¿·µ¬ºîÀ®¥â¡¼¥É or ÊÔ½¸¥â¡¼¥É 
     59// 新規作成モード or 編集モード 
    6060if( $_POST['mode'] == 'new' || $_POST['mode'] == 'edit') { 
    61     // ²èÌÌÁ«°Ü¤ÎÀµÅöÀ­¥Á¥§¥Ã¥¯ 
     61    // 画面遷移の正当性チェック 
    6262    if (sfIsValidTransition($objSess) == false) { 
    6363        sfDispError(INVALID_MOVE_ERRORR); 
    6464    } 
    65     // ÆþÎÏ¥¨¥é¡¼¥Á¥§¥Ã¥¯ 
     65    // 入力エラーチェック 
    6666    $objPage->arrErr = fnErrorCheck($conn); 
    6767     
    68     // ÆþÎϤ¬Àµ¾ï¤Ç¤¢¤Ã¤¿¾ì¹ç¤Ï¡¢DB¤Ë½ñ¤­¹þ¤à 
     68    // 入力が正常であった場合は、DBに書き込む 
    6969    if(count($objPage->arrErr) == 0) { 
    7070        if($_POST['mode'] == 'new') { 
    71             // ¥á¥ó¥Ð¡¼¤ÎÄɲà
     71            // メンバーの追加 
    7272            fnInsertMember(); 
    73             // ¥ê¥í¡¼¥É¤Ë¤è¤ëÆó½ÅÅÐÏ¿Âкö¤Î¤¿¤á¡¢Æ±¤¸¥Ú¡¼¥¸¤ËÈô¤Ð¤¹¡£ 
     73            // リロードによる二重登録対策のため、同じページに飛ばす。 
    7474            header("Location: ". $_SERVER['PHP_SELF'] . "?mode=reload");     
    7575            exit; 
    7676        } 
    7777        if($_POST['mode'] == 'edit') { 
    78             // ¥á¥ó¥Ð¡¼¤ÎÄɲà
     78            // メンバーの追加 
    7979            if(fnUpdateMember($_POST['member_id'])) { 
    80                 // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¸å¡¢¼«¥¦¥£¥ó¥É¥¦¤òÊĤ¸¤ë¡£ 
     80                // 親ウィンドウを更新後、自ウィンドウを閉じる。 
    8181                $url = URL_SYSTEM_TOP . "?pageno=".$_POST['pageno']; 
    8282                $objPage->tpl_onload="fnUpdateParent('".$url."'); window.close();"; 
    8383            } 
    8484        } 
    85     // ÆþÎÏ¥¨¥é¡¼¤¬È¯À¸¤·¤¿¾ì¹ç 
     85    // 入力エラーが発生した場合 
    8686    } else { 
    87         // ¥â¡¼¥É¤ÎÀßÄê 
     87        // モードの設定 
    8888        $objPage->tpl_mode = $_POST['mode']; 
    8989        $objPage->tpl_member_id = $_POST['member_id']; 
    9090        $objPage->tpl_old_login_id = $_POST['old_login_id']; 
    91         // ¤¹¤Ç¤ËÆþÎϤ·¤¿Ãͤòɽ¼¨¤¹¤ë¡£ 
     91        // すでに入力した値を表示する。 
    9292        $objPage->arrForm = $_POST; 
    93         // Ä̾ïÆþÎϤΥѥ¹¥ï¡¼¥É¤Ï°ú¤­·Ñ¤¬¤Ê¤¤¡£ 
     93        // 通常入力のパスワードは引き継がない。 
    9494        if($objPage->arrForm['password'] != DUMMY_PASS) { 
    9595            $objPage->arrForm['password'] = ''; 
     
    9898} 
    9999 
    100 // ¥ê¥í¡¼¥É¤Î»ØÄ꤬¤¢¤Ã¤¿¾ì¹ç 
     100// リロードの指定があった場合 
    101101if( $_GET['mode'] == 'reload') { 
    102     // ¿Æ¥¦¥£¥ó¥É¥¦¤ò¹¹¿·¤¹¤ë¤è¤¦¤Ë¥»¥Ã¥È¤¹¤ë¡£ 
     102    // 親ウィンドウを更新するようにセットする。 
    103103    $url = URL_SYSTEM_TOP; 
    104104    $objPage->tpl_onload="fnUpdateParent('".$url."')"; 
    105105} 
    106106 
    107 // ²èÌÌÁ«°Ü¤ÎÀµÅöÀ­¥Á¥§¥Ã¥¯ÍѤËuniqid¤òËä¤á¹þ¤à 
     107// 画面遷移の正当性チェック用にuniqidを埋め込む 
    108108$objPage->tpl_uniqid = $objSess->getUniqId(); 
    109109 
    110 // ¥Æ¥ó¥×¥ì¡¼¥ÈÍÑÊÑ¿ô¤Î³ä¤êÅö¤Æ 
     110// テンプレート用変数の割り当て 
    111111$objView->assignobj($objPage); 
    112112$objView->display('system/input.tpl'); 
    113113 
    114 /* ÆþÎÏ¥¨¥é¡¼¤Î¥Á¥§¥Ã¥¯ */ 
     114/* 入力エラーのチェック */ 
    115115function fnErrorCheck($conn) { 
    116116     
     
    120120    $_POST["department"] = mb_convert_kana($_POST["department"] ,"KV"); 
    121121     
    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    // 編集モードでない場合は、重複チェック 
    127127    if (!isset($objErr->arrErr['name']) && $_POST['mode'] != 'edit') { 
    128128        $sql = "SELECT name FROM dtb_member WHERE del_flg <> 1 AND name = ?"; 
    129129        $result = $conn->getOne($sql, array($_POST['name']));  
    130130        if ( $result ) { 
    131             $objErr->arrErr['name'] = "´û¤ËÅÐÏ¿¤µ¤ì¤Æ¤¤¤ë̾Á°¤Ê¤Î¤ÇÍøÍѤǤ­¤Þ¤»¤ó¡£<br>"; 
     131            $objErr->arrErr['name'] = "既に登録されている名前なので利用できません。<br>"; 
    132132        } 
    133133    } 
    134134         
    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が変更されている場合はチェックする。 
    140140    if (!isset($objErr->arrErr['login_id']) && $_POST['mode'] != 'edit' || ($_POST['mode'] == 'edit' && $_POST['login_id'] != $_POST['old_login_id'])) { 
    141141        $sql = "SELECT login_id FROM dtb_member WHERE del_flg <> 1 AND login_id = ?"; 
    142142        $result = $conn->getOne($sql, array($_POST['login_id']));  
    143143        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が入力されている場合は、スルーする) 
    149149    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")); 
    151151        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")); 
    159159    return $objErr->arrErr; 
    160160} 
    161161 
    162 /* DB¤Ø¤Î¥Ç¡¼¥¿ÁÞÆþ */ 
     162/* DBへのデータ挿入 */ 
    163163function fnInsertMember() { 
    164     // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À 
     164    // クエリークラスの宣言 
    165165    $oquery = new SC_Query(); 
    166     // INSERT¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£ 
     166    // INSERTする値を作成する。 
    167167    $sqlval['name'] = $_POST['name']; 
    168168    $sqlval['department'] = $_POST['department']; 
     
    171171    $sqlval['authority'] = $_POST['authority']; 
    172172    $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に設定 
    175175    $sqlval['creator_id'] = $_SESSION['member_id']; 
    176176    $sqlval['create_date'] = "now()"; 
    177177    $sqlval['update_date'] = "now()"; 
    178     // INSERT¤Î¼Â¹Ô 
     178    // INSERTの実行 
    179179    $ret = $oquery->insert("dtb_member", $sqlval); 
    180180    return $ret; 
    181181} 
    182182 
    183 /* DB¤Ø¤Î¥Ç¡¼¥¿¹¹¿· */ 
     183/* DBへのデータ更新 */ 
    184184function fnUpdateMember($id) { 
    185     // ¥¯¥¨¥ê¡¼¥¯¥é¥¹¤ÎÀë¸À 
     185    // クエリークラスの宣言 
    186186    $oquery = new SC_Query(); 
    187     // INSERT¤¹¤ëÃͤòºîÀ®¤¹¤ë¡£ 
     187    // INSERTする値を作成する。 
    188188    $sqlval['name'] = $_POST['name']; 
    189189    $sqlval['department'] = $_POST['department']; 
     
    194194    $sqlval['authority'] = $_POST['authority']; 
    195195    $sqlval['update_date'] = "now()"; 
    196     // UPDATE¤Î¼Â¹Ô 
     196    // UPDATEの実行 
    197197    $where = "member_id = " . $id; 
    198198    $ret = $oquery->update("dtb_member", $sqlval, $where); 
     
    200200} 
    201201 
    202 /* DB¤«¤é¥Ç¡¼¥¿¤ÎÆɤ߹þ¤ß */ 
     202/* DBからデータの読み込み */ 
    203203function fnGetMember($conn, $id) { 
    204204    $sqlse = "SELECT name,department,login_id,authority FROM dtb_member WHERE member_id = ?"; 
Note: See TracChangeset for help on using the changeset viewer.