'Web 프로그램/PHP 응용 및 활용'에 해당되는 글 46건

728x90

출처 : http://cacung82.blog.me/10035514681


n         쿠키란?

ü        쿠키란 서버측에서 클라이언트측에 상태 정보를 저장하고 추출할 수 있는 메커니즘

ü        클라이언트의 매 요청마다 웹 브라우저로부터 서버에게 전송되는 정보패킷의 일종

ü        HTTP에서 클라이언트의 상태 정보를 클라이언트의 하드 디스크에 저장하였다가 필요 시 정보를 참조하거나 재사용할 수 있음.

ü        사용 예

   방문했던 사이트에 다시 방문 하였을 때 아이디와 비밀번호 자동 입력

   팝업에서 오늘 이 창을 다시 보지 않음체크

ü        쿠키의 제약조건

   클라이언트에 총 300개까지 쿠키를 저장할 수 있다

   하나의 도메인 당 20개의 값만을 가질 수 있다

   하나의 쿠키 값은 4096Byte까지 저장 가능하다

하나의 도메인에서 설정한 쿠키값이 20개를 초과하면 가장 적게 사용된 쿠키부터 지워짐. 또한 쿠키는 기존에 설정한 값이 있는 곳에 값을 저장하거나 배열형태의 쿠키에 단일 값을 저장하려고 할 때 아무런 경고 없이 덮어쓰기 때문에 주의를 해야 한다.

 

n         세션이란?

ü     세션이란 클라이언트와 웹서버 간에 네트워크 연결이 지속적으로 유지되고 있는 상태를 말함

ü     클라이언트가 웹서버에 요청하여 처음 접속하면 JSP(혹은ASP)엔진은 요청한 클라이언트에 대하여 유일한 ID를 부여하게 되는데, ID를 세션이라 부른다

ü     세션 ID를 임시로 저장하여 페이지 이동 시 이용하거나, 클라이언트가 재 접속 했을 때 클라이언트를 구분할 수 있는 유일한 수단이 된다

ü     세션의 장점

  각각의 클라이언트마다 고유의 ID 부여

  세션 객체마다 저장해 둔 데이터를 이용하여 서로 다른 클라이언트의 요구에 맞게 서비스 제공

  클라이언트 자신만의 고유한 페이지를 열어놓아서 생길 수 있는 보안상의 문제 해결 용이

n         쿠키와 세션의 차이점

 쿠키(cookie)와 세션(session)은 기능상 비슷한 역할을 하고, 동작원리도 비슷하다. 왜냐하면, 일반적인 세션은 쿠키를 바탕으로 동작하기 때문이다. 그러나 가장 중요한 차이점은 저장되는 곳이 다르다는 것이다. 쿠키는 클라이언트에 저장되고, 세션은 서버에 저장된다. 쿠키의 경우에는 서버의 자원을 전혀 사용하지 않지만, 세션의 경우에는 서버에 저장되기 때문에 서버의 자원을 사용할 수가 있다. 쿠키와 세션의 만료 되는 기간도 다르다.

n    쿠키와 세션의 차이점()

구분

쿠키

세션

저장 위치

클라이언트

서버

저장 형식

텍스트형식

Object

종료 시점

쿠키 저장 시 설정(설정하지 않으면 브라우저 종료 시 소멸)

정확한 시점을 알 수 없다

    

클라이언트의 자원을 사용

서버의 자원을 사용

용량 제한

한 도메인 당 20, 쿠키 하나 당 4KB, 300

서버가 허용하는 한 용량에 제한이 없음

 

아래 내용은 위의 출처와는 별개로 별도 작성한 사항이다.


세션은 서버 측에 존재하기 때문에 web 서버가 주기적으로 세션의 상태를 확인할 수 있어서 특정 시간동안 web site 내에서 어떠한 이동도 발생하지 않으면 사용자가 나간 것으로 간주하여 세션을 삭제할 수 있다.

기본적으로 24분을 기준으로 하여 세션을 삭제한다.


※ PHP 5.4 부터 session_register 기능이 없어졌다.

