작성일 댓글 남기기

[phpschool펌] editplus PHP manual 연결



















navyism 날 짜 09-04-08 14:30 조 회 100
Link1   http://navyism.com (16)






예전에 그걸 만들었는데…
어느날 잘 안되고… 이런저런 부족한 면도 있고 하여…
요즘에는 이렇게 쓰고 있네요 ;;

editplus 사용자 도구에서

명령 : C:\Users\navyism\AppData\Local\Google\Chrome\Application\chrome.exe
인수 : -u “http://kr2.php.net/manual-lookup.php?pattern=$(CurSel)”
하단 체크 모두 해제, 콤보에서 바꾸기 선택

이렇게 등록하고…
단축기 F4정도 준 다음에…

찾아볼 단어 셀렉트해서 F4눌러주면…
0.1초만에 크롬으로 깔끔하게 매뉴얼 뜹니다 ^^;;

그전까지는 chm 연결해서 ctrl+1 로 사용했는데 윗분이 하신 대로 했더니 더 좋네요. ^^

작성일 댓글 남기기

controller를 model안에서 사용하기(혹은 불러오기?)

제목 붙이기가 좀 어렵네요
CI로 CMS를 개발하다보니 CI코어와 플러그인, 위젯, 레이아웃 등을 분리해야할 필요성이 생겼습니다.
그리고 플러그인의 특성상 자기 자신만으로도 웹에서 보일 수 있어야 해서 주소체계를 CI의 주소체계로 동일하게 사용해야 했습니다.(변수 전달도 포함)


application/
plugins/
widgets/
layouts/
system/

http://localhost/plugins/control/board/main    <- 이렇게 주소를 쓰는데 플러그인중 게시판(board)의 main.tpl.php(템플릿) 파일을 불러옵니다.
위 주소는 application/controllers/plugins.php 에 연결되어있고 그 내용은 다음과 같습니다.


function control (){
$this->load->model(PLUGPATH.’/’.$this->uri->segment(3).’/Functions’);
// $this->uri->segment(3)=> board 플러그인의 Functions.php 모델을 불러옵니다.
// 플러그인 규칙으로 모델은 Functions.php로 정합니다.
$data=$this->Functions->default_control(); // Functions 모델의 default_control 함수를 호출하는데 그 안에 컨트롤 파일이 들어있습니다.
$this->load->parser(PLUGPATH.’/’.$this->uri->segment(3).’/default/’.$this->uri->segment(4).’tpl.php’, $data);
}

plugins/board/Functions.php

function blist (){
  게시판 리스트 가져오는 함수
  return $query->result_array(); // result_array()-> CI의 DB함수
}
function default_control (){   
  $ll = $this->blist(‘test’); //게시판 리스트를 배열로 가져옵니다.
  return $ll;
}

└– default_control 부분이 핵심입니다. 컨트롤러에 있어야할 내용이 모델안에 함수로 정의되어 있습니다.
그리고 plusins라는 컨트롤에서 default_control 함수가 처리한 내용을 받아서
CI 템플릿 형태의 파일인 main.tpl.php로 보내줍니다.

위와 같은 작업을 함으로써 application 디렉토리 이외의 외부 디렉토리에서도 MVC 패턴(엄밀히 말하면 아니지만, 모델안에 컨트롤러가 구현되어 있으므로)을
그대로 구현할 수 있습니다. 특히나 다른 개발자가 만든 플러그인 같은 경우 정해진 규약대로만 만들면(Functions.php main.tpl.php 등)
CI의 주소체계를 이용하고 CI 내장함수도 그대로 이용을 할 수가 있습니다.

평상시 개발에서는 구현할 필요가 없지만 외부 개발자들이 만든 플러그인을 사용하는 구조라면 필요합니다.

이 내용을 올리는 가장 큰 목적은 CI의 유연성을 말하고 싶어서 입니다.
이번에 CI로 CMS 작업을 하면서 느낀 것은 CI의 확장성, 유연성입니다. 어느 정도 프레임워크로서의 틀을 가지고 있지만 그 틀을 넘나들 수 있는 유연성을 가지고 있다는 것.
다시 말해 개발자들이 어떻게 구현하느냐에 따라 정말 어떤 구조던지 가능하다는 것입니다.
프레임워크의 편리함(내장함수들의 편리함, 구조화, mvc패턴 등등)을 사용하면서 동시에 개발자의 재량에 따라 얼마든지 기존 구조이외에 것을 이용할 수 있다는 점이 큰 장점이라고 할 수 있겠습니다.

