>  기사  >  백엔드 개발  >  php Stripslashes() 함수와 addlashes() 함수의 차이점에 대한 자세한 예

php Stripslashes() 함수와 addlashes() 함수의 차이점에 대한 자세한 예

怪我咯
怪我咯원래의
2017-05-22 11:22:341661검색

이전에 PHP의 addslashes() 함수와 Stripslashes() 함수의 기능과 일부 사용법을 소개했습니다. 이 글에서는 PHP stripslashes() 함수와 addlashes() 함수를 소개합니다. 차이점.

함수 이름 차이: 스트립(strip) 슬래시(slash) 추가(add) 슬래시(slash)이므로 둘 중 하나는 슬래시를 제거하고 다른 하나는 추가 추가 슬래시는 반대 효과를 갖습니다.

사용 시나리오: 실제로 이 두 함수는 데이터베이스 작업과 같이 특수 문자를 변환해야 하는 일부 데이터 처리에 주로 사용됩니다. 이와 같은 작은 따옴표 특수 문자는 이스케이프되어 저장되며, 읽을 때

데이터베이스에서 이 이스케이프된 특수 문자를 역 이스케이프해야 합니다.

mysql에 데이터를 쓰면 다음과 같습니다.

mysql_query("update table set `title`='kuhanzhu's blog'");

오류가 발생합니다. ASP와 마찬가지로 데이터베이스는 작은따옴표에 알레르기가 있습니다. 이때 addlashes가 가장 중요하며 asp의 replacement("'",""","kuhanzhu's blog")와 동일한 기능을 가지고 있습니다.

보안을 위해 PHP에서는 Magic_quotes_gpc = On을 도입합니다. 함수를 사용하면 별도의 처리 없이 데이터베이스에 작은따옴표를 직접 삽입할 수 있습니다. 그런 다음 Off의 경우 운영 환경을 맹목적으로 신뢰하는 대신 작은따옴표 문제를 고려해야 합니다.

magic_quotes_gpc = On일 때 데이터. addlashes()를 사용하여 처리한 내용은 '' 형태로 데이터베이스에 저장됩니다. 이때 직접 출력해 보면 예상한 것보다 많은 내용이 있다는 것을 알 수 있으므로 Remove(Remove)할 수 있는 Stripslashes()가 나타납니다. str_replace("", "",$Str))

magic_quotes_gpc = Off일 때, addlashes()로 처리된 데이터는 위의 설명 없이 데이터베이스에 저장됩니다. 이때 데이터를 직접 출력하는 경우에는 Stripslashes() 및 Stripslashes()를 사용할 필요가 없습니다. 반대로 직접 메모리:addlashes()는 하나를 추가하고,stripslashes()는 하나를 제거합니다. 🎜>

그러면 언제 사용해야 할까요?

간단하게 말하면

magic_quotes_gpc = On일 때 시스템은 작은따옴표 등의 문제를 자동으로 처리하지 않습니다. addlashes() 및 Stripslashes()를 사용하는지 여부는 중요합니다. 그러나 데이터를 추가할 때 addlashes()를 사용하는 경우 데이터를 표시할 때

magic_quotes_gpc = Off인 경우에는 Stripslashes()를 사용해야 합니다. , 시스템은 작은 따옴표와 같은 문제를 처리하지 않으므로 데이터를 삽입할 때 addlashes()를 사용해야 하고, 데이터를 표시할 때는 Stripslashes()를 사용할 필요가 없습니다.

<.> Magic_quotes_gpc가 On인지 Off인지에 관계없이 데이터를 추가할 때 addlashes()를 사용합니다. ()를 사용해야 하며, Off일 때는 Stripslashes()를 사용할 수 없습니다.

On인지 Off인지 확인하는 방법은 무엇인가요?

get_magic_quotes_gpc() 함수의 코드는 다음과 같습니다. addlashes() 함수 및 Stripslashes() 함수 예제

위 내용은 php Stripslashes() 함수와 addlashes() 함수의 차이점에 대한 자세한 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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