mirror of
https://github.com/apache/httpd.git
synced 2025-05-30 01:07:09 +03:00
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@421136 13f79535-47bb-0310-9956-ffa450edef68
429 lines
15 KiB
XML
429 lines
15 KiB
XML
<?xml version='1.0' encoding='EUC-KR' ?>
|
|
<!DOCTYPE manualpage SYSTEM "../style/manualpage.dtd">
|
|
<?xml-stylesheet type="text/xsl" href="../style/manual.ko.xsl"?>
|
|
<!-- English Revision: 420990 -->
|
|
|
|
<!--
|
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
|
contributor license agreements. See the NOTICE file distributed with
|
|
this work for additional information regarding copyright ownership.
|
|
The ASF licenses this file to You under the Apache License, Version 2.0
|
|
(the "License"); you may not use this file except in compliance with
|
|
the License. You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
-->
|
|
|
|
<manualpage metafile="ssi.xml.meta">
|
|
<parentdocument href="./">How-To / Tutorials</parentdocument>
|
|
|
|
<title>아파치 투토리얼: Server Side Includes 소개</title>
|
|
|
|
<summary>
|
|
<p>Server-side includes를 사용하여 HTML 문서에 동적인 내용을
|
|
추가할 수 있다.</p>
|
|
</summary>
|
|
|
|
<section id="related"><title>소개</title>
|
|
<related>
|
|
<modulelist>
|
|
<module>mod_include</module>
|
|
<module>mod_cgi</module>
|
|
<module>mod_expires</module>
|
|
</modulelist>
|
|
|
|
<directivelist>
|
|
<directive module="core">Options</directive>
|
|
<directive module="mod_include">XBitHack</directive>
|
|
<directive module="mod_mime">AddType</directive>
|
|
<directive module="core">SetOutputFilter</directive>
|
|
<directive module="mod_setenvif">BrowserMatchNoCase</directive>
|
|
</directivelist>
|
|
</related>
|
|
|
|
<p>이 글은 보통 SSI라고 부르는 Server Side Includes를 설명한다.
|
|
SSI가 가능하도록 서버를 설정하는 방법과 HTML 페이지에 동적인
|
|
내용을 추가하는 기본적인 SSI 사용법을 소개한다.</p>
|
|
|
|
<p>이 글의 뒷부분은 SSI 지시어 조건문과 같은 고급기법을
|
|
설명한다.</p>
|
|
|
|
</section>
|
|
|
|
<section id="what"><title>SSI가 무엇인가?</title>
|
|
|
|
<p>SSI (Server Side Includes)는 HTML 페이지에 사용하는 지시어로,
|
|
페이지를 서비스할때 서버가 처리한다. SSI를 사용하면 CGI
|
|
프로그램이나 다른 동적인 기술로 페이지 전체를 만들어서
|
|
서비스하지 않고도 HTML 페이지에 동적으로 생성한 내용을 추가할
|
|
수 있다.</p>
|
|
|
|
<p>SSI를 사용할지 아니면 프로그램으로 페이지 전체를 생성할지
|
|
결정은 페이지에서 정적인 부분이 많은지와 페이지를 서비스할
|
|
때마다 어느정도를 다시 계산해야할지에 달렸다. SSI는 현재
|
|
시간과 같이 적은 정보를 추가하는데 좋다. 그러나 페이지를
|
|
서비스할때 페이지의 대부분을 생성해야 한다면 다른 방법을
|
|
찾아봐야 한다.</p>
|
|
</section>
|
|
|
|
<section id="configuring">
|
|
<title>SSI가 가능하도록 서버 설정하기</title>
|
|
|
|
<p>서버가 SSI를 처리하려면 <code>httpd.conf</code> 파일이나
|
|
<code>.htaccess</code> 파일에서 다음 지시어를 사용해야 한다.</p>
|
|
<example>
|
|
Options +Includes
|
|
</example>
|
|
|
|
<p>그러면 아파치는 파일에서 SSI 지시어를 처리한다. 설정에는
|
|
보통 여러 <directive module="core">Options</directive> 지시어가
|
|
있고, 이 지시어들은 서로 덮어써서 무효로 만들다. 그래서
|
|
지시어를 맨마지막에 처리하기위해 보통 SSI를 원하는 특정
|
|
디렉토리에서 <code>Options</code>를 사용한다.</p>
|
|
|
|
<p>모든 파일에서 SSI 지시어를 처리하는 것은 아니다. 아파치에게
|
|
어떤 파일을 처리할지 알려줘야 한다. 두가지 방법이 있다.
|
|
하나는 다음과 같은 지시어로 <code>.shtml</code>과 같은 특정
|
|
파일 확장자를 가진 파일을 처리하는 방법이다.</p>
|
|
<example>
|
|
AddType text/html .shtml<br />
|
|
AddOutputFilter INCLUDES .shtml
|
|
</example>
|
|
|
|
<p>이 방법의 단점은 이미 있는 페이지에 SSI 지시어를 추가하는
|
|
경우 SSI 지시어를 처리하기위해 <code>.shtml</code> 확장자를
|
|
부여하기때문에 파일명과 이 페이지의 모든 링크를 변경해야
|
|
하는 점이다.</p>
|
|
|
|
<p>다른 방법은 <directive module="mod_include">XBitHack</directive>
|
|
지시어를 사용하는 방법이다.</p>
|
|
<example>
|
|
XBitHack on
|
|
</example>
|
|
|
|
<p><directive module="mod_include">XBitHack</directive>는
|
|
실행권한이 있는 파일에서 SSI 지시어를 처리한다. 그래서 이미
|
|
있는 페이지에 SSI 지시어를 추가한다면 파일명을 변경하지
|
|
않고 <code>chmod</code>로 파일에 실행권한을 주면 된다.</p>
|
|
<example>
|
|
chmod +x pagename.html
|
|
</example>
|
|
|
|
<p>하지 말아야 할 것 하나. 가끔 <code>.shtml</code> 파일명에
|
|
골치를 앓지말고 모든 <code>.html</code> 파일을 SSI 처리하라고
|
|
충고하는 사람이 있다. 이 사람들은 아마도 <directive
|
|
module="mod_include">XBitHack</directive>에 대해 모르는
|
|
것 같다. 명심할 점은 이렇게 하면 아파치는 파일에 SSI 지시어가
|
|
없더라도 클라이언트로 보내는 모든 파일을 살펴봐야 한다는
|
|
것이다. 성능이 매우 느려질 수 있으며, 좋은 생각이 아니다.</p>
|
|
|
|
<p>물론 윈도우즈에서는 실행권한이란 것이 없기때문에 후자를
|
|
사용할 수 없다.</p>
|
|
|
|
<p>내용이 동적이여서 계산하기 어렵기때문에 아파치 기본 설정은
|
|
SSI 페이지의 최근수정일과 content length HTTP 헤더를 보내지
|
|
않는다. 그래서 문서를 캐쉬하지 못하고 클라이언트가 느끼는
|
|
성능이 떨어진다. 두가지 해결방법이 있다.</p>
|
|
|
|
<ol>
|
|
<li><code>XBitHack Full</code> 설정은 사용한다. 그러면
|
|
아파치는 포함하는(include) 파일들의 수정일은 무시한체
|
|
원래 요청한 파일의 날짜만 보고 최근수정일을 알아낸다.</li>
|
|
|
|
<li><module>mod_expires</module>에 있는 지시어를 사용하여
|
|
파일에 직접 만기일을 설정하면 브라우저와 프록시가 문서를
|
|
캐쉬할 수 있다.</li>
|
|
</ol>
|
|
</section>
|
|
|
|
<section id="basic"><title>기본 SSI 지시어</title>
|
|
|
|
<p>SSI 지시어의 사용법은 다음과 같다.</p>
|
|
<example>
|
|
<!--#element attribute=value attribute=value ... -->
|
|
</example>
|
|
|
|
<p>HTML 주석같이 생겼기때문에 SSI 기능을 가동하지 않아도
|
|
HTML 소스에는 나오지만 브라우저는 무시한다. SSI를 올바로
|
|
설정하면 지시어를 결과값으로 바꾼다.</p>
|
|
|
|
<p>element는 다음중 하나다. 다음 회에 더 자세히 설명할 것이다.
|
|
지금은 SSI로 할 수 있는 몇가지 예를 보인다</p>
|
|
|
|
<section id="todaysdate"><title>오늘 날짜</title>
|
|
|
|
<example>
|
|
<!--#echo var="DATE_LOCAL" -->
|
|
</example>
|
|
|
|
<p><code>echo</code> element는 변수값을 그대로 출력한다.
|
|
CGI 프로그램에 제공하는 환경변수들 외에도 여러 표준 변수가
|
|
있다. 또, <code>set</code> element를 사용하여 직접 변수를
|
|
정의할 수도 있다.</p>
|
|
|
|
<p>날짜 출력 형식이 마음에 들지 않는다면, 다음과 같이
|
|
<code>config</code> element의 <code>timefmt</code> attribute를
|
|
사용한다.</p>
|
|
|
|
<example>
|
|
<!--#config timefmt="%A %B %d, %Y" --><br />
|
|
Today is <!--#echo var="DATE_LOCAL" -->
|
|
</example>
|
|
</section>
|
|
|
|
<section id="lastmodified"><title>파일의 수정일</title>
|
|
|
|
<example>
|
|
이 문서는 <!--#flastmod file="index.html" -->에 마지막으로 수정되었다
|
|
</example>
|
|
|
|
<p>이 element도 <code>timefmt</code> 형식 설정에 달렸다.</p>
|
|
</section>
|
|
|
|
<section id="cgi"><title>CGI 프로그램 결과를 포함하기</title>
|
|
|
|
<p>일반적인 SSI 사용법중 하나로, 많이들 애용하는 ``방문수
|
|
카운터'' 같은 CGI 프로그램 결과를 출력한다.</p>
|
|
|
|
<example>
|
|
<!--#include virtual="/cgi-bin/counter.pl" -->
|
|
</example>
|
|
|
|
</section>
|
|
</section>
|
|
|
|
<section id="additionalexamples">
|
|
<title>추가 예제</title>
|
|
|
|
<p>다음은 HTML 문서에 사용할 수 있는 몇가지 SSI 예제다.</p>
|
|
|
|
<section id="docmodified"><title>이 문서가 언제 마지막으로
|
|
수정되었나?</title>
|
|
|
|
<p>앞에서 SSI를 사용하여 사용자에게 문서의 최근수정일을
|
|
알릴 수 있다고 말했다. 그러나 실제 방법은 알려주지 않았다.
|
|
다음 코드를 HTML 문서에 사용하면 페이지에 시간 기록을 남긴다.
|
|
물론 위에서 설명한대로 SSI가 올바로 작동해야 한다.</p>
|
|
<example>
|
|
<!--#config timefmt="%A %B %d, %Y" --><br />
|
|
이 문서는 <!--#flastmod file="ssi.shtml" -->에 마지막으로 수정되었다;
|
|
</example>
|
|
|
|
<p>물론 <code>ssi.shtml</code>대신 원하는 실제 파일명을
|
|
사용한다. 아무 페이지에라도 붙여넣을 수 있는 범용코드를
|
|
원한다면, 파일명 대신 <code>LAST_MODIFIED</code> 변수를
|
|
사용한다.</p>
|
|
<example>
|
|
<!--#config timefmt="%D" --><br />
|
|
This file last modified <!--#echo var="LAST_MODIFIED" -->
|
|
</example>
|
|
|
|
<p><code>timefmt</code> 형식에 대한 자세한 정보는 검색엔진에서
|
|
<code>strftime</code>을 찾아봐라. 문법은 같다.</p>
|
|
</section>
|
|
|
|
<section id="standard-footer">
|
|
<title>표준 페이지 하단을 포함하기</title>
|
|
|
|
<p>여러 페이지가 있는 사이트를 관리한다면 페이지 전체를
|
|
수정하는 것은, 특히 페이지들이 표준 외관을 가지도록 수정하는
|
|
것은 정말로 괴롭다.</p>
|
|
|
|
<p>페이지 상단(header)과 하단(footer)을 파일로 포함하여
|
|
이런 수정의 부담을 덜 수 있다. 모든 페이지에서
|
|
<code>include</code> SSI 명령어를 사용하여 페이지 하단 파일
|
|
하나를 포함하면 된다. <code>include</code> element의
|
|
<code>file</code> attribute나 <code>virtual</code> attribute로
|
|
포함할 파일을 지정한다. <code>file</code> attribute는 <em>현재
|
|
디렉토리에 상대적인</em> 파일경로다. 즉, (/로 시작하는)
|
|
절대파일경로나 경로 안에 ../를 사용할 수 없다. 아마도 서비스하는
|
|
문서의 상대 URL을 지정할 수 있는 <code>virtual</code> attribute가
|
|
더 유용할 것이다. 경로를 /로 시작할 수 있지만, 포함하려는
|
|
파일이 서비스하는 파일과 같은 서버에 있어야 한다.</p>
|
|
<example>
|
|
<!--#include virtual="/footer.html" -->
|
|
</example>
|
|
|
|
<p>나는 보통 이 두가지를 합쳐서 포함할 페이지 하단 파일에
|
|
<code>LAST_MODIFIED</code> 지시어를 넣는다. 포함하려는 파일에도
|
|
SSI 지시어가 나올 수 있으며, 이렇게 포함한 파일이 다른 파일을
|
|
포함하는 식으로 여러번 계속 포함할 수도 있다.</p>
|
|
</section>
|
|
|
|
</section>
|
|
|
|
<section id="config">
|
|
<title>이외에 설정할 수 있는 것은?</title>
|
|
|
|
<p>시간 형식 <code>config</code>(설정) 외에 두가지를 더
|
|
<code>config</code>(설정)할 수 있다.</p>
|
|
|
|
<p>보통 SSI 지시어가 잘못되면 다음과 같은 문구가 나온다</p>
|
|
<example>
|
|
[an error occurred while processing this directive]
|
|
</example>
|
|
|
|
<p>이 문구를 변경하고 싶다면 <code>config</code> element의
|
|
<code>errmsg</code> attribute를 사용하여 변경한다.</p>
|
|
<example>
|
|
<!--#config errmsg="[It appears that you don't know how to use SSI]" -->
|
|
</example>
|
|
|
|
<p>사이트를 서비스하기 전에 모든 SSI 지시어 문제를 해결하여
|
|
사용자가 이런 문구를 보지 않길 바란다. (그렇지?)</p>
|
|
|
|
<p>그리고 <code>sizefmt</code> attribute가 반환하는 파일크기
|
|
형식을 <code>config</code>(설정)할 수 있다. 바이트로 크기를
|
|
보여주려면 <code>bytes</code>, 적절히 Kb나 Mb로 크기를
|
|
보여주려면 <code>abbrev</code>를 사용한다.</p>
|
|
</section>
|
|
|
|
<section id="exec">
|
|
<title>명령어 실행하기</title>
|
|
|
|
<p>나는 다음 달에 작은 CGI 프로그램과 SSI를 같이 사용하는
|
|
글을 쓸 예정이다. 지금은 <code>exec</code> element로 할
|
|
수 있는 다른 것들을 설명할 것이다. SSI는 실제 쉘을 (정확히는
|
|
<code>/bin/sh</code>나 Win32를 사용한다면 DOS 쉘) 사용하여
|
|
명령어를 실행한다. 예를 들어, 다음은 디렉토리 목록을 보여준다.</p>
|
|
<example>
|
|
<pre><br />
|
|
<!--#exec cmd="ls" --><br />
|
|
</pre>
|
|
</example>
|
|
|
|
<p>or, on Windows</p>
|
|
<example>
|
|
<pre><br />
|
|
<!--#exec cmd="dir" --><br />
|
|
</pre>
|
|
</example>
|
|
|
|
<p><code>dir</code> 출력에 브라우저가 혼동할
|
|
``<<code>dir</code>>'' 문자열이 포함되있기때문에,
|
|
윈도우즈에서 이 지시어를 사용하면 결과가 조금 이상할 것이다.</p>
|
|
|
|
<p>이 기능은 <code>exec</code> 태그에 사용한 어떤 명령어라도
|
|
실행할 수 있기때문에 매우 위험하다. ``방명록''과 같이 사용자가
|
|
웹페이지 내용을 수정할 수 있는 환경이라면, 이 기능을 절대로
|
|
사용해선 안된다. <code>Options</code> 지시어에
|
|
<code>IncludesNOEXEC</code> 아규먼트를 사용하여 SSI를 허용하지만
|
|
<code>exec</code> 기능을 막을 수 있다.</p>
|
|
</section>
|
|
|
|
<section id="advanced">
|
|
<title>고급 SSI 기법</title>
|
|
|
|
<p>내용을 출력하는 기능 외에 아파치 SSI는 변수 설정이 가능하고,
|
|
비교문과 조건문에 이 변수를 사용할 수 있다.</p>
|
|
|
|
<section id="caveat"><title>경고</title>
|
|
|
|
<p>이 글에서 설명하는 대부분의 기능은 아파치 1.2 이후부터
|
|
사용할 수 있다. 물론, 아파치 1.2 이상을 사용하지 않는다면
|
|
아마도 빨리 업그레이드해야 한다. 해라. 지금 해라. 기다릴
|
|
것이다.</p>
|
|
</section>
|
|
|
|
<section id="variables"><title>변수 설정</title>
|
|
|
|
<p><code>set</code> 지시어를 사용하여 나중에 사용할 변수를
|
|
설정할 수 있다. 앞으로 변수가 필요하기때문에 먼저 설명한다.
|
|
문법은 다음과 같다.</p>
|
|
<example>
|
|
<!--#set var="name" value="Rich" -->
|
|
</example>
|
|
|
|
<p>다음과 같이 값을 문자그대로 설정하지 않고 <a
|
|
href="../env.html">환경변수</a>나 위에서 설명한 변수(예를
|
|
들어, <code>LAST_MODIFIED</code>)와 같이 다른 변수를 사용하여
|
|
변수값을 설정할 수도 있다. 이때 변수명 앞에 달러 표시($)를
|
|
붙여서 문자열이 아닌 변수임을 표시한다.</p>
|
|
|
|
<example> <!--#set var="modified" value="$LAST_MODIFIED" -->
|
|
</example>
|
|
|
|
<p>변수값에 달러 문자를 그대로 입력하려면 달러 표시 앞에
|
|
백슬래쉬를 사용한다.</p>
|
|
<example>
|
|
<!--#set var="cost" value="\$100" -->
|
|
</example>
|
|
|
|
<p>마지막으로 긴 문자열 중간에 변수를 사용하는데 뒤에 있는
|
|
문자도 변수명으로 오인하여 혼동되는 경우, 변수명을 대괄호로
|
|
묶어서 확실히 한다. (좋은 예를 찾기 힘들지만, 무슨 말인지
|
|
이해하길 바란다.)</p>
|
|
<example>
|
|
<!--#set var="date" value="${DATE_LOCAL}_${DATE_GMT}" -->
|
|
</example>
|
|
</section>
|
|
|
|
<section id="conditional">
|
|
<title>조건 표현식</title>
|
|
|
|
<p>변수를 설정하고 비교할 수 있으니 조건문이 가능하다. 이제
|
|
SSI가 일종의 간단한 프로그래밍언어가 된다.
|
|
<module>mod_include</module>는 조건문을 만드는 <code>if</code>,
|
|
<code>elif</code>, <code>else</code>, <code>endif</code>
|
|
구조를 제공한다. 실제 한 페이지로 여러 논리적인 페이지를
|
|
만들 수 있다.</p>
|
|
|
|
<p>조건문 구조는 다음과 같다.</p>
|
|
<example>
|
|
<!--#if expr="test_condition" --><br />
|
|
<!--#elif expr="test_condition" --><br />
|
|
<!--#else --><br />
|
|
<!--#endif -->
|
|
</example>
|
|
|
|
<p><em>test_condition</em>에는 어떤 논리비교라도 사용할
|
|
수 있다. 값을 다른 값과 비교하거나, 특정 값이 ``참''인지
|
|
검사한다. (문자열이 비어있지 않으면 참이다.) 사용가능한
|
|
비교 연산자를 모두 보려면, <module>mod_include</module>
|
|
문서를 참고하라. 다음은 조건문을 사용한 몇가지 예제다.</p>
|
|
|
|
<p>설정파일에 다음 줄을 추가한다.</p>
|
|
<example>
|
|
BrowserMatchNoCase macintosh Mac<br />
|
|
BrowserMatchNoCase MSIE InternetExplorer
|
|
</example>
|
|
|
|
<p>클라이언트가 맥킨토시에서 실행하는 Internet Explorer라면
|
|
환경변수 ``Mac''과 ``InternetExplorer'' 모두 참으로 설정한다.</p>
|
|
|
|
<p>그리고 SSI 문서에 다음과 같이 적는다.</p>
|
|
<example>
|
|
<!--#if expr="${Mac} && ${InternetExplorer}" --><br />
|
|
여기에 사과문가 나온다<br />
|
|
<!--#else --><br />
|
|
여기에 멋진 JavaScript 코드가 나온다<br />
|
|
<!--#endif -->
|
|
</example>
|
|
|
|
<p>내가 매킨토시 IE에 반감이 있는 것은 아니다. 나는 단지
|
|
저번주에 다른 곳에서는 문제가 없는 JavaScript 코드가 매킨토시
|
|
IE에서는 동작하지 않아서 몇시간을 고생했다. 위는 임시
|
|
해결책이다.</p>
|
|
|
|
<p>(직접 정의하였건 일반 환경변수이건) 어떤 변수라도 조건문에
|
|
사용할 수 있다. 아라치는 <code>SetEnvIf</code>나 다른 관련
|
|
지시어로 환경변수를 설정할 수 있기때문에 CGI 없이도 멋지게
|
|
동적인 내용을 만들 수 있다.</p>
|
|
</section>
|
|
</section>
|
|
|
|
<section id="conclusion"><title>결론</title>
|
|
|
|
<p>SSI는 확실히 CGI나 동적인 웹페이지를 생성하는 다른 기술을
|
|
대체할 수 없다. 그러나 많은 추가 작업없이 페이지에 동적인
|
|
내용을 조금 추가하기에는 훌륭한 방법이다.</p>
|
|
</section>
|
|
|
|
</manualpage>
|