Article Category

분류 전체보기 (303)
영어 (9)
관심 (11)
PHP (6)
자바&JSP (2)
Flex (3)
프로젝트 (1)
내 폴더 (183)
Ver 1.0 (94)

 

'관심/PHP'에 해당되는 글 6건

  1. 2011.02.15 mysql 프로시저에서 limit에 변수 불가 버그
  2. 2009.02.04 웹 리퍼러 수정하기
  3. 2007.09.08 PHP를 쉘 스크립트로 사용하기
  4. 2007.09.05 DOM 활용 1
  5. 2007.09.05 DOM 개념
  6. 2006.09.13 웹서버 설치

mysql 프로시저에서 limit에 변수 불가 버그

"order by sort limit __count, 12"

mysql에서는 위와 같은 쿼리가 불가능하다.
이유는 숫자가 아닌 어떠한 것도 limit에 사용 할 수 없다는 것..
하지만 난 저게 필요한걸..

검색 끝에 다름과 같은 결과를 얻었다.


Noted in 5.5.6, 6.0.14 changelogs.

Within stored programs, LIMIT clauses now accept integer-valued
routine parameters or local variables as parameters.

숫자형 파라미터나 내부변수는 사용가능하다는 것..
하지만 5.5.6 버전 부터.. ㅠㅠ

아 난감하다..

웹 리퍼러 수정하기

보호되어 있는 글입니다.
내용을 보시려면 비밀번호를 입력하세요.

PHP를 쉘 스크립트로 사용하기

오늘날 동적 웹 페이지를 개발하는 최고의 언어가 PHP라는 것은 누구나 다 아는 사실입니다. 하지만 PHP가 쉘 스크립트 언어로도 사용할 수 있다는 것은 모르는 사람이 많은 것 같습니다. 쉘 스크립트 언어로써의 PHP는 Bash나 Perl만큼 튼튼하지는 않지만 많은 이접이 있습니다.
PHP를 쉘 언어로 사용하기 위해 요구되는 것은 PHP를 아파치 모듈 대신 CGI 바이너리로 설치해야 합니다. 보안 문제가 걸려 있기 때문에 PHP메뉴얼의 참고하기 바랍니다.
일반적인 PHP 웹 페이지와 PHP 쉘 스크립트 사이의 단 한가지 차이점은 PHP스크립트의 제일 첫 번째 줄에 다음과 같이 쉘 호출을 해주어야 하는 점입니다.

#!/usr/local/bin/php -q

-q 옵션은 HTTP헤더를 사용하지 않겠다는 뜻입니다. 또한 PHP태그를 사용해서 스크립트의 시작과 끝을 지정해 주어야 합니다.

<?php ?>

이제 모든이가 알고 사랑하는 표준 예를 들어봅시다.

#!/usr/local/bin/php -q
<?php

print("Hello, world!n");

?>

이 코드는 예상하다 시피 화면에 "Hello, world!"를 출력하게 됩니다.

-쉘 스크립트에 매개변수 전달하기(Passing arguments to the shell script)

일반적으로 쉘 스크립트에는 매개변수를 전달 할 수 있어야합니다. 매개변수를 전달하는 것은 다음과 $argv 배열을 통해서 이루어 집니다.

#!/usr/local/bin/php -q
<?php
$first_name = $argv[1];
$last_name = $argv[2];

print("Hello, $first_name $last_name! How are you today?n");

?>

즉 이 예제에서는 스크립트로 전달된 두 매개변수를 출력합니다. 이 스크립트는 다음과 같이 사용될 수 있고

[dbrogdon@artemis dbrogdon]$ scriptname.ph Darrell Brogdon

다음과 같을 출력을 내게 될 것입니다.

Hello, Darrell Brogdon! How are you today?
[dbrogdon@artemis dbrogdon]$

쉘 스크립트와 웹 페이지에서 $argv 배열의 차이점은 쉘 스크립트의 $argv[0]은 실행된 스크립트 명이 들어 간다는 점입니다. 웹 페이지에서는 첫 번째 값($argv[0])은 query 문자열입니다.

-스크립트를 인터액티브하게 만들기(Making a script more interactive)

그러데 어떻게 해야 사용자의 입력을 받아들일 수 있을까요? 어떻게 인터액티브한 스크립트를 생성할 수 있을까요? PHP는 웹상에서 명령을 읽어오는 함수는 기본적으로 지원하지 않습니다. 하지만 다음과 같은 PHP 함수를 사용해서 에뮬레이트할 수 있습니다.

