개요: 이 기사에서는 PHP 개발자가 코딩할 때 간과하거나 주의를 기울이지 않는 작은 실수와 오류를 살펴봅니다.
변수 선언
아래와 같이 명령문에서 변수를 선언하는 경우: $var='value';컴파일러는 먼저 명령문의 오른쪽 절반의 값을 찾게 되는데, 이것이 바로 명령문의 이 부분입니다. 종종 오류가 발생합니다. 잘못된 구문을 사용하면 구문 분석 오류가 발생합니다.
파싱 오류
예를 들어 19행의 c:program filesapache groupapachehtdocsscript.php의 Parse error: Unexpected T_WHILE입니다. 이전 오류가 확인될 때마다 구문 분석 오류가 계속해서 차례로 나타나고, PHP는 첫 번째 구문 분석 오류 이후 실행을 중지하면 됩니다. 스크립트. 또한 구문 분석 오류에는 정보가 거의 없으며 오류가 발생한 줄 번호도 거의 보고되지 않습니다. 예를 들어, 사전 정의된 키워드가 표현식에 사용됩니다. 예: while=10; while은 사전 정의된 키워드이며 값을 할당할 수 없습니다. 미리 정의된 키워드에는 while, 함수 등이 포함됩니다. 이러한 미리 정의된 키워드를 사용하여 변수 이름을 지정할 수 없습니다. 그렇지 않으면 컴파일러가 오류를 보고합니다. 그 중 T_IF는 if()를 나타내고, T_WHILE은 while()을 나타내고, T_FOR은 for()를 나타냅니다.
흔히 발생하는 실수
세미콜론(;)으로 문을 끝내지 않거나 문자열에 따옴표가 누락되는 등 일반적인 오류도 있습니다. 또한 함수나 루프를 끝내기 위해 중괄호(})를 사용하지 않는 경우, 예를 들어 function UselessFunction(){for($iphp on line 9 함수 UselessFunction은 중괄호(})로 끝나지 않으므로 PHP 컴파일러는 계속해서 파일 끝에 도달할 때까지 닫는 중괄호를 찾으세요. 컴파일러는 일치하는 중괄호를 찾지 못하기 때문에 파일 끝 오류를 보고합니다. 코드 계층 구조가 올바르게 반영되면 오류 메시지가 매우 분명해집니다. 그렇지 않으면 코드를 디버그하기가 매우 어려워집니다. 따라서 코드의 계층적 구조를 명시해야 후속 개발자가 코드를 더 쉽게 개선할 수 있습니다.
MySQL 오류
또 다른 유형의 오류 메시지는 MySQL 오류입니다. 이 오류는 종종 PHP 초보자에게 다음과 같이 상당히 골치 아픈 느낌을 줍니다. 경고: 제공된 인수는 유효한 MySQL 결과 리소스가 아닙니다. 위에 보고된 잘못된 줄은 다음과 같습니다. ($row=mysql_fetch_array($result)){}쿼리가 실패하고 mysql_fetch_array를 처리할 수 없기 때문에 $result 매개변수는 유효한 리소스가 아닙니다. 쿼리 구문이 유효하지 않거나 데이터베이스 연결에 실패하는 경우 MySQL 콘솔로 이동하여 테스트해야 합니다.
에코와 인쇄의 차이점에 주의
PHP에서는 echo와 print 모두 출력 기능이 있지만 여전히 미묘한 차이가 있습니다. echo 출력 후에는 반환값이 없지만 print 에는 반환값이 있어서 실행 실패 시 false 를 반환합니다. 따라서 일반적인 함수로 사용할 수 있습니다. 예를 들어 $r=print "Hello World"가 실행되면 변수 $r의 값은 1이 됩니다. 게다가 코드의 echo 문은 print 문보다 약간 빠르게 실행됩니다.
빈 문자열('')과 NULL의 차이점에 주의하세요
PHP에서 빈 문자열과 NULL은 모두 0의 값으로 저장되는데, 전자가 문자열이고 후자는 문자열('')과 NULL 값이 있음을 알 수 있습니다. 동일하지만 유형이 다릅니다.
==(같음)과 ===(모두 같음)의 차이를 구별하세요
둘 다 비교 연산자입니다. ==(같음)은 값이 같은지 비교하는 반면, ===(모두 같음)은 값이 같은지 비교하는 것뿐만 아니라 유형이 같은지도 비교합니다. 더 엄격합니다.
포함과 필수의 차이점을 구별하세요
include()와 require()의 기능은 기본적으로 동일하지만 사용법에 약간의 차이가 있습니다. include()는 기능을 조건부로 포함하는 반면, require()는 무조건 기능을 포함합니다. 예를 들어, 다음 코드에서 $a 변수가 true이면 a.php 파일이 포함됩니다. if($a){include("a.php");} 및 require()는 다릅니다. include() 에서 $a 가 어떤 값을 취하든 상관없이 다음 코드는 a.php 파일을 포함합니다: if($a){require("a.php");} 오류 처리 측면에서 include 문을 사용하세요. 포함 오류가 발생하면 프로그램은 포함 문을 건너뛰고 오류 메시지가 표시되더라도 프로그램은 계속 실행됩니다. 그러나 require 문은 치명적인 오류를 발생시킵니다.
isset과 비어 있음의 차이점에 유의하세요.
비어 있음은 변수가 "비어 있는지" 확인하는 것이고, isset은 변수가 설정되어 있는지 확인하는 것입니다.
self::와 this의 차이점을 구별하세요.->
PHP 클래스의 멤버 변수나 메소드에 접근할 때, 참조되는 변수나 메소드가 const(상수) 또는 static(정적 속성)으로 선언된 경우 도메인 연산자::를 사용해야 하며, 참조되는 경우에는 변수 또는 메소드가 const 또는 static으로 선언되지 않은 경우 포인터 연산자 ->를 사용하십시오.위 내용은 PHP 프로그래밍에서 흔히 발생하는 실수 목록을 소개했으며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

세션 고정 공격을 방지하는 효과적인 방법은 다음과 같습니다. 1. 사용자 로그인 한 후 세션 ID 재생; 2. 보안 세션 ID 생성 알고리즘을 사용하십시오. 3. 세션 시간 초과 메커니즘을 구현하십시오. 4. HTTPS를 사용한 세션 데이터를 암호화합니다. 이러한 조치는 세션 고정 공격에 직면 할 때 응용 프로그램이 파괴 할 수 없도록 할 수 있습니다.

서버 측 세션 스토리지가없는 토큰에 저장되는 토큰 기반 인증 시스템 인 JSONWEBTOKENS (JWT)를 사용하여 세션없는 인증 구현을 수행 할 수 있습니다. 1) JWT를 사용하여 토큰을 생성하고 검증하십시오. 2) HTTPS가 토큰이 가로 채지 못하도록하는 데 사용되도록, 3) 클라이언트 측의 토큰을 안전하게 저장, 4) 변조 방지를 방지하기 위해 서버 측의 토큰을 확인하기 위해 단기 접근 메커니즘 및 장기 상쾌한 토큰을 구현하십시오.