<?php

// PHP에서 세션을 사용하려면 세션을 시작해줘야 한다.

// 세션을 시작하지 않은 페이지에서는 세션 값을 사용할 수 없다.

if(!isset($_SESSION)) {
    session_start();
}

if(!function_exists('session_register'))
{
    // PHP 5.4 부터 session_register 가 없어져 만들어진 코드
    // var_dump($_SESSION);
    foreach($_SESSION as $sKey => $sVal)
    {
        if(!isset(${$sKey}))
        {
            ${$sKey} = $sVal;
        }
    }

    function session_register($key)
    {
        $_SESSION[$key] = $GLOBALS[$key];
    }
}

?>


이런 코드도 사용하지 않는게 좋다.

PHP에서 권고하는 $_GET, $_POST, $_REQUEST 배열로 변수를 넘기는 걸 사용하는게 좋다.

그래야 android 연동, C# 과의 연동할 때에도 제대로 연동된다.


index.php 파일에서 코드 작성시에 기본적으로 이런 형태로 구성된다.

세션 값이 존재하면 자동으로 main.php 파일로 이동하고, 세션이 없으면 Login Form 을 띄운다.


if(isset($_SESSION['userID'])){
    echo("<meta http-equiv='Refresh' content='0; URL=main.php'>");
} else {
    include($_SERVER['DOCUMENT_ROOT'].'/loginForm.php');
}


세션 유지 시간 설정값은 php.ini 파일에 있다.

session.cache_expire = 180

로 3분으로 되어 있다. 늘리고 싶으면 값을 조정하고 Apache 를 restart 해야 한다.


[Session]
session.save_handler = files
session.save_path = "/temp"    //세션이 저장될 경로
session.use_cookies = 1          //클라이언트의 쿠키로 세션 아이디를 저장함
session.name = PHPSESSID     //세션아이디를 저장할 쿠키 이름
session.auto_start = 0            // 자동으로 세션을 시작함
session.cookie_lifetime = 0     // 세션아이디를 저장할 쿠키의 폐기시간
session.cookie_path = /         //세션 아이디를 저장할 쿠키 경로
session.cookie_domain =        //세션 아이디를 저장할 쿠키의 도메인


세션을 사용하기 원하는 파일에서 맨 위에 아래와 같이 코드를 추가해준다.

<?php

if(!isset($_SESSION)) {
    session_start();
}

?>

보통은 session_start(); 만 적어주면 되는데 jQuery 를 이용하여 코딩을 하다보면 파일을 include_once, require_once 로 파일을 include 하는 경우가 많다.

이때 세션이 있는 상태에서 또 세션이 들어오면 세션 중복 경고 메시지가 뜬다.

이런 경우를 방지하기 위해서 위와 같이 코드를 적어주는게 좋다.


<?php
// DB 연동후에 가져온 결과값
if(is_array($row)){
    if($row[0]==1){
        if(!isset($_SESSION)) {
            session_start();
        }
        $_SESSION['userID'] = $row['userID'];;
        $_SESSION['userIdx'] = $row['idx'];
    }
}
?>


세션이 동작하지 않을 때

ㅇ 웹브라우저 보안 수준이 높게 설정된 경우

ㅇ 웹브라우저 도구->인터넷옵션->개인정보에서 설정이 모든 쿠키를 차단하는 경우


세션 삭제

<?php
if(!isset($_SESSION)) {
    session_start();
}
session_destroy(); 
?>


session_unset("변수");  // 현재 변수의 값을 삭제하고 변수도 소멸시키는 함수

session_unset($_SESSION['userID']);


-----------------------------------------------------------------------------------------------

<?php
if(!isset($_SESSION)) {
    session_start();
}
$POST['userID']='jsk005@naver.com';
$_SESSION['userID']=$POST['userID'];
$id=$_SESSION['userID'];

if (isset($_SESSION['userID']) && !empty($_SESSION['userID']))
 echo $_SESSION['userID']. "님 반갑습니다.";
