백엔드 개발 PHP 튜토리얼 如何书写安全的PHP代码_PHP

如何书写安全的PHP代码_PHP

Jun 01, 2016 pm 12:43 PM
바이러스 사이버 카페 정보 소프트웨어

PHP是一个很容易学习的语言, 许多人在没有任何编程背景下学习它作为一种去增加一些互动元素到他们的网站的方法. 不幸的是,这往往意味着PHP程序员,尤其是那些较新的Web开发程序员, 并没有觉察他们网站中潜在安全风险. 这里是一些比较常见的安全问题,以及如何去避免它们。

永远,永远信任你的用户

不能说足够的次数,你应该永远,永远, 信任你的用户向你发送你期望的数据. 我听到很多人回应,大概是"哦,没有恶意的人将对我的网站感兴趣"。这就错了, 这里总是有怀有恶意的用户可以利用一个安全漏洞,问题可以很容易被发现,因为一个用户无意中做错了。

因此, 所有网页的发展的戒律,我不能再压缩了的话就是:永远,永远,相信你的用户。假定你的网站从使用者收集的每片数据含有恶意代码,始终, 你认为已经检查客户端验证的这些数据,例如在JavaScript ,如果你能够达到这个目标,你应该有了一个良好的开端。如果PHP的安全性很重要,这一点就要重要地学习,个人来说,"PHP安全"是一个重大的问题。

全局变量

在许多语言,你必须明确地设定一个变量以使用它。 在PHP中,有一个选项" , register_globals" , 你可以在php.ini中设置,让你可以使用全局变量,而不需要事先声明。

考虑下面的代码:

以下为引用的内容:

if ($password == "my_password") {

$authorized = 1;

}

if ($authorized == 1) {

echo "Lots of important stuff.";

}


许多人看上去觉得没什么问题,而事实上,这方面的代码在整个网站上应用. 但是,如果一个服务器开启"register_globals"。然后,只需添加"?authorized=1"的URL将让任何人都看到. 这是一个最普遍的PHP的安全问题。

所幸的是,这有两个简单的解决办法. 第一,也许最好的,就是把"register_globals"关闭. 二是你必须明确只有你使用变量. 在上面的例子中,这将意味着加入"?authorized=0"; 在脚本的开始:

$authorized = 0;if ($password == "my_password") {$authorized = 1;}if ($authorized == 1) {echo "Lots of important stuff.";}

错误信息

错误信息是一个非常有用的工具,无论是程序员和黑客. 开发者需要它们去改正错误. 黑客可以利用它们来找出一个网站的各种信息, 从目录结构的服务器,数据库登录信息. 如果可能的话,最好是关闭所有的错误报告. PHP可以完成这项工作. htaccess或php.ini,设置"error_reporting" 的值改为"0" . 如果你有一个开发环境,您可以设定不同的错误报告级别。

SQL注入

PHP的一个最大优点就是,它可以方便地与数据库中操作,最显着的MySQL的. 很多人使用这个数据库。不少网站,包括这一个,依赖于数据库的函数. 然而,正如你所料,有这么大的权力你就要够面对庞大的潜在安全问题. 所幸的是,有很多解决办法. 最常见面安全问题是一个数据库 SQL注入-当用户利用一个安全故障在你的数据库运行SQL语句. 让我们用一个常见的例子. 许多登录系统具有以下特点:一条线,看起来象不像是在检查从表单输入的用户名和密码, 比如去控制访问一个管理员区:

$check = mysql_query("Select Username, Password, UserLevel FROM Users Where Username = '".$_POST['username']."' and Password = '".$_POST['password']."'");

看上去很眼熟? 就表面看来,它好像做得不错.上述并不像可以做许多破坏. 但话又说回来,我在"username" 输入框输入这样的值并提交:

'' 或者 1=1 #

这个执行语句现在是这个样子:

elect Username, Password FROM Users Where Username = '' or 1=1 #' and Password = '';

