Android2010. 2. 3. 23:05
Posted by webdata
Spac 에서는 뷰를 이용해 화면을 출력할 때 사용자에게 보여지는 URL링크를 암호화 해서 출력 할 수 있습니다.
이렇게 암호화 된 URL을 통해 접근하면 Spac에서 자동으로 복호화 하여 원주소로 복원하여 접속할 수 있도록 도와줍니다.

예)

"/MyClass/MyMethod/param1/param2" 를 암호화 하여 처리하면
"/dkfhhlSDFsfskfldSDFdjkfasjfdkd" 형태로 만들어 링크를 걸어놓을 수 있습니다.

이후 웹페이지에서 암호화된 "/dkfhhlSDFsfskfldSDFdjkfasjfdkd" 로 접근하면 Spac 프레임웍이 암호화된 URL로 자동 판단하여
"/MyClass/MyMethod/param1/param2" 의 처리결과를 출력합니다.

URL 암호화 기능을 사용하면 외부에 자신의 웹페이지 링크를 제공할때 URL의 자세한 위치를 숨기거나, 암호화 키값 변경으로 이전에 알려진 URL을 사용할 수 없게 처리할 수도 있습니다.



Spac URL 암호화기능을 사용하려면 아래의 과정을 거칩니다.

1. Spac/controller/Controller.ini 설정
[Crypt URL]
useCryptUrl                = true

Controller.ini 파일내용 중 위의 내용이 있는 부분을 찾아 값을 "true" 로 설정합니다.

2. Spac/controller/Crypt.ini 설정
;Crypt Url Configuration
flag                = "a"                        ; 암호화URL 키값
className             = "Crypt"                            ; 암호화 클래스명
classPath            = "../Spac/controller/Crypt/Crypt.Class.php"    ; 암호화클래스 경로
encryptMethodName     = "encrypt"                            ; 암호화 메소드명
decryptMethodName    = "decrypt"                         ; 복호화 메소드명

   (1) 두번째 줄의 "flag" 에 지정된 값을 자신이 원하는 값으로 변경합니다.
   (2) 네번째 줄의  "classPath" 의 경로값을 "Spac" 경로가 맞는지 확인 한 후 맞지 않는경우 제대로 수정합니다.
   (3) 위의 두가지 설정값을 제외한 나머지 줄은 암호화 클래스를 수정하지 않는 한 기본값을 그대로 사용합니다.
       (사용자가 직접 암호화 클래스를 작성하거나 수정할 경우 직접 작성한 클래스 및 암호화/복호화 메소드를 지정합니다.)
         => 테스트가 끝나면 위의 암호화 클래스인 Crypt.Class.php 파일을 반드시 수정하신후 사용하시길 권장합니다.
             기본 암호화 클래스는 예제를 위해 단순하게 암호화 하는 코드가 들어있습니다.


3. view 파일에 링크 생성시 암호화 메소드를 사용하여 링크를 생성합니다.
sample.html
/MyClass/MyMethod/param1/param2
<?=$this->encryptUrl("/MyClass/MyMethod/param1/param2")?>

위의 예제에서 첫번째줄은 암호화를 하지 않았고, 두번째 줄은 암호화를 했습니다.

위 예제의 출력결과는 아래와 같습니다.
/MyClass/MyMethod/param1/param2
/a%3D%3DwLNl3QsF2cz9ST51UZ0h2bk9CchJXYtFzLwFmch1mMa



암호화된 URL을 통해 접근할 경우 Spac 이 자동으로 복호화해서 처리합니다.


실제 적용되는것을 확인하시려면 http://www.phpwork.kr/View/Login 로 이동하신 후 아이디/비밀번호 찾기 링크를 클릭해보시면 암호화된 URL로 이동하는것을 확인하실 수 있습니다.