주 : 이 함수는 Unix상에서만 동작합니다.

<?php

function read() {
$fp=fopen("/dev/stdin", "r");
$input=fgets($fp, 255);
fclose($fp);

return $input;
}

?>

이 함수는 표준 입력(Linux에서 /dev/stdin)을 의미하는 파일 포인터를 오픈하고 n이나 EOF를 만나거나 255문자까지 읽어 옵니다. 주로 n가지 일어오게 될 것입니다. 그런 다음 파일 포인터를 닫고 데이터를 리턴합니다.

이제 앞서든 예제 스크립트를 수정해서 read()함수를 사용해서 사용자 입력을 기다리게 해봅시다

#!/usr/local/bin/php -q
<?php

function read() {
$fp=fopen("/dev/stdin", "r");
$input=fgets($fp, 255);
fclose($fp);

return $input;
}

print("What is your first name? ");
$first_name = read();

print("What is your last name? ");
$last_name = read();

print("nHello, $first_name $last_name! Nice to meet you!n");

?>

그러나 이 스크립트를 실행하게 되면 마지막 라인에서 한줄로 출력되는 대신에 세줄로 출력되게 됩니다. 이는 read()함수가 n문자까지 취했기 때문입니다. 이는 read()함수가 데이터를 리턴할 때 n을 제거해서 데이터를 리턴하게 하면 해결됩니다.

<?php

function read() {
$fp=fopen("/dev/stdin", "r");
$input=fgets($fp, 255);
fclose($fp);

return str_replace("n", "", $input);
}

?>

- PHP 쉘 스크립트를 일반 쉘 스크립트에 포함시키기

때때로 PHP쉘 스크립트를 Bash나 다른 쉘 스크립트에 삽입하는 것이 편할 때도 있습니다. 이는 간단한 트릭으로 가능합니다.
PHP코드를 포함시키는 방법 :

#!/bin/bash
echo This is the Bash section of the code.

/usr/local/bin/php -q << EOF
<?php
print("This is the PHP section of the coden");
?>
EOF

간단하지 않습니까? 변수를 추가하기 전까지는 간단합니다. 다음의 코드 부분을 실행해 볼까요?

#!/bin/bash
echo This is the Bash section of the code.

/usr/local/bin/php -q << EOF
<?php
$myVar = "PHP";
print("This is the $myVar section of the code.n");
?>
EOF

아마 다음과 같은 에러를 발생하게 될 것입니다.

<b>Parse error</b>: parse error in <b>-</b> on line <b>2</b><br>

이를 해결하기 위해서 PHP코드의 $앞에 를 붙여 줍니다.

#!/bin/bash
echo This is the Bash section of the code.

/usr/local/bin/php -q << EOF
<?php

$myVar = "PHP";
print("This is the $myVar section of the code.n");
?>
EOF

이제 PHP를 사용해서 자신의 쉘 스크립트를 만들어 보세요~

--Darrell
--번역 : 허련호



kjh90@orgio.net
1]
# php -q your_script.php
이런 식으로 사용하는 대신
# ./your_script.php
라고 실행하려면
스크립트 맨 첫줄에는
#!/usr/local/bin/php -q
라고 쓰고, 그 아래에 <? 로 시작해서 ?>로 끝나는 PHP 구문을 씁니다.

[2]
콘솔 상에서 입력을 받는 경우에는
fopen("php://stdin", "r");
을 사용합니다.

예제:
#!/usr/local/bin/php -q
<?php
function getInput($length = 255) {
$fr = fopen("php://stdin", "r");
$input = fgets($fr, $length);
$input = rtrim($input);
fclose($fr);
return $input;
}
echo '글자를 입력하세요 (10자 이내): ';
$text = getInput(10);
echo '입력하신 내용은 '.$text."입니다.\n";
?>

[3]
물론 PHP 스크립트에는 실행권한이 주어져야겠죠.

원문보기 : http://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=tipntech&wr_id=1899&sca=&sfl=wr_subject&stx=%BD%A9&sop=and&page=2


그밖에 문서(en)

DOM 활용

1.XMLHttpRequest객체 생성
 
 
var xmlHttp;
 
