<사전지식>
php가 실제적으로 여러가지 에러관련 문구를 출력하지 않더라도
내부적으로는 모두 처리하므로, notice에러 나는 것 역시 나지 않도록 하는것이
좋습니다.
즉, 보이진 않더라도 에러가 안나는 것은 아니라는 말입니다.
제가 ! 대신 empty를 선호하는 이유도 거기에 있습니다.
! 은 변수가 정의되었다는 전제하에서 값이 참거짓을 판가름하여 거짓값을 가지면(0, '0', '', false)
참이라고 리턴해줍니다. 그러나 php내부적으로는 변수가 정의되지 않은 상태에서 ! 를 사용하게
되면 그런 변수가 정의되지 않았다는 notice 에러를 냅니다.
empty 는 변수가 정의되지 않았거나, 값이 0, '0', '', false 일때 모두 참을 리턴해줍니다.
즉 변수가 정의되지 않은 상태에서 empty 를 사용하더라도 내부적으로 notice 에러가 나지 않는다는
것이죠.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/empty.php
<소스>
<?php
@error_reporting(E_ERROR | E_WARNING | E_PARSE);
//짧은 환경변수 와 register_globals on, magic_quotes_gpc on 상태로 만든다.
//php버전이 4.1.0 미만일경우 기존변수를 새변수에 덮는다.
$phpversion = (float)@phpversion();
if ($phpversion < 4.1) $phpversion_check = 0;
else $phpversion_check = 1;
//짧은 환경 변수 정의
if ($phpversion_check == 0){
$_GET = $GLOBALS['_GET'] = (!empty($HTTP_GET_VARS) && is_array($HTTP_GET_VARS)) ? $HTTP_GET_VARS : Array();
$_POST = $GLOBALS['_POST'] = (!empty($HTTP_POST_VARS) && is_array($HTTP_POST_VARS)) ? $HTTP_POST_VARS : Array();
$_FILES = $GLOBALS['_FILES'] = (!empty($HTTP_FILES_VARS) && is_array($HTTP_FILES_VARS)) ? $HTTP_FILES_VARS : Array();
$_SERVER = $GLOBALS['_SERVER'] = (!empty($HTTP_SERVER_VARS) && is_array($HTTP_SERVER_VARS)) ? $HTTP_SERVER_VARS : Array();
$_ENV = $GLOBALS['_ENV'] = (!empty($HTTP_ENV_VARS) && is_array($HTTP_ENV_VARS)) ? $HTTP_ENV_VARS : Array();
$_COOKIE = $GLOBALS['_COOKIE'] = (!empty($HTTP_COOKIE_VARS) && is_array($HTTP_COOKIE_VARS)) ? $HTTP_COOKIE_VARS : Array();
$_SESSION = $GLOBALS['_SESSION'] = (!empty($HTTP_SESSION_VARS) && is_array($HTTP_SESSION_VARS)) ? $HTTP_SESSION_VARS : Array();
}
$magic_quotes_gpc = @get_magic_quotes_gpc;// @ini_get('magic_quotes_gpc'); 보다 이전 버전에서 지원하므로 @get_magic_quotes_gpc;사용
if (empty($magic_quotes_gpc)) {
$_POST = Yarray_addslashes($_POST);
$_GET = Yarray_addslashes($_GET);
$_COOKIE = Yarray_addslashes($_COOKIE);
}
$register_globals = @ini_get('register_globals');
if (empty($register_globals)) {
//우선 순위대로 변수 덮음
@extract($_GET, EXTR_OVERWRITE);
@extract($_POST, EXTR_OVERWRITE);
@extract($_COOKIE, EXTR_OVERWRITE);
@extract($_ENV, EXTR_OVERWRITE);
@extract($_SERVER, EXTR_OVERWRITE);
}
//배열 addslashes, 배열안의 배열도 모두 처리, 재귀호출 함수
function Yarray_addslashes($array){
if (is_array($array)){
foreach($array as $key => $value){
if (is_array($value)){
$array[$key] = Yarray_addslashes($value);
}
else {
$array[$key] = addslashes($value);
}
}
}
return $array;
}
?>
소스링크 : http://82da.com/Ybbs/sample/phpversion.phps<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
php가 실제적으로 여러가지 에러관련 문구를 출력하지 않더라도
내부적으로는 모두 처리하므로, notice에러 나는 것 역시 나지 않도록 하는것이
좋습니다.
즉, 보이진 않더라도 에러가 안나는 것은 아니라는 말입니다.
제가 ! 대신 empty를 선호하는 이유도 거기에 있습니다.
! 은 변수가 정의되었다는 전제하에서 값이 참거짓을 판가름하여 거짓값을 가지면(0, '0', '', false)
참이라고 리턴해줍니다. 그러나 php내부적으로는 변수가 정의되지 않은 상태에서 ! 를 사용하게
되면 그런 변수가 정의되지 않았다는 notice 에러를 냅니다.
empty 는 변수가 정의되지 않았거나, 값이 0, '0', '', false 일때 모두 참을 리턴해줍니다.
즉 변수가 정의되지 않은 상태에서 empty 를 사용하더라도 내부적으로 notice 에러가 나지 않는다는
것이죠.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/empty.php
<소스>
<?php
@error_reporting(E_ERROR | E_WARNING | E_PARSE);
//짧은 환경변수 와 register_globals on, magic_quotes_gpc on 상태로 만든다.
//php버전이 4.1.0 미만일경우 기존변수를 새변수에 덮는다.
$phpversion = (float)@phpversion();
if ($phpversion < 4.1) $phpversion_check = 0;
else $phpversion_check = 1;
//짧은 환경 변수 정의
if ($phpversion_check == 0){
$_GET = $GLOBALS['_GET'] = (!empty($HTTP_GET_VARS) && is_array($HTTP_GET_VARS)) ? $HTTP_GET_VARS : Array();
$_POST = $GLOBALS['_POST'] = (!empty($HTTP_POST_VARS) && is_array($HTTP_POST_VARS)) ? $HTTP_POST_VARS : Array();
$_FILES = $GLOBALS['_FILES'] = (!empty($HTTP_FILES_VARS) && is_array($HTTP_FILES_VARS)) ? $HTTP_FILES_VARS : Array();
$_SERVER = $GLOBALS['_SERVER'] = (!empty($HTTP_SERVER_VARS) && is_array($HTTP_SERVER_VARS)) ? $HTTP_SERVER_VARS : Array();
$_ENV = $GLOBALS['_ENV'] = (!empty($HTTP_ENV_VARS) && is_array($HTTP_ENV_VARS)) ? $HTTP_ENV_VARS : Array();
$_COOKIE = $GLOBALS['_COOKIE'] = (!empty($HTTP_COOKIE_VARS) && is_array($HTTP_COOKIE_VARS)) ? $HTTP_COOKIE_VARS : Array();
$_SESSION = $GLOBALS['_SESSION'] = (!empty($HTTP_SESSION_VARS) && is_array($HTTP_SESSION_VARS)) ? $HTTP_SESSION_VARS : Array();
}
$magic_quotes_gpc = @get_magic_quotes_gpc;// @ini_get('magic_quotes_gpc'); 보다 이전 버전에서 지원하므로 @get_magic_quotes_gpc;사용
if (empty($magic_quotes_gpc)) {
$_POST = Yarray_addslashes($_POST);
$_GET = Yarray_addslashes($_GET);
$_COOKIE = Yarray_addslashes($_COOKIE);
}
$register_globals = @ini_get('register_globals');
if (empty($register_globals)) {
//우선 순위대로 변수 덮음
@extract($_GET, EXTR_OVERWRITE);
@extract($_POST, EXTR_OVERWRITE);
@extract($_COOKIE, EXTR_OVERWRITE);
@extract($_ENV, EXTR_OVERWRITE);
@extract($_SERVER, EXTR_OVERWRITE);
}
//배열 addslashes, 배열안의 배열도 모두 처리, 재귀호출 함수
function Yarray_addslashes($array){
if (is_array($array)){
foreach($array as $key => $value){
if (is_array($value)){
$array[$key] = Yarray_addslashes($value);
}
else {
$array[$key] = addslashes($value);
}
}
}
return $array;
}
?>
소스링크 : http://82da.com/Ybbs/sample/phpversion.phps<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
댓글 7개
19년 전
[사전지식2]
다음과 같은 경우에도 notice에러를 출력합니다.
배열 사용시 배열의 키값이 문자형 인데도 불구 하고 ' 나 " 를 사용하지 않으면
notice 에러를 냅니다.
예를 들어 $_SERVER[PHP_SELF] 이런식으로 사용할 경우
php는 PHP_SELF 라는 상수를 먼저 찾게 됩니다.
해당 상수가 정의 되어있지 않으면 notice 에러를 출력합니다.
그런연후에 PHP_SELF 라는 문자열로 인식하고 처리하게 됩니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/arraykey.php
다음과 같은 경우에도 notice에러를 출력합니다.
배열 사용시 배열의 키값이 문자형 인데도 불구 하고 ' 나 " 를 사용하지 않으면
notice 에러를 냅니다.
예를 들어 $_SERVER[PHP_SELF] 이런식으로 사용할 경우
php는 PHP_SELF 라는 상수를 먼저 찾게 됩니다.
해당 상수가 정의 되어있지 않으면 notice 에러를 출력합니다.
그런연후에 PHP_SELF 라는 문자열로 인식하고 처리하게 됩니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/arraykey.php
19년 전
[사전지식3]
문자열 표현시 ' 와 " 의 차이
쉽게 한마디로 표현하면 ' 는 문자열 그대로를 출력하고,
" 은 문자열에 포함된 변수, \로 시작된 정의된 특수문자(개행문자, 탭, 등등)을 모두 인식합니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/quotes.php
문자열 표현시 ' 와 " 의 차이
쉽게 한마디로 표현하면 ' 는 문자열 그대로를 출력하고,
" 은 문자열에 포함된 변수, \로 시작된 정의된 특수문자(개행문자, 탭, 등등)을 모두 인식합니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/quotes.php
19년 전
[사전지식4]
다음과 같은 형태를 지닌것을 삼항 연산자라 합니다
(조건문) ? 처리1 : 처리2
이것은 다음과 같이 처리됩니다.
괄호안의 조건문이 참일 경우 ? 뒤의 : 앞에 까지 처리1의 결과를 리턴해줍니다.
반대로 조건문이 거짓일 경우 : 뒤부터 끝까지 처리2의 결과를 리턴해줍니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/3hang.php
다음과 같은 형태를 지닌것을 삼항 연산자라 합니다
(조건문) ? 처리1 : 처리2
이것은 다음과 같이 처리됩니다.
괄호안의 조건문이 참일 경우 ? 뒤의 : 앞에 까지 처리1의 결과를 리턴해줍니다.
반대로 조건문이 거짓일 경우 : 뒤부터 끝까지 처리2의 결과를 리턴해줍니다.
다음 링크를 참고하시기 바랍니다.
참고링크 : http://82da.com/Ybbs/sample/3hang.php
Photofly
19년 전
유용한 팁 감사합니다....^^
mando
19년 전
좋은 글 감사합니다.
그래서 게시판 명을 empty로 하고 최신글에서 게시판명을 empty로하면 에러가 났었군요^^
그래서 게시판 명을 empty로 하고 최신글에서 게시판명을 empty로하면 에러가 났었군요^^
alfresco
19년 전
$magic_quotes_gpc = @get_magic_quotes_gpc;
여기서 뒤에 () 넣어줘야하지 않을지요~
여기서 뒤에 () 넣어줘야하지 않을지요~
19년 전
네 맞습니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 7130 | 11년 전 | 2304 | ||
| 7129 | 11년 전 | 710 | ||
| 7128 |
senseme
|
11년 전 | 1298 | |
| 7127 | 11년 전 | 1169 | ||
| 7126 | 11년 전 | 822 | ||
| 7125 | 11년 전 | 2949 | ||
| 7124 | 11년 전 | 1425 | ||
| 7123 |
잘살아보자
|
11년 전 | 1291 | |
| 7122 |
잘살아보자
|
11년 전 | 689 | |
| 7121 |
잘살아보자
|
11년 전 | 3050 | |
| 7120 |
잘살아보자
|
11년 전 | 2916 | |
| 7119 |
잘살아보자
|
11년 전 | 731 | |
| 7118 |
잘살아보자
|
11년 전 | 3432 | |
| 7117 |
잘살아보자
|
11년 전 | 850 | |
| 7116 | 11년 전 | 744 | ||
| 7115 | 11년 전 | 1031 | ||
| 7114 | 11년 전 | 850 | ||
| 7113 | 11년 전 | 663 | ||
| 7112 | 11년 전 | 1086 | ||
| 7111 | 11년 전 | 1800 | ||
| 7110 | 11년 전 | 1035 | ||
| 7109 |
버섯먹은나
|
11년 전 | 810 | |
| 7108 | 11년 전 | 646 | ||
| 7107 | 11년 전 | 2409 | ||
| 7106 | 11년 전 | 1960 | ||
| 7105 | 11년 전 | 2484 | ||
| 7104 | 11년 전 | 1425 | ||
| 7103 |
|
11년 전 | 2708 | |
| 7102 | 11년 전 | 3118 | ||
| 7101 | 11년 전 | 4446 | ||
| 7100 | 11년 전 | 5794 | ||
| 7099 | 11년 전 | 2140 | ||
| 7098 | 11년 전 | 1723 | ||
| 7097 | 11년 전 | 1459 | ||
| 7096 | 11년 전 | 1128 | ||
| 7095 |
잘살아보자
|
11년 전 | 858 | |
| 7094 |
잘살아보자
|
11년 전 | 1062 | |
| 7093 |
잘살아보자
|
11년 전 | 939 | |
| 7092 |
잘살아보자
|
11년 전 | 1410 | |
| 7091 |
잘살아보자
|
11년 전 | 2212 | |
| 7090 |
잘살아보자
|
11년 전 | 894 | |
| 7089 | 11년 전 | 1066 | ||
| 7088 | 11년 전 | 1714 | ||
| 7087 | 11년 전 | 1411 | ||
| 7086 | 11년 전 | 1311 | ||
| 7085 |
|
11년 전 | 1236 | |
| 7084 | 11년 전 | 1155 | ||
| 7083 | 11년 전 | 3504 | ||
| 7082 | 11년 전 | 1152 | ||
| 7081 | 11년 전 | 1738 | ||
| 7080 | 11년 전 | 2023 | ||
| 7079 | 11년 전 | 1332 | ||
| 7078 | 11년 전 | 1305 | ||
| 7077 | 11년 전 | 1311 | ||
| 7076 | 11년 전 | 769 | ||
| 7075 | 11년 전 | 1154 | ||
| 7074 |
네이비칼라
|
11년 전 | 1509 | |
| 7073 | 11년 전 | 1478 | ||
| 7072 |
|
11년 전 | 836 | |
| 7071 | 11년 전 | 1210 | ||
| 7070 | 11년 전 | 935 | ||
| 7069 | 11년 전 | 1707 | ||
| 7068 | 11년 전 | 1361 | ||
| 7067 |
TPSint
|
11년 전 | 747 | |
| 7066 | 11년 전 | 2152 | ||
| 7065 | 11년 전 | 6651 | ||
| 7064 | 11년 전 | 1294 | ||
| 7063 | 11년 전 | 1140 | ||
| 7062 | 11년 전 | 1078 | ||
| 7061 | 11년 전 | 917 | ||
| 7060 | 11년 전 | 1473 | ||
| 7059 | 11년 전 | 883 | ||
| 7058 |
EngineMan
|
11년 전 | 3407 | |
| 7057 | 11년 전 | 1248 | ||
| 7056 | 11년 전 | 1638 | ||
| 7055 | 11년 전 | 1020 | ||
| 7054 | 11년 전 | 2657 | ||
| 7053 |
네이비칼라
|
11년 전 | 1289 | |
| 7052 | 11년 전 | 2582 | ||
| 7051 | 11년 전 | 1941 | ||
| 7050 | 11년 전 | 2456 | ||
| 7049 | 11년 전 | 1411 | ||
| 7048 | 11년 전 | 2538 | ||
| 7047 | 11년 전 | 1360 | ||
| 7046 | 11년 전 | 1041 | ||
| 7045 | 11년 전 | 1068 | ||
| 7044 | 11년 전 | 5438 | ||
| 7043 | 11년 전 | 1234 | ||
| 7042 | 11년 전 | 792 | ||
| 7041 |
열라뽕똬이
|
11년 전 | 762 | |
| 7040 | 11년 전 | 1118 | ||
| 7039 | 11년 전 | 1465 | ||
| 7038 | 11년 전 | 1879 | ||
| 7037 | 11년 전 | 2182 | ||
| 7036 | 11년 전 | 1089 | ||
| 7035 | 11년 전 | 1409 | ||
| 7034 | 11년 전 | 1358 | ||
| 7033 |
열라뽕똬이
|
11년 전 | 1000 | |
| 7032 | 11년 전 | 754 | ||
| 7031 | 11년 전 | 2187 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기