백엔드 개발 PHP 튜토리얼 PHP安全防护要点分析_PHP教程

PHP安全防护要点分析_PHP教程

Jul 15, 2016 pm 01:35 PM
php web 신뢰하다 ~에 대한 분석하다 외부 보안 보안 보호 데이터 ~의 주요사항

关于 Web 应用程序安全性,必须认识到的第一件事是不应该信任外部数据。外部数据(outside data) 包括不是由程序员在 PHP 代码中直接输入的任何数据。在采取措施确保安全之前,来自任何其他来源(比如 GET 变量、表单 POST、数据库、配置文件、会话变量或 cookie)的任何数据都是不可信任的。

例如,下面的数据元素可以被认为是安全的,因为它们是在 PHP 中设置的。

PHP安全防护清单 1. 安全无暇的代码

1

2

3

4

5

6

7

8

9

10

11

12

13

<ol class="dp-xml">

<li class="alt"><span><span class="tag"><span> ?php  </span></span></span></li>

<li>

<span>$</span><span class="attribute">myUsername</span><span> = ‘tmyer’;  </span>

</li>

<li class="alt">

<span>$</span><span class="attribute-value">array</span><span class="attribute">arrayUsers</span><span> = array<br>(’tmyer’, ‘tom’, ‘tommy’);  </span>

</li>

<li><span>define(”GREETING”, ‘hello<br> there’ . $myUsername);  </span></li>

<li class="alt">

<span class="tag">?&gt;</span><span> </span>

</li>

</ol>

로그인 후 복사

但是,下面的数据元素都是有瑕疵的。

PHP安全防护清单 2. 不安全、有瑕疵的代码

1

2

3

4

5

6

7

8

9

10

11

12

13

<ol class="dp-xml">

<li class="alt"><span><span class="tag"><span> ?php  </span></span></span></li>

<li>

<span>$</span><span class="attribute">myUsername</span><span> = $_POST[’username’]; <br>//tainted!  </span>

</li>

<li class="alt">

<span>$</span><span class="attribute-value">array</span><span class="attribute">arrayUsers</span><span> = array($my<br>Username, ‘tom’, ‘tommy’); <br>//tainted!  </span>

</li>

<li><span>define(”GREETING”, ‘hello there’ <br>. $myUsername); //tainted!  </span></li>

<li class="alt">

<span class="tag">?&gt;</span><span> </span>

</li>

</ol>

로그인 후 복사

为 什么第一个变量 $myUsername 是有瑕疵的?因为它直接来自表单 POST。用户可以在这个输入域中输入任何字符串,包括用来清除文件或运行以前上传的文件的恶意命令。

您可能会问,“难道不能使用只接受字母 A-Z 的客户端(Javascrīpt)表单检验脚本来避免这种危险吗?”是的,这总是一个有好处的步骤,但是正如在后面会看到的,任何人都可以将任何表单下载 到自己的机器上,修改它,然后重新提交他们需要的任何内容。

解决方案很简单:必须对 $_POST[’username’] 运行清理代码。如果不这么做,那么在使用 $myUsername 的任何其他时候(比如在数组或常量中),就可能污染这些对象。

对用户输入进行清理的一个简单方法是,使用正则表达式来处理它。在这个示例中,只希望接受字母。将字符串限制为特定数量的字符,或者要求所有字母都是小写的,这可能也是个好主意。

PHP安全防护清单 3. 使用户输入变得安全

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

<ol class="dp-xml">

<li class="alt"><span><span class="tag"><span> ?php  </span></span></span></li>

<li>

<span>$</span><span class="attribute">myUsername</span><span> = </span><span class="attribute-value">cleanInput</span><span>($_<br>POST[’username’]); //clean!  </span>

</li>

<li class="alt">

<span>$</span><span class="attribute-value">array</span><span class="attribute">arrayUsers</span><span> = array(<br>$myUsername, ‘tom’, ‘tommy’); //clean!  </span>

</li>

<li><span>define(”GREETING”, ‘hello <br>there’ . $myUsername); //clean!  </span></li>

<li class="alt"><span>function cleanInput($input){  </span></li>

<li>

<span>$</span><span class="attribute">clean</span><span> = </span><span class="attribute-value">strtolower</span><span>($input);  </span>

</li>

<li class="alt">

<span>$</span><span class="attribute">clean</span><span> = </span><span class="attribute-value">preg_replace</span><span>(”/[^a-z]<br>/”, “”, $clean);  </span>

</li>

<li>

<span>$</span><span class="attribute">clean</span><span> = </span><span class="attribute-value">substr</span><span>($clean,0,12);  </span>

</li>

<li class="alt"><span>return $clean;  </span></li>

<li><span>}  </span></li>

<li class="alt">

<span class="tag">?&gt;</span><span> </span>

</li>

</ol>

로그인 후 복사

以上就是PHP安全防护的相关技巧讲解。


www.bkjia.comtruehttp://www.bkjia.com/PHPjc/445922.htmlTechArticle关于 Web 应用程序安全性,必须认识到的第一件事是不应该信任外部数据。外部数据(outside data) 包括不是由程序员在 PHP 代码中直接输入...
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

CakePHP 프로젝트 구성

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

CakePHP 날짜 및 시간

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

CakePHP 파일 업로드

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

CakePHP 라우팅

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP 토론

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법

CakePHP 빠른 가이드 CakePHP 빠른 가이드 Sep 10, 2024 pm 05:27 PM

CakePHP 빠른 가이드

See all articles