<사전지식>
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년 전
네 맞습니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 1030 | 18년 전 | 1775 | ||
| 1029 | 18년 전 | 2209 | ||
| 1028 | 18년 전 | 2624 | ||
| 1027 | 18년 전 | 1783 | ||
| 1026 | 18년 전 | 1513 | ||
| 1025 | 18년 전 | 1530 | ||
| 1024 | 18년 전 | 1457 | ||
| 1023 | 18년 전 | 3218 | ||
| 1022 | 18년 전 | 2909 | ||
| 1021 | 18년 전 | 1664 | ||
| 1020 | 18년 전 | 3405 | ||
| 1019 | 18년 전 | 1833 | ||
| 1018 | 18년 전 | 1483 | ||
| 1017 | 18년 전 | 1944 | ||
| 1016 | 18년 전 | 2090 | ||
| 1015 | 18년 전 | 1623 | ||
| 1014 | 18년 전 | 2336 | ||
| 1013 | 18년 전 | 1994 | ||
| 1012 | 18년 전 | 1602 | ||
| 1011 | 18년 전 | 1780 | ||
| 1010 | 18년 전 | 2034 | ||
| 1009 | 18년 전 | 1792 | ||
| 1008 | 18년 전 | 1593 | ||
| 1007 | 18년 전 | 1652 | ||
| 1006 | 18년 전 | 3123 | ||
| 1005 | 18년 전 | 1986 | ||
| 1004 | 18년 전 | 1860 | ||
| 1003 | 18년 전 | 4364 | ||
| 1002 | 18년 전 | 4990 | ||
| 1001 | 18년 전 | 3155 | ||
| 1000 | 18년 전 | 2901 | ||
| 999 | 18년 전 | 3494 | ||
| 998 | 18년 전 | 2036 | ||
| 997 | 18년 전 | 2383 | ||
| 996 | 18년 전 | 2680 | ||
| 995 | 18년 전 | 2750 | ||
| 994 | 18년 전 | 2345 | ||
| 993 | 18년 전 | 1607 | ||
| 992 | 18년 전 | 3372 | ||
| 991 | 18년 전 | 1971 | ||
| 990 | 18년 전 | 2376 | ||
| 989 | 18년 전 | 2448 | ||
| 988 | 18년 전 | 2875 | ||
| 987 | 18년 전 | 5209 | ||
| 986 |
|
18년 전 | 2483 | |
| 985 |
|
18년 전 | 3329 | |
| 984 | 18년 전 | 4272 | ||
| 983 |
느낌좋은날
|
18년 전 | 2492 | |
| 982 | 18년 전 | 2458 | ||
| 981 | 18년 전 | 4032 | ||
| 980 | 18년 전 | 2746 | ||
| 979 |
Sinpre
|
19년 전 | 2982 | |
| 978 | 19년 전 | 2196 | ||
| 977 | 19년 전 | 2215 | ||
| 976 | 19년 전 | 1990 | ||
| 975 | 19년 전 | 3271 | ||
| 974 | 19년 전 | 2103 | ||
| 973 |
|
19년 전 | 2777 | |
| 972 |
|
19년 전 | 1736 | |
| 971 | 19년 전 | 5307 | ||
| 970 | 19년 전 | 3560 | ||
| 969 | 19년 전 | 4313 | ||
| 968 | 19년 전 | 3054 | ||
| 967 | 19년 전 | 2520 | ||
| 966 | 19년 전 | 3916 | ||
| 965 | 19년 전 | 2640 | ||
| 964 | 19년 전 | 2986 | ||
| 963 | 19년 전 | 2953 | ||
| 962 | 19년 전 | 4172 | ||
| 961 | 19년 전 | 3122 | ||
| 960 | 19년 전 | 3016 | ||
| 959 | 19년 전 | 3666 | ||
| 958 | 19년 전 | 2968 | ||
| 957 | 19년 전 | 2189 | ||
| 956 | 19년 전 | 2219 | ||
| 955 | 19년 전 | 2157 | ||
| 954 | 19년 전 | 2762 | ||
| 953 | 19년 전 | 2471 | ||
| 952 | 19년 전 | 3336 | ||
| 951 | 19년 전 | 3189 | ||
| 950 | 19년 전 | 1819 | ||
| 949 | 19년 전 | 2737 | ||
| 948 | 19년 전 | 7820 | ||
| 947 |
|
19년 전 | 2492 | |
| 946 |
DeepnBlue
|
19년 전 | 3096 | |
| 945 |
pearly
|
19년 전 | 2848 | |
| 944 | 19년 전 | 3012 | ||
| 943 |
|
19년 전 | 2211 | |
| 942 | 19년 전 | 2447 | ||
| 941 |
|
19년 전 | 4067 | |
| 940 | 19년 전 | 2226 | ||
| 939 |
|
19년 전 | 4215 | |
| 938 |
|
19년 전 | 2377 | |
| 937 | 19년 전 | 2071 | ||
| 936 |
|
19년 전 | 2320 | |
| 935 | 19년 전 | 1863 | ||
| 934 |
|
19년 전 | 2396 | |
| 933 | 19년 전 | 2188 | ||
| 932 |
|
19년 전 | 3061 | |
| 931 | 19년 전 | 1847 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기