백엔드 개발 PHP 튜토리얼 PHP与SQL注入攻击防范小技巧_php技巧

PHP与SQL注入攻击防范小技巧_php技巧

May 17, 2016 am 09:15 AM
주입 공격 예방법

下面来谈谈SQL注入攻击是如何实现的,又如何防范。

 看这个例子:

复制代码 代码如下:

// supposed input
$name = "ilia'; DELETE FROM users;";
mysql_query("SELECT * FROM users WHERE name='{$name}'");

 很明显最后数据库执行的命令是:

SELECT * FROM users WHERE name=ilia; DELETE FROM users

 这就给数据库带来了灾难性的后果–所有记录都被删除了。

 不过如果你使用的数据库是MySQL,那么还好,mysql_query()函数不允许直接执行这样的操作(不能单行进行多个语句操作),所以你可以放心。如果你使用的数据库是SQLite或者PostgreSQL,支持这样的语句,那么就将面临灭顶之灾了。

 上面提到,SQL注入主要是提交不安全的数据给数据库来达到攻击目的。为了防止SQL注入攻击,PHP自带一个功能可以对输入的字符串进行处理,可以在较底层对输入进行安全上的初步处理,也即Magic Quotes。(php.ini magic_quotes_gpc)。如果magic_quotes_gpc选项启用,那么输入的字符串中的单引号,双引号和其它一些字符前将会被自动加上反斜杠\。

 但Magic Quotes并不是一个很通用的解决方案,没能屏蔽所有有潜在危险的字符,并且在许多服务器上Magic Quotes并没有被启用。所以,我们还需要使用其它多种方法来防止SQL注入。

 许多数据库本身就提供这种输入数据处理功能。例如PHP的MySQL操作函数中有一个叫mysql_real_escape_string()的函数,可将特殊字符和可能引起数据库操作出错的字符转义。

 看这段代码:
复制代码 代码如下:

//如果Magic Quotes功用启用
if (get_magic_quotes_gpc()) {
$name = stripslashes($name);
}else{
$name = mysql_real_escape_string($name);
}

mysql_query("SELECT * FROM users WHERE name='{$name}'");

 注意,在我们使用数据库所带的功能之前要判断一下Magic Quotes是否打开,就像上例中那样,否则两次重复处理就会出错。如果MQ已启用,我们要把加上的去掉才得到真实数据。

 除了对以上字符串形式的数据进行预处理之外,储存Binary数据到数据库中时,也要注意进行预处理。否则数据可能与数据库自身的存储格式相冲突,引起数据库崩溃,数据记录丢失,甚至丢失整个库的数据。有些数据库如 PostgreSQL,提供一个专门用来编码二进制数据的函数pg_escape_bytea(),它可以对数据进行类似于Base64那样的编码。

 如:
复制代码 代码如下:

// for plain-text data use:
pg_escape_string($regular_strings);

// for binary data use:
pg_escape_bytea($binary_data);

 另一种情况下,我们也要采用这样的机制。那就是数据库系统本身不支持的多字节语言如中文,日语等。其中有些的ASCII范围和二进制数据的范围重叠。

 不过对数据进行编码将有可能导致像LIKE abc% 这样的查询语句失效。
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Vue 프로젝트의 보안 위험 및 예방 방법 Vue 프로젝트의 보안 위험 및 예방 방법 Jun 11, 2023 pm 10:10 PM

Vue는 단일 페이지 애플리케이션을 구축하는 데 널리 사용되는 인기 있는 JavaScript 프레임워크입니다. Vue 프로젝트를 개발할 때 보안 문제는 주의해야 할 주요 문제입니다. 일부 부적절한 작업으로 인해 Vue가 공격자의 표적이 될 수 있기 때문입니다. 이 글에서는 Vue 프로젝트의 일반적인 보안 위험과 이를 방지하는 방법을 소개합니다. XSS 공격 XSS 공격은 공격자가 웹사이트의 취약점을 이용하여 사용자 페이지를 변조하거나 코드를 삽입하여 정보를 훔치는 것을 말합니다. 인 뷰

Nginx를 사용하여 LDAP 주입 공격으로부터 보호하는 방법 Nginx를 사용하여 LDAP 주입 공격으로부터 보호하는 방법 Jun 10, 2023 pm 08:19 PM

네트워크 보안 취약점이 증가함에 따라 LDAP 주입 공격은 많은 웹사이트에서 직면한 보안 위험이 되었습니다. 웹사이트 보안을 보호하고 LDAP 주입 공격을 방지하려면 몇 가지 보안 조치를 사용해야 합니다. 그 중 Nginx는 고성능 웹 서버이자 역방향 프록시 서버로서 우리에게 많은 편의성과 보호 기능을 제공할 수 있습니다. 이 기사에서는 Nginx를 사용하여 LDAP 주입 공격을 방지하는 방법을 소개합니다. LDAP 주입 공격 LDAP 주입 공격은 공격자가 LDAP 데이터베이스를 대상으로 하는 공격 방법입니다.

일반적인 네트워크 애플리케이션 취약점 분석 및 예방 일반적인 네트워크 애플리케이션 취약점 분석 및 예방 Jun 11, 2023 pm 08:36 PM