Posted by webdata
웹 페이지를 만들 때는 보통 하나의 파일로 하나의 페이지를 구성하기보다는, 페이지의 각 부분 ( 메인메뉴,서브메뉴,바디,하단카피라이트 등)을 각각 파일로 만들어 하나의 파일에 삽입하여 구성하는 방법을 많이 사용합니다.

예를 들면 아래와 같습니다.



위의 그림에서는 각 부분의 html 파일들이 모여 "layout.html" 파일을 이루고 있습니다.

layout.html 파일에 각 html 파일들을 직접 삽입하여 페이지를 구성할 수도 있으나, Spac 프레임웍은 위와 같은 레이아웃 구성을 쉽게 할 수 있도록 레이아웃 도구를 제공합니다.

이제 Spac 의 레이아웃 도구를 이용하여 위와 같은 레이아웃을 구성해 보도록 하겠습니다.


먼저 레이아웃을 구성할 설정파일을 열어 아래와 같이 입력합니다. (만약 설정파일이 존재하지 않는다면 만들어줍니다)
레이아웃 설정파일은 "Spac/controller/Layout.ini" 파일입니다.


* Spac/controller/Layout.ini
;layout files config
[main]
layout   = "/layout.html"
menu   = "/menu.html"
left  = "/left.html"
body  = "/body.html"
foot  = "/foot.html"

- 첫번째줄(녹색글씨) 는 주석문이므로 무시됩니다.

- 두번째줄은 레이아웃의 대표 이름입니다.
  이 설정파일에는 여러개의 레이아웃을 구성할 수 있으므로 각 레이아웃마다 구별할 수 있는 이름을 지정해줍니다.
  이번 예제에서는 "main" 으로 하겠습니다.

- 세번째줄은 전체레이아웃의 부모가 되는 파일을 지정합니다.
  이 부모파일은 반드시 레이아웃파일 구성중 가장 먼저 와야 합니다.

- 네번째부터는 부모 레이아웃의 각 부분에 들어갈 조각파일들을 지정합니다.
  레이아웃파일의 지정은 이름 = "값" 의 형식을 가집니다.


레이아웃 설정이 끝나면 그 내용대로 각각의 파일들을 만들어줍니다.
설정파일의 순서대로 파일들을 만들어보겠습니다.

* Spac/view/layout.html
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Spac Layout Page...</title>
</head>
<body>

<table border="1">
    <tr>
        <td width="800" colspan="2" height="70">#menu#</td>
    </tr>
    <tr>
       <td width="150" height="500">#left#</td>
       <td width="650">#body#</td>
    </tr>
    <tr height="50">
        <td width="800" colspan="2">#foot#</td>
    </tr>
</table>

</body>
</html>

레이아웃에 들어가는 내용은 전체적인 레이아웃 배치와 각 부분에 들어갈 html 파일로 구성됩니다.
html 로 삽입해야 하는 부분에는 "Layout.ini" 에 지정한 html 파일의 이름을 지정해주고 앞뒤로 "#" 을 이용해 닫습니다.(파랑색 글씨)


이제 각 html 파일의 내용을 만들어 보겠습니다.

* Spac/view/menu.html
이곳은 메뉴 영역입니다.


* Spac/view/left.html
이곳은 왼쪽 서브 메뉴 영역입니다.


* Spac/view/body.html
이곳은 바디 부분입니다.
<br/>
<?=$this->msg?>
<br/>
이곳이 주요 내용을 출력할 부분입니다.


* Spac/view/foot.html
이곳은 하단 카피라이트 부분입니다.




레이아웃을 위한 설정과 파일을 모두 만들었습니다.
이제 모델클래스를 만들어 지금까지 만든 레이아웃페이지를 출력해보겠습니다.

* Spac/model/LayoutTest.Class.php
<?php
class LayoutTest extends Controller {

    var $msg = '안녕하세요';

    function LayoutTest() {}

    function execute() {
        $this->setLayout("main");
        $this->result_uri = "body.html";
        $this->targetLayoutName  = "body";
        $this->dispatcher();
    }
}
?>

