PHP 초보자를 혼란스럽게 하는 10가지 지식 포인트
[1] get, post, session 변수는 페이지 간 이동이 불가능합니다. 최신 PHP 버전에서는 자동 전역 변수가 꺼져 있으므로 이전 페이지에서 제출된 변수를 가져오려면
$_GET[을 사용하세요. ' foo'],$_POST['foo'],$_SESSION['foo'] 를 가져옵니다. 물론, 자동 전역 변수를 on(php.ini에서 Register_globals = On)으로 수정할 수도 있습니다. 호환성을 고려하면 www.lampbrother.net의 새로운 작성 방법에 억지로 익숙해지는 것이 좋습니다.
참고: PHP의 슈퍼전역 변수
PHP 4.2.0부터 Register_globals의 기본값은 off입니다. 이러한 방식으로 $PHP_SELF 또는 사용자가 설정한 SESSION과 같이 직접 사용할 수 있는 이전 변수가 많이 있습니다. "$variable name" 형식으로는 액세스할 수 없습니다. 이렇게 하면 많은 변경 사항이 발생할 수 있지만 보안을 향상하는 데 도움이 됩니다. 이러한 변수에 액세스하려면 다음과 같이 PHP 슈퍼전역 변수를 사용해야 합니다.
$_SERVER
변수는 웹 서버에 의해 설정되거나 현재 스크립트의 실행 환경과 직접 연결됩니다. 이전 $HTTP_SERVER_VARS 배열과 유사합니다. 이전 $PHP_SELF는 $_SERVER['PHP_SELF']에 해당합니다. phpinfo를 사용하여 $_SERVER 변수를 볼 수 있습니다.
$_GET
HTTP GET 메소드를 통해 스크립트에 제출된 변수입니다. 이전 $HTTP_GET_VARS 배열과 유사합니다.
$_POST
HTTP POST 메서드를 통해 스크립트에 제출된 변수입니다. 이전 $HTTP_POST_VARS 배열과 유사합니다.
$_COOKIE
HTTP 쿠키 메소드를 통해 스크립트에 제출된 변수입니다. 이전 $HTTP_COOKIE_VARS 배열과 유사합니다.
$_SESSION
현재 스크립트 세션에 등록된 변수입니다. 이전 $HTTP_SESSION_VARS 배열과 유사합니다.
$_FILES
HTTP POST 파일 업로드를 통해 스크립트에 제출된 변수입니다. 이전 $HTTP_POST_FILES 배열과 유사합니다.
$_ENV
실행 환경에서 스크립트에 제출한 변수입니다. 이전 $HTTP_ENV_VARS 배열과 유사합니다.
========================================== == ========================
$_FILES 변수의 경우: (파일 도메인 필드는 "myfile"입니다.)
$_FILES[ 'myfile']['name']
클라이언트 컴퓨터 파일의 원래 이름(경로 포함)입니다.
$_FILES['myfile']['type']
브라우저가 "image/gif"와 같이 이 정보를 지원해야 하는 파일의 MIME 유형입니다.
$_FILES['myfile']['size']
업로드된 파일의 크기(바이트)입니다.
$_FILES['myfile']['tmp_name']
파일 업로드 후 서버에 저장되는 임시 파일 이름(경로 포함)입니다.
$_FILES['myfile']['error']
파일 업로드 관련 오류 코드입니다. ['오류']는 PHP 4.2.0에 추가되었습니다.
php.ini의 Register_globals가 on으로 설정되면 $myfile_name은 $_FILES['myfile']['name']과 동일하고 $myfile_type은 $_FILES['myfile']['type' ]wait와 동일합니다. .
【2】win32에서 세션이 제대로 작동하지 않습니다.
php.ini 기본 session.save_path = /tmp
이것은 분명히 Linux에서의 구성입니다. PHP는 win32에서 세션 파일을 읽고 쓸 수 없습니다. 세션을 사용할 수 없습니다. session.save_path = c:windowstemp와 같은 절대 경로로 변경하면 됩니다.
【3】오류 정보 표시
php.ini의 display_errors = On, error_reporting = E_ALL일 경우, 디버깅 중 오류 수정을 위해 이를 켜는 것이 가장 좋습니다. 과거에는 대부분의 PHP 작성 오류 메시지가 정의되지 않은 변수에 관한 것이었습니다. 변수가 할당되기 전에 호출되면 프롬프트가 표시됩니다. 해결책은 이를 감지하거나 차단하는 것입니다. 예를 들어, $foo가 표시되면 if(isset($foo)) echo $foo 또는 echo @$foo를 수행할 수 있습니다.
【4】헤더가 이미 전송되었습니다.
이 오류는 일반적으로 HEADER를 사용할 때 발생합니다. 그 이유는 다음과 같습니다: 1. HEADER를 사용하기 전에 PRING 또는 ECHO를 실행합니다. 2. 앞에 빈 줄이 있습니다. 현재 파일의 3. 파일을 포함시켰을 수 있습니다. 이 오류는 파일 끝이나 출력에 빈 줄이 있는 경우에도 발생합니다.
【5】php.ini 변경 후 변경 없음
IIS, Apache 등 웹 서버를 다시 시작하면 최신 설정이 적용됩니다.
【6】가끔 sql 문이 작동하지 않아 데이터베이스 작업이 실패하는 경우가 있습니다. 디버깅하는 가장 쉬운 방법은 SQL 문을 에코하여 변수 값을 얻을 수 있는지 확인하는 것입니다.
【7】include와 require의 차이점
include할 파일이 존재하지 않는 경우에는 include를 알리고 다음 명령문을 계속 실행합니다. require는 치명적인 오류를 표시하고 종료됩니다. 테스트에 따르면 win32 플랫폼에서는 먼저 포함된 후 실행되므로 포함된 파일에 include 또는 require 문을 두지 않는 것이 가장 좋습니다. 이로 인해 디렉터리 혼란이 발생할 수 있습니다. *nux에서는 상황이 다를 수도 있습니다. 아직 테스트해 보지 않았습니다. 파일을 여러 번 포함하지 않으려면 include_once 또는 require_once##를 사용하여 문서 데이터를 읽고 쓸 수 있습니다.
function r($file_name) {
$filenum=@fopen( $file_name,"r ");
@flock($filenum,LOCK_SH)
$file_data=@fread($filenum,filesize($file_name)); 🎜>return $file_data;
}
함수 w($file_name,$data,$method="w"){
$filenum=@fopen($file_name,$method)
flock($ filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
return $file_data; ()와 empty()의 차이점
둘 다 변수를 테스트하는 데 사용되지만 isset()은 변수에 값이 할당되었는지 테스트하고,empty()는 값이 할당된 변수가 비어 있는지 테스트합니다. 값을 할당하지 않고 PHP에서 변수를 참조하는 경우 허용되지만 알림이 표시됩니다. 변수에 null 값($foo="" 또는 $foo=0 또는 $foo=false)이 할당된 경우 비어 있음($foo)은 true를 반환하고 isset($foo)도 true를 반환합니다. 로그아웃하지 마세요. 변수 등록을 취소하려면 unset($foo) 또는 $foo=NULL을 사용하세요.
【9】mysql 쿼리문에 키워드가 포함되어 있습니다.
PHP가 mysql을 쿼리할 때 mysql 테이블 이름이나 열 이름에 키워드가 포함되어 있는 경우가 있는데 이때 쿼리에 오류가 발생합니다. 예를 들어 테이블 이름이 order인 경우 쿼리 시 오류가 발생합니다. 간단한 방법은 SQL 문에서 테이블 이름이나 열 이름에 `[탭 키 위]를 추가하여 구분하는 것입니다. 예를 들어 *를 선택합니다. '주문'에서.
[10] HTTP 프로토콜을 통해 여러 파일을 한 번에 업로드하는 방법
같은 방법을 두 가지 구현한 두 가지 아이디어가 있습니다. 구체적인 절차는 직접 설계해야 합니다.
1. 양식에 여러 개의 파일 입력 상자를 설정하고 다음과 같이 배열로 이름을 지정해야 합니다.
이런 식으로 서버 측에서 다음 테스트를 수행합니다.
echo " "
print_r($_FILES)
echo; " " ;
2. 형식에 여러 파일 입력 상자를 설정하되 이름은 다음과 같이 설정합니다.
서버 측에서도 동일한 테스트를 수행합니다.
echo " "
print_r($_FILES) echo "
";

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alipay PHP ...

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

이 기사에서는 프레임 워크에 사용자 정의 기능 추가, 아키텍처 이해, 확장 지점 식별 및 통합 및 디버깅을위한 모범 사례에 중점을 둡니다.

PHP 개발에서 PHP의 CURL 라이브러리를 사용하여 JSON 데이터를 보내면 종종 외부 API와 상호 작용해야합니다. 일반적인 방법 중 하나는 컬 라이브러리를 사용하여 게시물을 보내는 것입니다 ...

PHP 개발에서 견고한 원칙의 적용에는 다음이 포함됩니다. 1. 단일 책임 원칙 (SRP) : 각 클래스는 하나의 기능 만 담당합니다. 2. Open and Close Principle (OCP) : 변경은 수정보다는 확장을 통해 달성됩니다. 3. Lisch의 대체 원칙 (LSP) : 서브 클래스는 프로그램 정확도에 영향을 미치지 않고 기본 클래스를 대체 할 수 있습니다. 4. 인터페이스 격리 원리 (ISP) : 의존성 및 사용되지 않은 방법을 피하기 위해 세밀한 인터페이스를 사용하십시오. 5. 의존성 반전 원리 (DIP) : 높고 낮은 수준의 모듈은 추상화에 의존하며 종속성 주입을 통해 구현됩니다.

Reactphp의 비 블로킹 기능에 대한 Reactphp의 심층적 인 해석의 비 차단 기능에 대한 공식 소개는 많은 개발자들의 질문을 불러 일으켰습니다.