else
 echo "SESSION 없다.";
?>


세션 공격 방어


세션 토큰이 생성과는 과정은 위의 그림과 같다.

1. 서버에서 로그인 성공이후 세션 정보를 생성하면 해당 정보를 지정한 디렉토리에 PHPSESSIONID 를 저장한다.

2. 클라이언트는 세션 정보를 브라우저를 통해 COOKIE로 저장해둔다.


세션 쿠키의 값을 알아낼 수 있다면 아이디와 비번 따위는 훔칠 필요도 없다.

세션 쿠키를 사용하면 남의 아이디로 로그인된 상태로 만들 수 있다.

세션 고정 공격은 공격자가 정상적으로 얻을 수 있는 권한보다 높은 권한을 가진 SID를 획득하기 위해 수행하는 공격이므로, 로그인 하는 등 권한이 변경될 때마다 SID를 재생성한다면 무력화시킬 수 있다.

session_regenerate_id();
이 함수는 현재 세션ID를 새로운 세션 ID로 바꿔주는 함수다.
이 함수는 session_save_path 함수에서 절대 경로를 사용해야 한다.
주로 세션 고정 공격을 방지하는 데 도움이 된다.
그럼 언제 사용해야 하는가? 인증(Authentication) 단계(login, logout)가 바뀔 때마다 변경하는게 좋다.

$user = $c->getUser($userID, $password);
if ($user != false) {
    session_regenerate_id();
    $_SESSION['userID'] = $user['userID'];
    $_SESSION['userNM'] = $user['userNM'];
    $_SESSION['access'] = $user['access']; // Authorization (인가) : 특정 리소스에 접근할 수 있는 권한을 부여
}

이렇게 하고 크롬 브라우저 개발자 모드 network 에서 헤더정보를 확인해보면

Cookie: PHPSESSID=h0mf6k6ok9vhitq2v4l605d6d4
Cookie: PHPSESSID=q9or3cl6t8njqui5t28ql3ksi6
로그인/로그아웃 할 때마다 새로운 세션 ID로 변경된 것을 확인할 수 있다.


http/https 혼합 환경에서 세션 보안 강화하기 https://www.phpschool.com/gnuboard4/bbs/board.php?bo_table=tipntech&wr_id=79296 참조


변수에 대한 이해 http://link2me.tistory.com/996 에 isset 과 empty 에 대한 설명이 있다.

'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 날짜 함수 정리  (0) 2015.08.03
[PHP] 설문조사 종료날짜 체크  (0) 2015.05.27
[PHP] 홈페이지 설정 정보 확인  (0) 2015.04.28
PHP 기본 함수  (0) 2015.03.07
[PHP] 한글자르기 substr  (0) 2015.01.04
블로그 이미지

Link2Me

,
728x90

<? phpinfo();?>

홈페이지에 설치된 정보를 보기 위해서는 이 한줄만 있으면 된다.

정보를 알 수 있어 좋지만 노출되면 보안 문제가 발생할 수도 있다.



'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 설문조사 종료날짜 체크  (0) 2015.05.27
[PHP] 쿠키와 세션, 그리고 보안  (0) 2015.05.27
PHP 기본 함수  (0) 2015.03.07
[PHP] 한글자르기 substr  (0) 2015.01.04
IP 체크  (0) 2014.05.18
블로그 이미지

Link2Me

,
728x90

PHP 기본 함수


PHP 함수를 다 열거할 수는 없고 좀 더 자주 봤으면 하는 것만 발췌하여 작성한다.


