찾다
백엔드 개발PHP 튜토리얼PHP_php 스킬 중 잘 알려지지 않은 8가지 보안 기능 분석

이 글에서는 잘 알려지지 않은 PHP의 8가지 보안 기능을 예시와 함께 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.

보안은 프로그래밍에서 매우 중요한 측면입니다. 모든 프로그래밍 언어에는 프로그램의 안전을 보장하기 위해 많은 기능이나 모듈이 제공됩니다. 최신 웹사이트 애플리케이션에서는 전 세계 사용자로부터 입력을 받아야 하는 경우가 많지만 "해당 사용자가 입력한 데이터는 결코 신뢰할 수 없다"는 사실을 우리 모두 알고 있습니다. 따라서 다양한 웹 개발 언어에는 사용자가 입력한 데이터의 보안을 보장하기 위한 기능이 제공됩니다. 여기서는 유명한 오픈 소스 언어인 PHP의 유용한 보안 기능을 살펴보겠습니다.

PHP에는 몇 가지 유용한 기능이 오픈 소스로 공개되어 있어 SQL 주입 공격, XSS(Cross Site Scripting) 공격 등 다양한 공격으로부터 웹사이트를 보호하는 데 매우 편리합니다. 프로젝트 보안을 보장하기 위해 PHP에서 일반적으로 사용되는 기능을 살펴보겠습니다. 이것은 전체 목록이 아니며 귀하의 i 프로젝트에 유용할 것으로 생각되는 일부 기능일 뿐입니다.

1.mysql_real_escape_string()

이 기능은 PHP에서 SQL 주입 공격을 방지하는 데 매우 유용합니다. 이 함수는 작은따옴표, 큰따옴표, 백슬래시 등과 같은 일부 특수 문자에 백슬래시를 추가하여 이 데이터를 쿼리하기 전에 사용자가 제공한 입력이 깨끗한지 확인합니다. 단, 이 기능은 데이터베이스에 연결한다는 전제 하에 사용하고 있다는 점을 참고하시기 바랍니다.
그러나 mysql_real_escape_string()을 사용하는 것은 더 이상 권장되지 않습니다. 모든 새로운 애플리케이션은 데이터베이스 작업을 수행하기 위해 PDO와 같은 함수 라이브러리를 사용해야 합니다. 즉, SQL 주입 공격을 방지하기 위해 이미 만들어진 명령문을 사용할 수 있습니다.

2. 속눈썹 추가()

이 함수의 원리는 mysql_real_escape_string()과 유사합니다. 단, php.ini 파일에서 "magic_quotes_gpc" 값이 "on"인 경우에는 이 기능을 사용하지 마세요. Magic_quotes_gpc의 기본값은 on이며, 이는 모든 GET, POST 및 COOKIE 데이터에 대해 자동으로 addlashes()를 실행합니다. Magic_quotes_gpc에 의해 이스케이프된 문자열에는 addlashes()를 사용하지 마십시오. 이렇게 하면 이중 이스케이프가 발생하게 됩니다. get_magic_quotes_gpc() 함수를 사용하여 활성화 여부를 확인할 수 있습니다.

3.htmlentities()

이 기능은 사용자가 입력한 데이터를 필터링하는 데 매우 유용합니다. 일부 특수 문자를 HTML 엔터티로 변환합니다. 예를 들어, 사용자가 를 입력하면 엔터티>로 변환됩니다.

4.htmlspecialchars()

HTML에서 일부 특정 문자는 특별한 의미를 갖습니다. 문자의 원래 의미를 유지하려면 해당 문자를 HTML 엔터티로 변환해야 합니다. 이 함수는 변환된 문자열을 반환합니다. 예를 들어 '&'(앰퍼샌드)는 '&'

로 변환됩니다.

ps: 원문에 오류가 있습니다. 올려주신 유진님께 진심으로 감사드립니다. 수정되었으며 이 기능에 대한 일반적인 변환 문자도 첨부됩니다:

수행된 번역은 다음과 같습니다.
'&'(앰퍼샌드)는 '&'가 됩니다
ENT_NOQUOTES가 설정되지 않은 경우 '"'(큰따옴표)는 '"'가 됩니다.
"'"(작은따옴표)는 ENT_QUOTES가 설정된 경우에만 '''(또는 ')가 됩니다.
'이 됩니다. '>'(보다 큼)은 '>'

이 됩니다.

5.strip_tags()

이 함수는 문자열에서 모든 HTML, JavaScript 및 PHP 태그를 제거할 수 있습니다. 물론 함수의 두 번째 매개변수를 설정하여 일부 특정 태그가 표시되도록 할 수도 있습니다.

6.md5()

보안 관점에서 일부 개발자가 간단한 비밀번호를 데이터베이스에 저장하는 행위는 권장되지 않습니다. md5() 함수는 주어진 문자열의 32자 md5 해시를 생성할 수 있으며 이 프로세스는 되돌릴 수 없습니다. 즉, md5()의 결과에서 원래 문자열을 가져올 수 없습니다.
현재 이 기능은 오픈 소스 데이터베이스가 해시 값의 일반 텍스트를 역검사할 수 있기 때문에 안전한 것으로 간주되지 않습니다. 여기에서 MD5 해시 데이터베이스 목록을 찾을 수 있습니다

7.sha1()

이 함수는 md5()와 유사하지만 다른 알고리즘을 사용하여 40자 SHA-1 해시를 생성합니다(md5는 32자 해시를 생성합니다). 절대적인 안전을 위해 이 기능에 의존하지 마십시오. 그렇지 않으면 예상치 못한 결과가 발생할 수 있습니다.

8. intval()

아직 웃지 마세요. 이 기능은 보안과 관련이 없다는 것을 알고 있습니다. intval() 함수는 변수를 정수 유형으로 변환합니다. 특히 ID 및 연령과 같은 데이터를 구문 분석할 때 PHP 코드를 더욱 안전하게 만들 수 있습니다.

여기에 원본 영어 주소가 첨부되어 있습니다: http://www.pixelstech.net/article/1300722997-Useful-functions-to-provide-secure-PHP-application

이 기사가 모든 사람의 PHP 프로그래밍 설계에 도움이 되기를 바랍니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

See all articles

핫 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를 무료로 생성하십시오.

뜨거운 도구

맨티스BT

맨티스BT

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

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1

메모장++7.3.1

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