function createXMLHttpRequest() {     if (window.ActiveXObject) {         xmlHttp = new ActiveXObject("Microsoft.XML HTTP"); //IE     }     else if (window.XMLHttpRequest) {         xmlHttp = new XMLHttpRequest();//Mozila     } }
 
2.메소드
void open(string method, string url, boolean asynch, string username, string password )
   method - GET,POST,PUT
   url - 요청 서버 URL
   asynch - 비동기/동기 선택 (default true - 비동기)
 
void send(content) : 실질적으로 요청을 서버로 보낸다. 요청이 비동기이면 이 메소드는 바로 리턴되지만 요청이 동기이면 서버에서 응답을 받을때까지 계속 대기한다. content 는 선택사항이며, DOM 객체(XML 객체)이거나 input stream, string 값으로 설정할 수 있으며 HttpRequest body 의 한 부분으로 서버로 전달된다. content 에 값을 넘 기려면 open() 메소드는 반드시 POST 로 설정해야 하며, GET 방식으로 요청하려면 null 을 설정하면 된다.
 
void setRequestHeader(string header, string value) : header 에 해당하는 value 값으로 HttpRequest  헤더에 값을 설정하는 메소드로써, 반드시 open() 메소 드 다음에 위치해야 한다.
 
void abort() : 요청중지
 
string getAllResponseHeaders() : 요청에 대응되는 응답의 헤더정보를 리턴한다. 즉, C ontent-Length, Date, URI 등을 포함하는 헤더정보를 string 형식으로 반환한다.
 
string getResponseHeader(string header) : 응답의 헤더정보중에서 header 에 대 응되는 값을 string 형식으로 반환한다.
 
 
3.속성
onreadystatechange : 자바스크립트 콜백함수(funtion pointer)를 저장한다. 콜백함수는 readyState 값이 변할때 마다 호출된다. 요청이 서버로 보 내지면 readyState 는 5가지 숫자값으로 계속 변화가 일어나게 된다.
readyState : 요청의 상태를 의미한다.(0 = uninitialized, 1 = loading, 2 = loaded, 3 = interactive, 4 = complete)
responseText : 서버의 응답을 string 형식으로 나타낸다. 단순 text를 innerHTML 속성 으로 표현하기에는 알맞지만 논리적으로 파싱하거나 동적으로 페이지 컨텐츠를 생 성하기는 힘들다.
responseXML : 서버의 응답을 XML 로 나타낸다. 이 속성은 DOM 객체로 파싱할 수 있다.
status : 서버로부터의 HTTP 상태코드이다.(예 200(OK), 404(NOT Found), 202(결과 값 이 없을 때)등등
)
statusText : HTTP 상태코드에 대한 텍스트 값이다.(예 OK, NOT Found 등등)
 
 
4. 예제
function startRequest() {     createXMLHttpRequest();     xmlHttp.onreadystatechange = handleStateChange;//function     xmlHttp.open("GET", "simpleResponse.xml", true);     xmlHttp.send(null); }     function handleStateChange() {     if(xmlHttp.readyState == 4) {         if(xmlHttp.status == 200) {
            // complete, OK             alert("The se rver replied with: " + xmlHttp.responseText);         }     } }
 
5.DOM 속성
 
 
childNodes : 현재 요소의 자식을 배열로 표현한다.
firstChild : 현재 요소의 첫번째 자식이다.
lastChild : 현재 요소의 마지막 자식이다.
nextSibling : 현재 요소와 바로 다음의 요소를 의미한다.
nodeValue : 해당 요소의 값을 읽고 쓸 수 있는 속성을 정의한다.(=data)
parentNode : 해당 요소의 부모노드이다.
previousSibling : 현재 요소와 바로 이전의 요소를 의미한다.
 
 
6.DOM 메소드
 
getElementById(id) : 다큐먼트에서 특정한 id 속성값을 가지고 있는 요소를 반 환한다
.
getElementsByTagName(name) : 특정한 태그 이름을 가지고 있는 자식 요소로 구성된 배열을 리턴한다
.
hasChildNodes() : 해당 요소가 자식 요소를 포함하고 있는지를 나타내는 Boolean 값 을 리턴한다
.
getAttribute(name) : 특정한 name 에 해당하는 요소의 속성값을 리턴한다.
 
document.createElement(tagName) : tagName 으로된 엘리먼트를 생성한다. div 를 메 소드 파라미터로 입력하면 div 엘리먼트가 생성된다.
document.createTextNode(text) : 정적 텍스트를 담고 있는 노드를 생성한다.
<element>.appendChild(childNode) : 특정 노드를 현재 엘리먼트의 자식 노드 에 추가시킨다. (예를들어 select 엘리먼트에 option 엘리먼트 추가)
<element>.getAttribute(name) : 속성명이 name 인 속성값을 반환한다.
<element>.setAttribute(name, value) : 속성값 value 를 속성명이 name 인 곳에 저장한다
.
<element>.insertBefore(newNode, tartgetNode) : newNode 를  tartgetN ode 전에 삽입한다
.
<element>.removeAttribute(name) : 엘리먼트에서 name 속성을 제거한다.
<element>.removeChild(childNode) : 자식 엘리먼트를 제거한다.
<element>.replaceChild(newNode, oldNode) : oldNode 를 newNode 로 치환한 다
.
<element>.hasChildNodes() : 자식 노드가 존재하는지 여부를 판단한다. 리 턴형식은 Boolean 이다

DOM 개념

DOM은 문서 객체 모형이라고 말하며, HTML의 구조에 접근하는 방법

Document.layers 층에 접근하기 위해 document.all 또는document.getElementById 사용

 

W3C의 표준 – document.getElementById

 

 

 

계층적 구조(Tree 구조)

 

<HTML> - 문서의 TOP(document 문서 하위)

<HEAD> - <HTML>의 꼬리표

, HTML 문서의 최정상은 document 가 된다.

 

 

DOM을 이해하기 위한 도형

 

(부모)

|

|

형제1---- ----형제2

|

|

아이1------------ 아이2

 

 

1. parentNode : 나를 기준으로 부모 마디에 접근.

   - document.getElementById("myElement").parentNode

 

2. childNode : 나를 기준으로 NodeList를 반환

- document.getElementById("나").childNodes

- document.getElementById("나").childNodes.item(0)

- document.getElementById("나").childNodeds[0] 와 동일

 

3. firstChild : 첫번째 마디에 대한 접근

- document.getElementById("나").firstChild

- document.getElementById("나").childNodeds[0] 와 동일

 

4. lastChild : 마지막 마디에 대한 접근

- document.getElementById("나").lastChild

- document.getElementById("나").childNodes.item(document.getElementById("나").childNo des.length)과 동일

 

5. previousSibling : 아이1로 접근

- document.getElementById("나").previousSibling

 

6. nextSibling은 아이2에 접근

   - document.getElementById("나").nextSibling

웹서버 설치

스킬 공부에 앞서 일단 리눅스를 깔려고 했으나, 여러가지 제약이 앞서서 일단 보류 하기로 하고, 윈도우용 웹서버를 간단하게 설치 했다.
apmsetup으로 설치 할까 했으나, http://kldp.net/projects/rwapm/ 에서 만들고 있는 rwapm이란 프로그램을 사용하기로 했다. 이건 예전에 1.0 버전을 PHPschool에서 받아서 쓴적이 있는데 지금은 벌써 버전이 5.7까지 나왔다. 2년이란 시간이 절대 짧지만은 않았는가 보네.

프로그램 정보
* Apache 2.2.3 (mod_ssl mod_deflate zlib 1.2.3)
* OpenSSL/0.9.8b
* mod_bandwidth 0.7(대역폭 제한모듈)
* php 5.1.6/exif/mbstring/gd2/iconv/mcrypt/mhash/crypt
* iconv 1.11.0
* sendmail/smtp
* mod_security 1.9.4
* mysql 5.0.24 (mysqld-max-nt,euc-kr)
* Phpmyadmin 2.8.2.4
* eAccelerator 0.9.6-svn268-dev
* ZendOptimizer 3.0.1
* GeoIP webalizer2.01.10

GD Version bundled (2.0.28 compatible)
FreeType Support enabled
FreeType Linkage with freetype
FreeType Version 2.2.1
T1Lib Support enabled
GIF Read Support enabled
GIF Create Support enabled
JPG Support enabled
PNG Support enabled
WBMP Support enabled
XBM Support enabled

설정 테스트
관리자 페이지

빌드에 사용된 프로그램
Microsoft Visual Studio c++ 6.0을 사용해 개발하였습니다.;;

prev 1 next