함수

 설 명

 substr

  • 엑셀에서는 문자열 좌측을 추출할 때 left(string,length) 를 사용하지만
    PHP 에서는 문자열 추출은 substr 함수를 사용한다.

  • substr(string,start,length); 
    주어진 스트링에서 start 부터 length 만큼의 부분 스트링을 리턴한다.
    start는 0 부터 시작하며,
    length 는 생략 가능하다.
  • echo substr("abcdefg",3)."<br />";    // defg 를 리턴 즉, 3번째부터 전부 리턴한다.
    echo substr("abcdefg",1,3)."<br />"; // bcd 를 리턴
    echo substr("abcdefg",-3)."<br />";    // efg 를 리턴. 즉, 뒤에서부터 3개를 리턴한다.
    echo substr("abcdefg",-1)."<br />";    // g 만 리턴. 즉, 뒤에서부터 1개만 리턴한다.
    echo substr("abcdefg",-3,1)."<br />"; // e만 리턴. 즉, 뒤에서부터 3번째만 리턴한다.
  • <?php
    $tel = "010-9999-0001";
    echo "전화번호는 ". $tel;
    echo "<br />";
    $phone_type = 1;
    if(substr($tel,0,3) == '070') $phone_type = 2;
    if(substr($tel,0,2) == '01') $phone_type = 3;
    echo "전화타입은 ". $phone_type;
    ?>

 chop

  • 스트링의 뒤쪽 공백을 없애준다.
  • $trimmed = chop($line);

 chr

  • 지정된 아스키 문자를 리턴해준다
  • $str .= chr(27);  // ESC 문자를 해당 스트링에 붙여준다.

 flush

  • PHP에서 사용하는 출력 버퍼를 비운다. 이것은 Web 브라우저로 가는 데이터를 빨리 보낼 수 있는 장점이 있다.
  • flush();   // output 버퍼에 있던 데이터를 모두 비운다.

 strcmp

  • 두 개의 스트링을 비교해 준다.
    두개의 스트링이 같은 경우에는 0이 리턴된다.
  • $result = strcmp($str1, $str2);
    if ($result == 0) {
        echo "두 문자열은 서로 동일";
    }

 strlen

  • 해당 스트링의 길이를 알려 준다.
  • $length = strlen ($str);
    echo $length ;

 strchr

  •  스트링에서 해당 문자의 마지막 위치를 파악해서 그 뒷부분을 리턴해준다.

strstr

  •  스트링에서 해당 문자의 첫 번째 위치를 파악해서 그 뒷부분을 리턴해준다.

 str_replace

  •  주어진 스트링에서 단어들을 바꾸어 준다.

 count

  • 주로 배열 요소들의 개수를 파악할 때 사용한다.
  • $num = count($result);

 array_push

  • 해당 배열에 값을 추가적으로 넣을 수 있게 한다.
  • $stack = array("orange""banana");
    array_push($stack"apple""raspberry");
    print_r($stack);
    결과는 Array ( [0] => orange [1] => banana [2] => apple [3] => raspberry )
  • $multisqlque = array();
    for($i=0; $i < count($stack); $i++)
    {
        array_push($multisqlque, "subject LIKE '%".$stack[$i]."%'" );
    }
    if(count($multisqlque) > 0) {
        $sqlque .= " ( ";
        $sqlque .= join(" or ", $multisqlque);
        $sqlque .= " ) ";
    }
    echo $sqlque; // 쿼리문이 정상인지 확인
    결과는 ( subject LIKE '%orange%' or subject LIKE '%banana%' or subject LIKE '%apple%' or subject LIKE '%raspberry%' )

 in_array

  • 배열내에 해당 값이 있는지 없는지 알려준다.
    배열에 값이 있으면 true 인 1 을 리턴해주고, 없으면 false 를 리턴
  • if(in_array("apple",$stack)) {
        echo "배열이 존재";
    }
    else {
        echo " 배열이 없어요";
    }

 next

  • 배열의 내부 포인터를 하나 증가시키면서 그 값을 리턴한다

 prev

  • 배열의 내부 포인터를 하나 감소시키면서 그 값을 리턴한다.

 reset

  • 배열의 포인터를 맨 처음으로 옮긴다.

 basename

  • PATH 에 붙어있는 파일 이름을 가져온다.
  • echo basename("/home/httpd/html/index.php"); // index.php 를 출력해준다.
  • echo dirname("/home/httpd/html/index.php");  // /home/httpd/html 를 출력해준다.