1. "setLayout" 메소드를 이용하여 "Layout.ini" 에 정의된 레이아웃 중 "main" 이라는 이름의 레이아웃을 적용합니다.
2. "result_uri" 에 주요한 출력파일을 설정합니다. (여기서는 body.html 가 주요한 내용이 있는 파일입니다.)
3. "targetLayoutName" 에는 위 2번 항목이 위치할 레이아웃내의 이름영역을 지정해줍니다. (기본값 "body")
4. "dispatcher" 메소드를 이용해 위 레이아웃을 화면에 배치/출력합니다.


브라우저에서 호출해봅니다.


실제 적용된 예제는 아래 링크에서 확인하실 수 있습니다.
Posted by webdata
Spac은 URL 을 분석하여 실행할 액션클래스를 찾아 실행하는데, 이때 호출되는 URL에 실행되는 액션클래스명이 노출되게 됩니다.

여러가지 이유로 노출되는 클래스명을 감추고 싶은경우 클래스매핑을 통해 호출되는 클래스와 실제 실행되는 클래스를 다르게 지정할 수 있습니다.

클래스매핑은 ActionClassMapping.ini 파일에의해 작동되므로 이 파일을 수정하여 사용합니다.

먼저 "ActionClassMapping.ini" 파일의 내용을 보면 아래와 같습니다.
;ActionClass Mapping
[Class]
Welcome = HelloSpac

세번째 줄 부터 실제 사용할 클래스명을 설정합니다.
세번째 줄의 변수명인 "Welcome"은 URL로 이 "Welcome" 이 호출되면 값인 "HelloSpac" 이 실행되게 합니다.
즉, http://www.mydomain.com/Welcome 이 호출되면 실제는 http://www.mydomain.com/HelloSpac 이 실행됩니다.



그렇다면 http://www.mydomain.com/HelloSpac 을 직접 호출되면 어떻게 될까요?
"HelloSpac" 의 실행결과 값이 그대로 출력됩니다.

위의 예처럼 실제 실행되는 클래스는 "HelloSpac" 이지만 웹에서 호출할땐 "Welcome" 을 사용하고
"HelloSpac" 이 호출되면 거부 응답을 하고 싶다면???

먼저 "HelloSpac" 이 호출될 경우 응답할 액션클래스를 생성합니다.
아래처럼 만들어 봅니다.

거부응답을 보여줄 클래스명을 "Deny.Class.php" 로 해봅시다.

* Spac/model/Deny.Class.php
<?php
class Deny extends Controller {
   
    function Deny() {}

    function execute() {
        echo "Access Denied";
    }

}
?>

거부 응답을 보여줄 "Deny" 클래스를 만들었습니다.

이제  "ActionClassMapping.ini" 에 거부응답 클래스를 등록해 줍니다.
;ActionClass Mapping
[Class]
Welcome = HelloSpac
HelloSpac = Deny


위처럼 설정하게 되면
1. http://www.mydomain.com/Welcome 이 호출되면 "HelloSpac" 클래스가 정상적으로 실행됩니다.
2. http://www.mydomain.com/HelloSpac 이 호출되면 "Deny" 클래스가 호출됩니다.

결론적으로 "HelloSpac" 를 실행하기 위해선 "Welcome" 을 호출해야만 하고 직접 "HelloSpac"을 호출하게되면 거부응답인 "Deny"를 보여줍니다.

직접 접근을 막고 싶은 클래스는 위와 같이 Deny 클래스를 매핑하여 외부에 해당 클래스의 노출을 막을 수 있습니다.