작성일 댓글 남기기

[펌] editplus로 svn commit, update 하기








 


 
commit

TortoiseProc.exe /command:commit /path:”c:\svn_wc\file1.txt*c:\svn_wc\file2.txt”/notempfile /closeonend
update

TortoiseProc.exe /command:update /path:”c:\svn_wc\” /notempfile /closeonend


  • /closeonend:0 don’t close the dialog automatically


  • /closeonend:1 auto close if no errors

     

    에디트 플러스의 도구 -> 사용자도구구성 메뉴이용.

    1. 도구 항목을 하나 추가 한다.

    2. 메뉴제목에 svn commit 를 입력 한다.

    3. 명령에 svn 이 설치된 ‘C:\Program Files\TortoiseSVN\bin\TortoiseProc.exe’ 선택한다.

    4. 인수 부분에 위의 commit 에 해당 되는 내용을 넣는다.

       예) /command:commit /path:”$(FilePath)”/logmsg:”test log message” /notempfile /closeonend:1

           인수 옆의 버튼을 클릭 하면 파일 이름을 선택 할수 있다.

    5. update 두 마찬가지로 명령과 인수를 위와 같이 입력 하시면 됩니다.

     

    에디트 플러스에서 ctrl+1, ctrl+2 키를 누르면 commit, update 가 됩니다.
  • 작성일 댓글 남기기

    [PHPSCHOOL 펌] 자동로그아웃 관련 사전 경고 보여주며 로그아웃 처리하기





    [스크립트] 자동로그아웃 관련 사전 경고 보여주며 로그아웃 처리하기















    글쓴이   LinuxZZang 날 짜 09-03-19 13:48 조 회 115






    안녕하세요.

    대부분의 웹사이트 로그인 인증은 세션이나 쿠키를 사용하고 있습니다만..
    특별하게 설정하지 않는 한 30분~120분 사이에 세션이나 쿠키가 소멸 됩니다.

    하지만 클라이언트가 특정 입력창을 띄워놓고 장시간 자리를 비우거나
    비활성화 시켰을 경우에는 세션이나 쿠키가 삭제되어도
    http프로토콜 속성상 재연결을 하기 전에는
    로그아웃 여부를 알기가 어렵습니다.
     
    저 역시 예전에 인터넷통신교육을 받을때
    4시간 동안 교육레포트를 작성하여 입력하고 “저장”을 누르는 순간에
    로그아웃 처리가 되어 교육레포트를 모두 날린적이 있습니다.

    그래서 업체에 강하게 항의했더니 세션유지시간은 24시간으로 만들어 주던데..
    이건 정답은 아닌거 같습니다.

    그래서 아래의 소스처럼 사용자가 해당 페이지에서
    아무런 작업(마우스, 키보드이벤트)도 하지 않을경우
    사전경고창을 보여준후 대기시간이 지나면 자동으로 로그아웃 시키도록 만들었습니다.

    물론 그 안에 어떠한 이벤트라도 발생시키면 대기시간을 다시 초기화 시키도록 하였으며,
    비활성화시켰을 때도 작동이 가능하며 익스 7 에서만 테스트 했습니다.

    그리고 여기 저기서 소스를 가져다 조합한거니 필요하신분은
    부담없이 사용바랍니다.

    감사합니다. 꾸벅.

     ——————————————————————————————-
     <html> <head>
    <script>
    Lpad=function(str, len)
     {
        str = str + “”;
          while(str.length < len)
        {
          str = “0”+str;
        }
         return str;
     }

    /// 사용자로부터 마우스 또는 키보드 이벤트가 없을경우의
        자동로그아웃까지의 대기시간, 분단위
     var iMinute = 1;
     
     //자동로그아웃 처리 몇초전에 경고를 보여줄지 설정하는 부분, 초단위
     var noticeSecond = 55;

     var iSecond = iMinute * 60 ;
     var timerchecker = null;
     
     initTimer=function()
     {
        /// //사용자부터 마우스 또는 키보드 이벤트가 발생했을경우
              자동로그아웃까지의 대기시간을 다시 초기화
        if(window.event)
        {
        iSecond = iMinute * 60 ;;
         clearTimeout(timerchecker);
          coverFilmMain.style.visibility=’hidden’; //// 입력방지 레이어 해제
        timer.style.visibility=’hidden’;  /// 자동로그아웃 경고레이어 해제
        }
        rMinute = parseInt(iSecond / 60);
        rSecond = iSecond % 60;
        if(iSecond > 0)
        {
        /////지정한 시간동안 마우스, 키보드 이벤트가 발생되지 않았을 경우
            if(iSecond < noticeSecond)
              {
                coverFilmMain.style.visibility=’visible’; /// 입력방지 레이어 활성
                timer.style.visibility=’visible’;  /// 자동로그아웃 경고레이어 활성
                            }
                ///자동로그아웃 경고레이어에 경고문+남은 시간 보여주는 부분
          timer.innerHTML = 
                        “<font family=tahoma style=’font-size:70;’>AUTO LOG OUT</font>
                        </h1> <font color=red>” + Lpad(rMinute, 2)+”:”+Lpad(rSecond, 2) ;
            iSecond–;
          timerchecker = setTimeout(“initTimer()”, 1000); // 1초 간격으로 체크
        }
        else
        {
              clearTimeout(timerchecker);
            alert(“장시간 미사용으로 자동 로그아웃 처리되었습니다.”);
            ////location.href = “./logOut.php”; // 로그아웃 처리 페이지
        }
     }
     onload = initTimer;///현재 페이지 대기시간
     document.onclick = initTimer; /// 현재 페이지의 사용자 마우스 클릭이벤트 캡춰
    document.onkeypress = initTimer;/// 현재 페이지의 키보트 입력이벤트 캡춰
    </script>
     </head>
     <body topmargin=0 leftmargin=0>
     <!– 비활성화 시키는 레이어–>
     <div id=’coverFilmMain’ style=’z-index: 99997; position:absolute; visibility:hidden; width:100%; height:100%; background-color:#000000; filter:Alpha(opacity=20); opacity:0.6; -moz-opacity:0.6; text-align:center; font-size:12pt;color:black;’></div>
      <!– 자동로그아웃시까지 남은 시간을 보여주는 레이어–>
      <div id=”timer” style=”position:absolute; width:100%; height:40%;margin-top:20%; visibility:hidden; border:0;  color:black; font-family:tahoma; font-size:150;font-weight:bold;text-align:center”></div>

    입력 <input type = text size=10><br>
    입력 <input type = radio checked><input type = radio><br>
    입력 <input type = checkbox>
    입력 <select><option>123</option><option>1234</option></select>
    입력 <textarea></textarea>
    <pre>
    사용자로부터 지정한 대기시간동안 아무런 마우스, 키보드 이벤트가 발생하지 않을 경우

    지정한 시간부터 자동로그 아웃 경고를 보여주며,

    대기시간이 지나면 자동으로 로그아웃 처리합니다.

    하지만 사용자로부터 마우스, 키보드 이벤트가 발생할 경우 대기시간을 다시 초기화 시킵니다.

    * 익스7 기준으로 테스트 되었습니다.
    * 비활성화시켜도 작동됩니다.

    감사합니다. 꾸벅
    </body></html>

    작성일 댓글 남기기

    PHP Framework CODEIGNITER의 장점과 사용하면서 불편했던 점

    먼저 좋은 점은 가볍다 입니다. 확장도 용이하구요.
    사용자들이 올려놓은 wiki의 파일이나 플러그인이 이용할만한게 많습니다.
    다른 프레임워크도 그렇지만 지원되는 함수(유저가이드 참고)가 정말 필요한 것들을 집약해놓았습니다.
    jquery를 이그나이터의 함수처럼 사용하는 부분도 있고.
    폼체크, 페이징, 트랙백, xml, 세션 암호화 등등.. 유저 가이드 대로만 하면 금방 구현. ^^
    helper도 마찬가지구요.
    모델의 경우 다른 컨트롤을 위해 만든 모델도 로딩시켜서 그냥 쓸 수 있다는거..
    common 모델을 만들고 기능별로 따로 만들어서 불러서 쓰는 것이 좋겠죠.
    모델에서 데이터 처리후 배열로 뷰파일에 전달, foreach(){ .. }로 처리하기만 하면 되는 뷰.
    MVC패턴의 장점이야 두말할 나위가 없구요.

    단점으로는 모든 프레임워크가 그렇듯 사용법을 따로 배워야 하죠.
    $_POST[‘var’] 로 처리하던 것만 하더라도 $this->input->post(‘var’)로 바꿔서 사용해야 합니다.
    $_SERVER 도 마찬가지..

    http://www.h.com/index.php/together/mview/index/ 의 주소체계를 사용하다보면 검색후 2페이지로 이동할때 검색어를
    http://www.h.com/index.php/together/mview/index/10/검색어 (검색어 부분은 실제로는 urlencode해서 넘깁니다.)의 형태로 넘기게 되는데
    간혹 중간에 프로그램 수정에 의해 인자가 추가되는 경우가 있으면 좀 난감해집니다.
    그래서 코드이그나이터 포럼에 검색을 해보니 쿠키로 처리하는 경우도 있었고 config.php 파일에서 $config[‘enable_query_strings’] 를 TRUE로 셋팅하여
    주소체계를 혼용하여 사용하면 해결이 가능하긴 하지만 그렇게 되면 또 한가지 문제가 생깁니다.
    $config[‘enable_query_strings’] = TRUE; –> http://www.h.com/index.php?d=together&c=mview&m=index&page=10&q=검색어 형태의 주소로 사용할 수 있습니다.
    이렇게 되면 해결이 되는데 문제는 코드이그나이터의 pagenation 라이브러리 사용에서 문제가 생깁니다.
    기존형식으로 사용할때는 잘 작동하던 페이징이 $config[‘enable_query_strings’] = TRUE 가 되면 페이징의 주소가 기존과 다른 형태로 바뀌면서 오작동을 합니다.
    그래서 pagenation config 선언할때 한줄을 더 추가해줘야 합니다.
    $config[‘page_query_string’] = FALSE; 이 라인이 추가 되어야 문제없이 사용이 됩니다.
    설명이 좀 어려운데 실제로 코딩해보시면 이해가 금방 됩니다. ^^;
    전 두가지 방법을 다 적용했습니다. 쿠키로 구워서 체크후 일정시간후 날리는 방법과 주소형태를 바꾸는 방법.

    그리고 1.7.1 버전에서는 고쳐졌는지 확인을 안해봤는데 제가 사용했던 1.6.3 버전에서는 로그인후 창을 닫으면 세션이 그대로 살아있습니다. 수정하려면 아래 부분 패치

    config.php 파일의 $config[‘sess_expiration’] = -1 로 수정후

    libraries 디렉토리의 Session.php 89 라인
    if ($this->sess_expiration == 0)
    {
    $this->sess_expiration = (60*60*24*365*2);
    }

    if ($this->sess_expiration == 0)
    {
                    $this->sess_expiration = (60*60*24*365*2);
    }
    else
    {
    $this->sess_expiration = (60*60*24);
    }
    로 수정

    659라인
    setcookie(
    $this->sess_cookie_name,
    $cookie_data,
    – //$this->sess_expiration + time(),
    + ($this->CI->config->item(‘sess_expiration’) == -1) ? 0 : ($this->sess_expiration + time()),
    $this->cookie_path,
    $this->cookie_domain,
    0
    );


    config.php 파일의 $config[‘permitted_uri_chars’] = ‘a-z 0-9~%.:_=\-‘; 부분도 문제가 됩니다.
    주소로 사용할 수 있는 문자를 정규표현식으로 표현한 것이데 간혹 한글을 주소에 사용하기위해 urlencode 했을때 충돌이 납니다.
    경우의 수를 다 찾아서 넣어주면 좋겠지만 전 현재 $config[‘permitted_uri_chars’] = ”; 이렇게 사용중입니다.

    일단 생각 나는 부분은 여기까지인데 추후에 더 보강하겠습니다. ^^