ereg_replace

  • 주어진 스트링에서 특정 패턴을 찾아서 다른 것으로 대처한다.
  • $string = "This is a test";
    echo ereg_replace ("is", "was", $string);
    // This was a test 를 출력한다.


'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 쿠키와 세션, 그리고 보안  (0) 2015.05.27
[PHP] 홈페이지 설정 정보 확인  (0) 2015.04.28
[PHP] 한글자르기 substr  (0) 2015.01.04
IP 체크  (0) 2014.05.18
GET, POST 변수전달  (0) 2014.05.15
블로그 이미지

Link2Me

,
728x90

완성형 한글의 경우 한글은 2바이트로 영어는 1바이트로 구성되기 때문에 PHP의 substr() 함수를 쓸 때 한글이 깨지는 경우가 있다. 이런 경우 mb_substr() 함수로 대체하면 된다.


substr ($str, $start_Pos, $length);
$Str에 담고 있는 문자열의 $start_Pos부터 길이$length만큼을 잘라내어 반환한다

mb_substr ($str, $start_Pos, $length, $encoding);
$str에 담고 있는 문자열의 $start_Pos부터 길이$length만큼을 잘라내어 $encoding 형식에 맞게 반환한다


mb_substr($str, 0, 10, 'EUC-KR');
mb_substr($str, 0, 10, 'UTF-8');

function strcut_euckr($msg, $limit) {    // 완성형 한글 자르기
    $msg = substr($msg, 0, $limit);
    for ($i = $limit - 1; $i > 1; $i--) {   
        if (ord(substr($msg,$i,1)) < 128) break;
    }
    $msg = substr($msg, 0, $limit - ($limit - $i + 1) % 2);
    return $msg;
}


function strcut_utf8($str, $len, $checkmb=false, $tail='') {  // UTF-8 한글자르기
    /** UTF-8 Format
    * 0xxxxxxx = ASCII, 110xxxxx 10xxxxxx or 1110xxxx 10xxxxxx 10xxxxxx
    * latin, greek, cyrillic, coptic, armenian, hebrew, arab characters consist of 2bytes
    * BMP(Basic Mulitilingual Plane) including Hangul, Japanese consist of 3bytes
    **/
    preg_match_all('/[\xE0-\xFF][\x80-\xFF]{2}|./', $str, $match); // target for BMP
     
    $m = $match[0];
    $slen = strlen($str); // length of source string
    $tlen = strlen($tail); // length of tail string
    $mlen = count($m); // length of matched characters
     
    if ($slen <= $len) return $str;
    if (!$checkmb && $mlen <= $len) return $str;
     
    $ret = array();
    $count = 0;
    for ($i=0; $i < $len; $i++) {
        $count += ($checkmb && strlen($m[$i]) > 1)?2:1;
        if ($count + $tlen > $len) break;
        $ret[] = $m[$i];
    }    
    return join('', $ret).$tail;
}


※ 문자열의 '바이트 수'를 확인하려면 strlen() 함수를, '문자 수'를 조사하려면 mb_strlen() 함수를 사용해야 한다.

영문이나 숫자 등의 싱글 바이트 문자로 구성된 문자열에서는 strlen() 함수와 mb_strlen() 함수의 결과는 같다.

하지만, 멀티바이트 문자를 포함하는 문자열(한국어, 일본어, 중국어 등)에서는 결과가 다르다.



'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 쿠키와 세션, 그리고 보안  (0) 2015.05.27
[PHP] 홈페이지 설정 정보 확인  (0) 2015.04.28
PHP 기본 함수  (0) 2015.03.07
IP 체크  (0) 2014.05.18
GET, POST 변수전달  (0) 2014.05.15
블로그 이미지

Link2Me

,
728x90

접속 IP 검사


<?php
$UserIP = $REMOTE_ADDR;

$ip_extract = explode(".",$UserIP);  //.로 분리해서 배열로 저장
$UserIP_trim = $ip_extract[0].".".$ip_extract[1].".".$ip_extract[2];

$IP_block1 = '192.168.1';