* 클래스매핑에 설정하는 접근클래스명은 Spac 클래스명명규칙을 따르지 않습니다.
  :  Spac 에서 액션클래스명은 알파벳이나 숫자로 이루어져야 하며 첫글짜는 반드시 알파벳대문자로 시작해야 하는 규칙이 
     있지만, 클래스 매핑을 통해 접속을 하도록 하는경우에는 이 규칙을 따르지 않아도됩니다.
     따라서 클래스매핑을 통해 URL 을 복잡하게 구성할 수도 있습니다.


     ActionClassMapping.ini
;ActionClass Mapping
[Class]
d90f7f896g5jh7467fg58df7g89df6g8df7g5h6DFA3jjd7sg____ = HelloSpac
     위 예제처럼 클래스명을 "d90f7f896g5jh7467fg58df7g89df6g8df7g5h6DFA3jjd7sg____" 와 같이 임의의 문자를 복잡하게
     구성해도 Spac에서 클래스매핑에 따라 "HelloSpac" 의 처리를 문제없이 수행합니다.
Posted by webdata
템플릿태그는 사용자 화면인 View 파일을 구성할때 html 및 php 코드를 사용해서 작성하게 되는데 이때 php코드들을 간단한 태그를 사용하여 간편하게 작성할 수 있도록 해줍니다.

이때 사용하는 태그는 기본적으로 Spac에 정의되어 있지만 사용자가 임의대로 작성하여 사용할 수도 있습니다.
템플릿태그는 View 에서만 사용할 수 있습니다.

템플릿태그를 사용하기 위해선 Spac 컨트롤러 환경설정파일내의 템플릿태그 사용을 활성화 해야 합니다. 


* 템플릿태그 사용 활성화
    : Controller.ini 파일의 "useTemplateTag" 부분을 활성화
[viewTemplate]
useTemplateTag    = true


* 템플릿사용 예제 (클래스 및 뷰)
----- Test.Class.php----------
<?
class Test extends Controller {
    var $msg;
    function Test() {
        $this->msg = '안녕하세요';
    }
    function execute() {
        $this->result_uri = 'test.html';
        $this->dispatcher();
    }
}
?>


---------- test.html -----------
<html>
<head>
<title>test</title>
</head>
<body>
{=msg}
</body>
</html>

위 test.html 내에서 "Test.Class.php" 의 맴버변수 "msg" 내용을 출력하기 위해서 {=msg} 를 사용했습니다.
이것은 템플릿 태그를 사용한 것이며 php코드 "<? echo $this->msg; ?>" 와 같은 결과입니다.

Spac 에서는 "Spac/ViewTemplate/ViewTemplate.Class.php"를 통해 템플릿태그의 치환을 수행합니다.
PHP코드로 치환된 코드들은 Spac컨트롤러에 의해 캐시로 저장되어 다음번 같은 내용을 호출시 템플릿치환과정을 생략하고 곧바로 저장된 캐시파일을 로드하여 실행하므로 매번 치환하지 않아 서버의 부담을 줄여줍니다. (Spac 컨트롤러 설정에서 "useViewCache" 기능 활성화)

"Spac/ViewTemplate/ViewTemplate.Class.php" 파일을 수정하여 자신만의 템플릿 문법을 정의하여 사용할 수도 있습니다.

'Spac 매뉴얼 > 템플릿태그의사용' 카테고리의 다른 글

Spac 기본 템플릿 태그  (0) 2010.02.16
Posted by webdata
넷북용 무선랜드라이버 rtl8192se 리눅스 드라이버 설치하기...


팬텀 V10HC 에 우분투 9.10을 설치했다.
모든 드라이버가 자동으로 설치됐지만, 무선랜이 인식이 안된다;;
내장되어 있는 무선랜카드는 "rtl8192se" 이다.
구글링을 해보니 넷북 어쩌고 하는 내용들이 많이 검색되는것으로 보아 넷북에 많이 사용하는 모델인가보다.

다행히 리얼텍 홈페이지에서 검색하니 리눅스 드라이버가 제공된다.

다운로드 링크 : http://www.realtek.com.tw/downloads/downloadsView.aspx?Langid=2&PNid=21&PFid=48&Level=5&Conn=4&DownTypeID=3&GetDown=false&Downloads=true

