php错误处理和php异常处理机制
php错误处理
当我们开发程序时,有时候程序出现了问题,我们就可以用以下几种办法找出错误。
开发阶段:开发时输出所有的错误报告,有利于我们进行程序调试
运行阶段:我们不要让程序输出任何一种错误报告(不能让用户看到(包括懂技术, 不懂技术的人))
将错误报告写入日志中
一、指定错误报告 error_reporting = E_LL
二、关闭错误输出 display_errors = Off
三、开启错误日志功能 log_errors = On
1. 默认如果不指定错误日志位置,则默认写WEB服务器的日志中
2. 为error_log选项指定 一个文件名(可写)
3. 写入到操作系统日志中error_log=syslog
以下代码示例
<span style="font-family:SimSun;font-size:14px;"><?php // error_reporting(E_ALL);/// ini_set("display_errors", "off");// ini_set("error_log", "syslog");// ini_set("MAX_FILEUPLOAD", 200000000);// echo ini_get("upload_max_filesize");// error_log("this is a error message!!!!"); getType($var); //注意 getType(); //警告 getTye(); //错误 会终止程序运行 echo "###########################<br>"; ?></span>
当然php还提供了函数error_get_last()来获得错误信息
函数定义和用法
小例子:
<span style="font-family:SimSun;font-size:14px;"><?php echo $test; print_r(error_get_last()); ?>输出:Array ( [type] => 8 [message] => Undefined variable: test [file] => D:\www\test.php [line] => 2 )</span>
php5.4以后也提供了PHP预定义变量$php_errormsg
$php_errormsg — 前一个错误信息
$php_errormsg 变量包含由 PHP 生成的最新错误信息。这个变量只在错误发生的作用域内可用,并且要求track_errors 配置项是开启的(默认是关闭的)。例子:
<?php @strpos();echo $php_errormsg;?>
会输出:
Wrong parameter count for strpos()
所以这样我们也很方便了。。。这样是不是对调试程序和排查错误的时候很有帮助呢?
这些错误报告级别是错误处理程序旨在处理的错误的不同的类型:
值 | 常量 | 描述 |
---|---|---|
2 | E_WARNING | 非致命的 run-time 错误。不暂停脚本执行。 |
8 | E_NOTICE |
Run-time 通知。 脚本发现可能有错误发生,但也可能在脚本正常运行时发生。 |
256 | E_USER_ERROR | 致命的用户生成的错误。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_ERROR。 |
512 | E_USER_WARNING | 非致命的用户生成的警告。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_WARNING。 |
1024 | E_USER_NOTICE | 用户生成的通知。这类似于程序员使用 PHP 函数 trigger_error() 设置的 E_NOTICE。 |
4096 | E_RECOVERABLE_ERROR | 可捕获的致命错误。类似 E_ERROR,但可被用户定义的处理程序捕获。(参见 set_error_handler()) |
8191 | E_ALL |
所有错误和警告,除级别 E_STRICT 以外。 (在 PHP 6.0,E_STRICT 是 E_ALL 的一部分) |
php异常处理机制
定义:
异常处理: 意外,是在程序运行过程中发生的意料这外的事,使用异常改变脚本正常流程
语法格式:
<span style="font-family:SimSun;font-size:14px;">try{ //...}catch(Exception $e){ //...}</span>
PHP中try{}catch{}是异常处理.
将要执行的代码放入TRY块中,如果这些代码执行过程中某一条语句发生异常,则程序直接跳转到CATCH块中,由$e收集错误信息和显示.
PHP中try{}catch{}语句
为了进一步处理异常,我们需要使用PHP中try{}catch{}----包括Try语句和至少一个的catch语句。任何调用 可能抛出异常的方法的代码都应该使用try语句。Catch语句用来处理可能抛出的异常。例子:
我写一段代码:
自己定义一个异常类
作用:就是写一个或多个方法解决当发生这个异常时的处理方式
1. 自己定义异常类,必须是Exception(内置类)的子类, 可以查看PHP手册里面Exception(内置类)的使用方法
2. Exception类中的只有构造方法和toString()可以重写, 其它都final
<span style="font-family:SimSun;font-size:14px;"><?phpclass OpenFileException extends Exception { //继承PHP的内置类 function __construct($message = null, $code = 0){ parent::__construct($message, $code); echo "wwwwwwwwwwwwwww<br>"; } function open(){ touch("tmp.txt"); $file=fopen("tmp.txt", "r"); return $file; }}?></span>
1. 如果try中代码没有问题,则将try中代码执行完后就到catch后执行
2. 如果try中代码有异常发生,则抛出一个异常对象(使用throw),抛出给了catch中的参数, 则在try中代码就不会再继续执行下去 直接跳转到catch中去执行, catch中执行完成, 再继续向下执行
注意: 提示发生了什么异常,这不是主要我们要做事,需要在catch中解决这个异常, 如果解决不了,则出去给用户在下面代码中,如果我没有这个TMP.TXT文件的话,就会抛出异常了。
如果有异常,我们调用OPEN方法就可以解决这个异常了。
<span style="font-family:SimSun;font-size:14px;"><?phptry { $file=fopen("tmp.txt", "r"); // 尝试读取这个文件 if(!$file) throw new OpenFileException("文件打开失败"); //如果文件不存在则抛出异常 }catch(OpenFileException $e){ //$e =new Exception(); echo $e->getMessage()."<br>"; //getMessage() 是PHP里面内置的方法,可以直接调用 $file=$e->open(); }</span>
下面将代码进行整理以及多个异常处理方法:
<span style="font-family:SimSun;font-size:14px;"><?php /* * 异常处理: 意外,是在程序运行过程中发生的意料这外的事,使用异常改变脚本正常流程 * * PHP5中的一个新的重要特性 * * if(){ * * }else{ * * } * * try { * * }catch(异常对象){ * * } * * 1. 如果try中代码没有问题,则将try中代码执行完后就到catch后执行 * 2. 如果try中代码有异常发生,则抛出一个异常对象(使用throw),抛出给了catch中的参数, 则在try中代码就不会再继续执行下去 * 直接跳转到catch中去执行, catch中执行完成, 再继续向下执行 * * * 注意: 提示发生了什么异常,这不是主要我们要做事,需要在catch中解决这个异常, 如果解决不了,则出去给用户 * * 二、自己定义一个异常类 * * 作用:就是写一个或多个方法解决当发生这个异常时的处理方式 * * 1. 自己定义异常类,必须是Exception(内置类)的子类, * 2. Exception类中的只有构造方法和toString()可以重写, 其它都final * * 三、处理多个异常 * * * 自己定义功能类时如果在方法中抛出异常 * * */class OpenFileException extends Exception { function __construct($message = null, $code = 0){ parent::__construct($message, $code); echo "wwwwwwwwwwwwwww<br>"; } function open(){ touch("tmp.txt"); $file=fopen("tmp.txt", "r"); return $file; }}class DemoException extends Exception { function pro(){ echo "处理demo发生的异常<br>"; }}class TestException extends Exception { function pro(){ echo "这里处理test发生的异常<br>"; }}class HelloException extends Exception {}class MyClass { function openfile(){ [email protected]("tmp.txt", "r"); if(!$file) throw new OpenFileException("文件打开失败"); } function demo($num=0){ if($num==1) throw new DemoException("演示出异常"); } function test($num=0){ if($num==1) throw new TestException("测试出错"); } function fun($num=0){ if($num==1) throw new HelloException("###########"); }}try{ echo "11111111111111<br>"; $my=new MyClass(); $my->openfile(); $my->demo(0); $my->test(0); $my->fun(1); echo "22222222222222222<br>";}catch(OpenFileException $e){ //$e =new Exception(); echo $e->getMessage()."<br>"; $file=$e->open();}catch(DemoException $e){ echo $e->getMessage()."<br>"; $e->pro();}catch(TestException $e){ echo $e->getMessage()."<br>"; $e->pro();}catch(Exception $e){ echo $e->getMessage()."<br>";} var_dump($file); echo "444444444444444444444<br>";</span>

세션 관련 XSS 공격으로부터 응용 프로그램을 보호하려면 다음 조치가 필요합니다. 1. 세션 쿠키를 보호하기 위해 Httponly 및 Secure 플래그를 설정하십시오. 2. 모든 사용자 입력에 대한 내보내기 코드. 3. 스크립트 소스를 제한하기 위해 컨텐츠 보안 정책 (CSP)을 구현하십시오. 이러한 정책을 통해 세션 관련 XSS 공격을 효과적으로 보호 할 수 있으며 사용자 데이터가 보장 될 수 있습니다.

PHP 세션 성능을 최적화하는 방법 : 1. 지연 세션 시작, 2. 데이터베이스를 사용하여 세션을 저장, 3. 세션 데이터 압축, 4. 세션 수명주기 관리 및 5. 세션 공유 구현. 이러한 전략은 높은 동시성 환경에서 응용의 효율성을 크게 향상시킬 수 있습니다.

THESESSION.GC_MAXLIFETIMESETTINGINSTTINGTINGSTINGTERMINESTERMINESTERSTINGSESSIONDATA, SETINSECONDS.1) IT'SCONFIGUDEDINPHP.INIORVIAINI_SET ()

PHP에서는 Session_Name () 함수를 사용하여 세션 이름을 구성 할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Session_Name () 함수를 사용하여 Session_Name ( "my_session")과 같은 세션 이름을 설정하십시오. 2. 세션 이름을 설정 한 후 세션을 시작하여 세션을 시작하십시오. 세션 이름을 구성하면 여러 응용 프로그램 간의 세션 데이터 충돌을 피하고 보안을 향상시킬 수 있지만 세션 이름의 독창성, 보안, 길이 및 설정 타이밍에주의를 기울일 수 있습니다.

세션 ID는 로그인시, 민감한 작업 전에 및 30 분마다 정기적으로 재생되어야합니다. 1. 세션 고정 공격을 방지하기 위해 로그인 할 때 세션 ID를 재생합니다. 2. 안전성을 향상시키기 위해 민감한 작업 전에 재생성. 3. 정기적 인 재생은 장기 활용 위험을 줄이지 만 사용자 경험을 평가해야합니다.

Session_SET_COOKIE_PARAMS () 함수를 통해 PHP에서 세션 쿠키 매개 변수 설정을 달성 할 수 있습니다. 1)이 기능을 사용하여 만료 시간, 경로, 도메인 이름, 보안 플래그 등과 같은 매개 변수를 설정하십시오. 2) call session_start ()를 호출하려면 매개 변수를 발효시킵니다. 3) 사용자 로그인 상태와 같은 요구에 따라 매개 변수를 동적으로 조정합니다. 4) 보안을 향상시키기 위해 안전하고 httponly 플래그 설정에주의를 기울이십시오.

PHP에서 세션을 사용하는 주요 목적은 다른 페이지간에 사용자의 상태를 유지하는 것입니다. 1) 세션은 Session_Start () 함수를 통해 시작되어 고유 한 세션 ID를 생성하고 사용자 쿠키에 저장합니다. 2) 세션 데이터는 서버에 저장되므로 로그인 상태 및 쇼핑 카트 컨텐츠와 같은 다른 요청간에 데이터를 전달할 수 있습니다.

하위 도메인 간의 세션을 공유하는 방법? 공통 도메인 이름에 대한 세션 쿠키를 설정하여 구현. 1. 세션 쿠키 도메인을 서버 측에서 .example.com으로 설정하십시오. 2. 메모리, 데이터베이스 또는 분산 캐시와 같은 적절한 세션 저장 방법을 선택하십시오. 3. 쿠키를 통해 세션 ID를 전달하면 서버는 ID를 기반으로 세션 데이터를 검색하고 업데이트합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

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

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