if($UserIP_trim != $IP_block1) {
   echo "<script> window.alert('허용IP대역 아님'); history.back();</script>";

   //echo ("<meta http-equiv='Refresh' content='0; URL=/'>");  // 홈으로 이동시킴
}
?>


IP검사를 하고 검사조건과 틀리면 history.go(-1) 뒤로 이동하거나 홈으로 이동 등 원하는 조건으로 분기시킬 때 유용하게 사용할 수 있다.


'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 쿠키와 세션, 그리고 보안  (0) 2015.05.27
[PHP] 홈페이지 설정 정보 확인  (0) 2015.04.28
PHP 기본 함수  (0) 2015.03.07
[PHP] 한글자르기 substr  (0) 2015.01.04
GET, POST 변수전달  (0) 2014.05.15
블로그 이미지

Link2Me

,
728x90

PHP 변수전달 GET, POST



$_POST$_GET 같은 슈퍼 전역 배열은 PHP 4.1.0 이후버전부터 사용되기 시작했다.

$_REQUEST 는 $_GET 배열과 $_POST 배열 둘다 처리할 수 있다.


수퍼 전역변수

$_COOKIE    HTTP 쿠키 변수
$_FILES      업로드시 파일 정보 변수
$_SESSION  세션 변수
$_SERVER   웹서버와 PHP 환경에서의 환경 설정 변수


전역변수 : 모든 함수와 어느 영역이든 사용 가능한 변수


GET

같은 페이지가 아닌 다른페이지에서 값을 넘겨 받을때 사용되어지는 방식

직접 url에 ? 로 붙여서 전달하는 방법

웹브라우저의 URL에는 같이 넘어갈수 있는 글자수에 한계(255자)가 있다.


GET 방식의 장점 : 속도가 빠르다!

GET 방식의 단점
정보가 노출되므로 보안 취약하다.
보내는 정보의 크기가 1024바이트로 제한된다.

기본적으로 데이터베이스에 대한 질의어 데이터와 같은 요청 자체를 위한 정보를 전송할 때 사용

GET 방식을 사용하면 이를 초과하는 데이터가 절단되므로, 일정한 크기 이상의 데이터를 전송할 때에는 POST 방식을 사용


POST

폼을 통해 입력받은 값을 전달하는 방법

POST 방식은 GET 방식과 달리 정보를 첨부파일 형태로 전달하기 때문에 보안성이 GET 방식에 비해 좋으며, 보내는 정보의 크기에 제한이 없다.


POST 방식의 단점 : 속도가 GET방식보다 느리다고 하는데 차이가 없다. 보안상 POST 방식을 사용하는게 좋다.


php 파일(Page)에서 다른 파일(Page)로 변수를 전달할 때 $_GET 배열이나 $_POST 배열로 넘긴다.

받아들이는 쪽에서 둘다 받아들이게 하려면 $_REQUEST 배열로 받는다.


$_GET['변수명']

$_POST['변수명'];    // 변수명 예를 들면 username
$_POST['$변수명'] --> $변수명

으로 받을수 있는건 php.ini 에서 register_globals=On 인 상태에서만 작동한다.

보안 강화 목적으로 PHP 버전이 높아지면서 보안 강화를 목적으로 register_globals 는 삭제되었다.

PHP 5.4 부터 session_register 기능이 없어졌다.


register_globals = on
  가능 -> $_POST['user_name']
  가능 -> $user_name
register_globals = off
  가능 -> $_POST['user_name']
  불가능 -> $user_name  // 단, extract($_POST) 추가시 가능


extract($_POST); 를 한줄 상단에 추가해주면 $_POST['$변수명'] 대신에 $변수명 을 사용할 수 있다.

단 보안을 고려하여 

if(isset($_POST) && $_SERVER['REQUEST_METHOD'] == "POST"){

@extract($_POST); // $_POST['loginID'] 라고 쓰지 않고, $loginID 라고 써도 인식되게 함

}

와 같이 해주는 것이 바람직하다.


먼저, 다음과 같이 텍스트 입력 박스가 들어간 간단한 HTML 코드를  보자.