드라이버가 소스로 제공되므로 직접 컴파일 해야 한다.
파일내용을 풀면 텍스트 파일로 설명서가 제공되지만, 찾기 귀찮은분들을 위해 중요한 설치과정만 발췌했다.

1. 적당한 디렉토리 만들어 파일 내용 풀어놓기

2. 파일이 풀린 디렉토리로 들어가 아래의 순서대로 진행
    (1) sudo su
    (2) make
    (3) make install
    (4) reboot  
   


재부팅을 하고나면 시스템에 무선랜이 잡혀있다.
상단 메뉴바 우측의 트레이영역에 안테나모양의 무선랜을 마우스 우클릭하여 인식되는 AP를 선택하여 등록한다.
Posted by webdata

::: SPAC (Simple Php Action Class) PHP Framework:::


요기로 가서 보세요 : http://spac.tistory.com/65

Posted by webdata
Spac에서 모델은 사용자가 작성할 비즈니스로직을 뜻합니다.
Class 로 작성된 모델은  URL 을 통해 일정한 규칙대로 호출하게 되며, Spac 컨트롤러는 URL을 분석하여 해당 모델이 실행되도록 합니다.

::: 모델 클래스 작성 및 실행 방법 :::
1. 모델은 클래스(Class)로 작성해야 합니다.

2. 모델클래스는 model 영역에 작성해야 하며, Spac은 URL을 분석하여 model 영역의 사용자 모델클래스를 실행합니다.

3. 모델명명규칙은 아래와 같습니다.
    - 모델클래스 파일명은 "모델명.Class.php" 의 형태를 가져야 합니다.
    - 모델명은 알파벳 대/소 문자, 숫자, 언더바(_)만 사용가능합니다.
    - 모델명은 2글자 이상이어야 합니다.
    - 모델명의 첫글자는 반드시 대문자이어야 합니다.

4. 모델 클래스 작성시 Spac 컨트롤러의 메소드를 상속받아 사용하려면 반드시 Controller 를 상속받아야 합니다.

5. 작성된 모델 호출시에는 아래와 같은 URL 규칙으로 호출합니다.
    - http://www.mydomain.com/모델명/메소드명/전달변수1/전달변수2/전달변수3............

6. URL을 통해 모델 호출 시 메소드명은 생략 가능하며 생략할 경우 기본메소드인 "execute" 가 실행됩니다.

7. "model" 디렉토리 내에 하위 디렉토리를 만들고 그 안에 모델클래스를 작성하는 경우 호출 URL 의 모델명에 해당 하위디렉토리를 명시합니다.
    - http://www.mydomain.com/모델하위디렉토리명/모델명/메소드명/전달변수1/전달변수2/전달변수3............

Posted by webdata



Spac은 요청 URL을 분석하여 개발자가 작성한 모델 어플리케이션을 호출/실행 해 주고, 실행 결과값을 뷰를 통해 출력하는 역할을 합니다.

그림에서 보는바와 같이 사용자의 요청을 Spac 컨트롤러가 분석하여 수행해야 하는 모델클래스를 연결해주고, 모델에서 수행된 결과값을 받아 뷰로 출력하는 순환구조를 가지고 있습니다.

모델클래스를 작성하는데 필요한 확장컨트롤러(Dao, Paging 등)는 별도의 컨트롤러 형태로 제공되며, 사용자가 직접 개발한 클래스 또한 확장컨트롤러로 등록하여 사용할 수 있습니다.
Posted by webdata




Spac은 모델 및 사용자컨트롤러, 뷰 를 통합관리하는 PHP 개발 프레임웍입니다.
모든 파일들은 Spac 내에 위치하게되며 뷰를 제외한 모델 및 사용자컨트롤러는 PHP Class로 작성되어 집니다.

Posted by webdata