PHP 세션의 보안 위험에는 주로 세션 납치, 세션 고정, 세션 예측 및 세션 중독이 포함됩니다. 1. HTTPS를 사용하고 쿠키를 보호하여 세션 납치를 방지 할 수 있습니다. 2. 사용자가 로그인하기 전에 세션 ID를 재생하여 세션 고정을 피할 수 있습니다. 3. 세션 예측은 세션 ID의 무작위성과 예측 불가능 성을 보장해야합니다. 4. 세션 중독 데이터를 확인하고 필터링하여 세션 중독을 방지 할 수 있습니다.

PHP 세션을 파괴하려면 먼저 세션을 시작한 다음 데이터를 지우고 세션 파일을 파괴해야합니다. 1. 세션을 시작하려면 세션 _start ()를 사용하십시오. 2. Session_Unset ()을 사용하여 세션 데이터를 지우십시오. 3. 마지막으로 Session_Destroy ()를 사용하여 세션 파일을 파괴하여 데이터 보안 및 리소스 릴리스를 보장하십시오.

PHP의 기본 세션 저장 경로를 변경하는 방법은 무엇입니까? 다음 단계를 통해 달성 할 수 있습니다. session_save_path를 사용하십시오 ( '/var/www/sessions'); session_start (); PHP 스크립트에서 세션 저장 경로를 설정합니다. php.ini 파일에서 세션을 설정하여 세션 저장 경로를 전 세계적으로 변경하려면 세션을 설정하십시오. memcached 또는 redis를 사용하여 ini_set ( 'session.save_handler', 'memcached')과 같은 세션 데이터를 저장합니다. ini_set (

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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

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

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