HTML 에서 page 간에 값을 넘기는 방식이 GET방식과 POST 방식이 있다.

아래 코드는 POST 방식으로 값을 넘기는 예제이다.


method="post" 를 지정하지 않으면 GET방식으로 데이터를 전달한다.


=== registerform.html ===
<form method = "post" action = "register.php">
  나이? <input type = "text" name = "age">
  <input type = "submit" value = "확인">
</form>


 속성

설명

 name

 폼의 이름

 method

 폼 정보 전달방식(GET 또는 POST)

 enctype

 폼 데이터의 인코딩 타입(POST 전송만 해당)

 action

 폼의 정보가 전달될 주소


HTML에서 method="value" 와 같이 value가 숫자가 아닐 경우에는 quote를 해 주는 것이 좋다.
그리고 HTML quote시에는 single quote보다 double qoute가 렌더링 시에 더 빠르다.

password와 같은 정보는 GET 보다는 POST로 넘겨야 안전하다.

input type을 hidden으로 해주면 화면상에는 몇개 안보이지만 실제로는 많은 변수를 넘겨줄 수 있다.

<input type="hidden" name="num" value="<?php echo $_GET['num']; ?>">


위 코드를 웹 브라우저로 확인하면 입력 박스 한 개와 확인 버튼이 나오게 된다.
그리고, 그 입력 박스에 사용자가 "30" 이라고 입력하고 확인 버튼을 누르게 되면 입력된 문자열은 위 코드에 기술되어 있듯이 text 양식의 name 에 해당되는 "age" 에 담겨져 action 에 명시된 "register.php" 로 넘겨진다.

다음으로 register.php 웹 페이지가 호출되면 registerform.html 에 기술된 텍스트 박스의 name 에 해당되는 "age" 라는 이름을 갖는 변수 즉, $age 변수 형태(
$_POST['age'])로 전달이 되어진다.

이 때, $age 변수에는 사용자가 registerform.html 웹 페이지에서 입력한 "30" 이라는 문자열이 담겨져 있다.
그럼 실제로 register.php 에 다음과 같은 코드를 작성해서 확인한다.

===
register.php ===
<?php
$age = $_POST['age'];
echo "당신의 나이는 : $age";
?>

결과로 당신이 나이는 : 30
위와 같이 php 에서는 이전 입력 페이지의 폼(form)에 입력된 값을 구하기 위해서는 $_POST['폼 텍스트 박스명'] 형태로 기술해주면 된다.



<form method = "post" action = <?=$PHP_SELF?> >
폼에 임의의 값을 입력받아 자신의 파일($PHP_SELF)로 그 정보를 넘기는 PHP, 즉 자신을 다시 호출함

자신의 파일을 다시 호출하지만, 변수 인식은 $_POST 배열로 받아서 처리한다.

아래 예제에서 $_POST 배열, $_GET 배열일 때 받는 변수에 따라 각각 처리하는 걸 확인할 수 있다.

<?php
if (!isset($_SESSION)) {
    session_start();
}
require('../connection.php');
if(isset($_SESSION['admin']) && $_SESSION['admin']!=1){
   header("location:access-denied.php");
}

$sql ="SELECT * FROM positions";
$result=mysqli_query($dbconn,$sql);
if (mysqli_num_rows($result)<1){
    $result = null;
}

// inserting sql query
if (isset($_POST['Submit'])){
    $newPosition = addslashes( $_POST['position'] ); //prevents types of SQL injection
    $sql = "INSERT INTO positions(position_name) VALUES ('$newPosition')";
    mysqli_query($dbconn,$sql);
    header("Location: positions.php");
}

if (isset($_POST['Update'])){
    $idx = $_POST['idx'];
    $newPosition = addslashes( $_POST['position'] ); //prevents types of SQL injection
    $sql ="Update positions SET position_name='$newPosition' where idx=$idx";
    mysqli_query($dbconn,$sql);
     header("Location: positions.php");
}