散列符号(#)告诉MySQL的它之后一切,都会被忽略. 所以实际上只是执行的SQL到这一点. 1永远等于1 ,所以SQL将从数据库返回所有的用户名和密码. 在大多数用户登录数据库的首个户名和密码组合都是管理员用户, 他干脆输入了几个符号作为管理员已登录你的网站, 果他们其实都知道的用户名和密码,他们会有同样的权力如。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Bonjour란 어떤 소프트웨어이며 제거할 수 있나요? Bonjour란 어떤 소프트웨어이며 제거할 수 있나요? Feb 20, 2024 am 09:33 AM

제목: Bonjour 소프트웨어 탐색 및 제거 방법 개요: 이 문서에서는 Bonjour 소프트웨어의 기능, 사용 범위 및 제거 방법을 소개합니다. 동시에 사용자의 요구에 맞게 Bonjour를 대체하는 다른 도구를 사용하는 방법도 설명합니다. 소개: Bonjour는 컴퓨터 및 네트워크 기술 분야의 일반적인 소프트웨어입니다. 일부 사용자에게는 이 기능이 생소할 수 있지만 일부 특정 상황에서는 매우 유용할 수 있습니다. Bonjour 소프트웨어가 설치되어 있지만 지금 제거하려는 경우

WPS Office에서 PPT 파일을 열 수 없는 경우 수행할 작업 - WPS Office에서 PPT 파일을 열 수 없는 경우 수행할 작업 WPS Office에서 PPT 파일을 열 수 없는 경우 수행할 작업 - WPS Office에서 PPT 파일을 열 수 없는 경우 수행할 작업 Mar 04, 2024 am 11:40 AM

최근 많은 친구들이 WPSOffice에서 PPT 파일을 열 수 없는 경우 어떻게 해야 하는지 문의해 왔습니다. 다음으로 WPSOffice에서 PPT 파일을 열 수 없는 문제를 해결하는 방법에 대해 알아보겠습니다. 1. 먼저 WPSOffice를 열고 아래 그림과 같이 홈페이지에 들어갑니다. 2. 그런 다음 위의 검색창에 "문서 복구"라는 키워드를 입력한 후 아래 그림과 같이 클릭하여 문서 복구 도구를 엽니다. 3. 그런 다음 아래 그림과 같이 복구를 위해 PPT 파일을 가져옵니다.

크리스탈디스크마크란 어떤 소프트웨어인가요? -크리스탈디스크마크는 어떻게 사용하나요? 크리스탈디스크마크란 어떤 소프트웨어인가요? -크리스탈디스크마크는 어떻게 사용하나요? Mar 18, 2024 pm 02:58 PM

CrystalDiskMark는 순차 및 무작위 읽기/쓰기 속도를 빠르게 측정하는 하드 드라이브용 소형 HDD 벤치마크 도구입니다. 다음으로 편집자님에게 CrystalDiskMark 소개와 crystaldiskmark 사용법을 소개하겠습니다~ 1. CrystalDiskMark 소개 CrystalDiskMark는 기계식 하드 드라이브와 솔리드 스테이트 드라이브(SSD)의 읽기 및 쓰기 속도와 성능을 평가하는 데 널리 사용되는 디스크 성능 테스트 도구입니다. ). 무작위 I/O 성능. 무료 Windows 응용 프로그램이며 사용자 친화적인 인터페이스와 다양한 테스트 모드를 제공하여 하드 드라이브 성능의 다양한 측면을 평가하고 하드웨어 검토에 널리 사용됩니다.

CrystalDiskinfo 사용 튜토리얼-CrystalDiskinfo는 어떤 소프트웨어입니까? CrystalDiskinfo 사용 튜토리얼-CrystalDiskinfo는 어떤 소프트웨어입니까? Mar 18, 2024 pm 04:50 PM

CrystalDiskInfo는 컴퓨터 하드웨어 장치를 확인하는 데 사용되는 소프트웨어입니다. 이 소프트웨어에서는 읽기 속도, 전송 모드, 인터페이스 등과 같은 컴퓨터 하드웨어를 확인할 수 있습니다! 그러면 이러한 기능 외에도 CrystalDiskInfo를 사용하는 방법과 CrystalDiskInfo가 정확히 무엇인지 정리해 보겠습니다! 1. CrystalDiskInfo의 유래 컴퓨터 호스트의 세 가지 주요 구성 요소 중 하나인 솔리드 스테이트 드라이브는 컴퓨터의 저장 매체이며 컴퓨터 데이터 저장을 담당합니다. 소비자 경험에 영향을 미칩니다. 소비자가 새 장치를 받으면 타사 소프트웨어나 기타 SSD를 사용하여 다음을 수행할 수 있습니다.

Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법 - Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법 Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법 - Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법 Mar 04, 2024 pm 06:04 PM