인터넷이 대중화되면서 점점 더 많은 네트워크 애플리케이션이 등장하고 있으며, 다양한 웹사이트, APP, 소규모 프로그램 등이 곳곳에 존재하고 있습니다. 네트워크 애플리케이션은 우리에게 편리함과 즐거움을 선사하지만 보안 위험도 가져옵니다. 네트워크 애플리케이션 취약점의 존재는 해커에 의해 쉽게 악용될 수 있으며, 데이터 유출, 개인정보 도용, 계정 도용, 네트워크 공격 등의 보안 문제로 이어질 수 있습니다. 이 기사에서는 일반적인 네트워크 애플리케이션 취약점부터 시작하여 원인을 분석하고 예방 조치를 제공합니다. SQL 주입 취약점 SQL 주입 취약점은 해커가 데이터베이스를 공격하기 위해 악용하는 일반적인 취약점입니다.

Nginx가 XML 주입 공격으로부터 보호하는 방법 Nginx가 XML 주입 공격으로부터 보호하는 방법 Jun 11, 2023 am 08:20 AM

XML 주입 공격은 공격자가 악의적으로 주입된 XML 코드를 응용 프로그램에 전달하여 무단 액세스를 얻거나 악의적인 작업을 수행하는 일반적인 형태의 네트워크 공격입니다. Nginx는 다양한 방법으로 XML 주입 공격으로부터 보호할 수 있는 인기 있는 웹 서버이자 역방향 프록시 서버입니다. 입력 필터링 및 유효성 검사 XML 입력을 포함하여 서버에 입력되는 모든 데이터는 필터링되고 유효성이 검사되어야 합니다. Nginx는 요청을 백엔드 서비스로 프록시하기 전에 처리할 수 있는 몇 가지 기본 제공 모듈을 제공합니다.

PHP 보안 보호: 주입 공격 방지 PHP 보안 보호: 주입 공격 방지 Jun 24, 2023 am 09:22 AM

오늘날의 온라인 세계에서 네트워크 보안은 주요 문제입니다. 개인 사용자와 기업 조직 모두 네트워크 시스템 보안에 특별한 주의를 기울여야 합니다. 특히 웹 사이트 개발 및 유지 관리 과정에서 주입 공격은 일반적인 보안 취약점 중 하나입니다. 웹사이트 개발에 널리 사용되는 프로그래밍 언어인 PHP는 주입 공격에 훨씬 더 취약합니다. 따라서 이 글에서는 인젝션 공격을 방지하기 위한 PHP 보안 보호 방법을 소개하겠습니다. 주입 공격이란 무엇입니까? 먼저 인젝션 공격은 해커가 네트워크 시스템의 취약점을 악용하는 공격을 말한다.

Nginx를 사용하여 아파치 플래그 주입 공격을 방지하는 방법 Nginx를 사용하여 아파치 플래그 주입 공격을 방지하는 방법 Jun 10, 2023 pm 03:17 PM

네트워크 보안 분야에서 Apache 플래그 삽입 공격은 비교적 일반적인 공격 방법입니다. 공격자는 특정 취약점이나 특정 HTTP 요청 매개변수를 사용하여 요청 헤더를 위조하여 서버를 속여 예상치 못한 작업을 수행하거나 악성 코드를 실행합니다. 이 공격을 방지하기 위해 Nginx를 역방향 프록시 서버로 사용하여 요청을 처리할 수 있습니다. 다음은 Nginx를 사용하여 Apache 플래그 삽입 공격을 방지하는 방법을 설명합니다. Nginx 역방향 프록시 설정 Nginx는 요청을 처리할 때 요청을 전달할 수 있습니다.

Go의 XSS(교차 사이트 스크립팅) 공격 예방: 모범 사례 및 팁 Go의 XSS(교차 사이트 스크립팅) 공격 예방: 모범 사례 및 팁 Jun 17, 2023 pm 12:46 PM

인터넷의 급속한 발전으로 인해 웹사이트 보안 문제는 온라인 세계에서 큰 문제가 되었습니다. XSS(교차 사이트 스크립팅) 공격은 웹사이트의 약점을 이용하여 웹페이지에 악성 스크립트를 삽입하여 사용자 정보를 도용하고 변조하는 일반적인 보안 취약점입니다. 효율적이고 안전한 프로그래밍 언어인 Go 언어는 XSS 공격을 방지하는 강력한 도구와 기술을 제공합니다. 이 기사에서는 Go 언어 개발자가 XSS 공격을 효과적으로 예방하고 해결하는 데 도움이 되는 몇 가지 모범 사례와 기술을 소개합니다. 모든 입력에 대해

PHP 언어 개발에서 로그 파일 주입 공격을 피하는 방법은 무엇입니까? PHP 언어 개발에서 로그 파일 주입 공격을 피하는 방법은 무엇입니까? Jun 10, 2023 pm 08:48 PM

인터넷 기술의 발달로 인해 웹사이트 보안 문제가 점점 더 주목을 받고 있습니다. 그 중 로그 파일 인젝션 공격은 공격자가 로그 파일의 출력 기능을 이용해 로그 파일에 악성 내용을 적어 공격 및 파괴 목적을 달성하는 공격이다. PHP 언어 개발에서는 로깅 기능을 사용하는 것이 매우 일반적입니다. 따라서 PHP 언어 개발에서 로그 파일 주입 공격을 방지하는 방법은 주목할 만한 문제입니다. 1. 로그 파일 주입 공격의 원리 PHP 개발에서는 많은 코드가 로그 기능을 사용하고 기록 시스템을 통해 실행됩니다.

See all articles