// deleting sql query
if (isset($_GET['id']) && isset($_GET['mode']) && $_GET['mode']=='delete') {
 $id = $_GET['id'];
 $sql = "DELETE FROM positions WHERE idx='".$id."'";
 $result = mysqli_query($dbconn,$sql);
 header("Location: positions.php");
}
?>


<!DOCTYPE html>
<html>
<head>
<title>온라인 투표</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<link href="layout/styles/layout.css" rel="stylesheet" type="text/css" media="all">
<script language="JavaScript" src="js/user.js">
</script>
</head>
<body id="top">

<?php require_once ('header.php');?>
<div >
    <table width="380" align="center">
    <CAPTION><h4>후보자 분류
    <?php if(isset($_GET['mode']) && $_GET['mode']=='update'){
            echo '수정';
            require_once '../phpclass/dbClass.php';
            $c = new MySQLiDbClass;
            $R = $c -> getDbData('positions', 'idx='.$_GET['id'], '*');
    }else{
        echo '추가';
    }
    ?></h4></CAPTION>
    <form name="fmPositions" id="fmPositions" action="positions.php" method="post" onsubmit="return positionValidate(this)">
        <?php if(isset($_GET['mode']) && $_GET['mode']=='update'):?>
        <input type="hidden" name="idx" value="<?php echo $R['idx'];?>" />
        <?php endif;?>
    <tr>
        <td bgcolor="#00ff80">분류</td>
        <td bgcolor="#808080"><input type="text" name="position" value="<?php echo isset($_GET['mode']) && $_GET['mode']=='update' ? $R['position_name']:'';?>" /></td>
        <?php if(isset($_GET['mode']) && $_GET['mode']=='update'):?>
        <td bgcolor="#00FF00"><input type="submit" name="Update" value="수정" /></td>
        <?php else:?>
        <td bgcolor="#00FF00"><input type="submit" name="Submit" value="추가" /></td>
        <?php endif;?>
    </tr>
    </table>

    <table border="0" width="420" align="center">
        <CAPTION><h4>분류 현황</h4></CAPTION>
        <tr>
        <th>ID</th>
        <th>분류</th>
        <th>수정</th>
        <th>삭제</th>
        </tr>

        <?php
            while ($row=mysqli_fetch_array($result)){
                echo "<tr>";
                echo "<td>" . $row['idx']."</td>";
                echo "<td>" . $row['position_name']."</td>";
                echo '<td><a href="positions.php?id='. $row['idx'].'&mode=update">수정</a></td>';
                echo '<td><a href="positions.php?id='. $row['idx'].'&mode=delete">삭제</a></td>';
                echo "</tr>";
            }
            mysqli_free_result($result);
        ?>

    </table>
    <hr>
</div>

<?php require_once ('../layout/tail.php');?>

<a id="backtotop" href="#top"><i class="fa fa-chevron-up"></i></a>
<!-- JAVASCRIPTS -->
<script src="layout/scripts/jquery.min.js"></script>
<script src="layout/scripts/jquery.backtotop.js"></script>
<script src="layout/scripts/jquery.mobilemenu.js"></script>
<!-- IE9 Placeholder Support -->
<script src="layout/scripts/jquery.placeholder.min.js"></script>
<!-- / IE9 Placeholder Support -->
</body>
</html>


위와 같이 하나의 파일에서 두개의 파일(Form 전송파일: 파일 A, Action 처리 파일 : 파일 B)의 역할을 동시에 하는 것은 바람직한 코딩은 아니다.

그냥 이렇게 코딩하는 것도 있더라 라고 알아두면 좋을 거 같다.

'Web 프로그램 > PHP 응용 및 활용' 카테고리의 다른 글

[PHP] 쿠키와 세션, 그리고 보안  (0) 2015.05.27
[PHP] 홈페이지 설정 정보 확인  (0) 2015.04.28
PHP 기본 함수  (0) 2015.03.07
[PHP] 한글자르기 substr  (0) 2015.01.04
IP 체크  (0) 2014.05.18
블로그 이미지

Link2Me

,