많은 사용자가 사무실에서 Adobe Illustrator CS6 소프트웨어를 사용하고 있으므로 Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법을 알고 있습니까? 그러면 편집자가 Adobe Illustrator CS6에서 키보드 증분을 설정하는 방법을 알려줄 것입니다. 아래를 살펴보세요. 1단계: 아래 그림과 같이 Adobe Illustrator CS6 소프트웨어를 시작합니다. 2단계: 메뉴 바에서 [편집] → [기본 설정] → [일반] 명령을 차례로 클릭합니다. 3단계: [키보드 증분] 대화 상자가 나타나면 [키보드 증분] 텍스트 상자에 필요한 숫자를 입력한 후 마지막으로 [확인] 버튼을 클릭합니다. 4단계: 단축키 [Ctrl] 사용

봉쥬르는 어떤 소프트웨어인가요? 봉쥬르는 어떤 소프트웨어인가요? Feb 22, 2024 pm 08:39 PM

Bonjour는 LAN 내에서 네트워크 서비스를 검색하고 구성하기 위해 Apple에서 출시한 네트워크 프로토콜 및 소프트웨어입니다. 주요 역할은 동일한 네트워크에 연결된 장치 간을 자동으로 검색하고 통신하는 것입니다. Bonjour는 2002년 MacOSX10.2 버전에 처음 소개되었으며 현재 Apple 운영 체제에 기본적으로 설치되어 활성화되어 있습니다. 그 이후로 Apple은 Bonjour의 기술을 다른 제조업체에 공개했기 때문에 다른 많은 운영 체제와 장치도 Bonjour를 지원할 수 있습니다.

Edge와 함께 로드하려는 호환되지 않는 소프트웨어 시도를 해결하는 방법은 무엇입니까? Edge와 함께 로드하려는 호환되지 않는 소프트웨어 시도를 해결하는 방법은 무엇입니까? Mar 15, 2024 pm 01:34 PM

Edge 브라우저를 사용하다 보면 가끔 호환되지 않는 소프트웨어가 함께 로드를 시도하는 경우가 있는데 무슨 일이 일어나고 있는 걸까요? 이 사이트에서는 Edge와 호환되지 않는 소프트웨어를 로드하는 문제를 해결하는 방법을 사용자에게 주의 깊게 소개합니다. Edge로 로드하려고 하는 호환되지 않는 소프트웨어를 해결하는 방법 솔루션 1: 시작 메뉴에서 IE를 검색하고 IE로 직접 액세스합니다. 해결 방법 2: 참고: 레지스트리를 수정하면 시스템 오류가 발생할 수 있으므로 주의해서 작업하십시오. 레지스트리 매개변수를 수정합니다. 1. 작동 중에 regedit를 입력하십시오. 2.\HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Micros 경로를 찾으세요.

휴대폰에서 바이러스를 완전히 제거하는 방법 휴대폰에서 바이러스를 처리하는 권장 방법 휴대폰에서 바이러스를 완전히 제거하는 방법 휴대폰에서 바이러스를 처리하는 권장 방법 Feb 29, 2024 am 10:52 AM

휴대폰이 특정 트로이 목마 바이러스에 감염된 후에는 바이러스 백신 소프트웨어로 탐지 및 제거할 수 없습니다. 이 원리는 마치 C 드라이브를 포맷하고 바이러스에 감염된 컴퓨터를 완전히 제거할 수 있는 것과 같습니다. 시스템을 다시 설치한 다음, 휴대폰이 완고한 바이러스에 감염된 후 바이러스를 완전히 치료하는 방법을 설명하겠습니다. 방법 1: 휴대폰을 열고 "설정" - "기타 설정" - "휴대폰 복원"을 클릭하여 휴대폰을 공장 설정으로 복원합니다. 참고: 공장 설정을 복원하기 전에 휴대폰의 중요한 데이터를 백업해야 합니다. "시스템을 포맷하고 재설치하는 것과 같습니다." 복구 후 휴대폰의 데이터가 삭제됩니다. 방법 2 (1) 먼저 휴대폰을 끄고 "전원"을 길게 누릅니다. 버튼" + "볼륨 + 버튼 또는 볼륨 - 버튼"을 동시에 휴대폰에서.

See all articles