>  기사  >  백엔드 개발  >  PHP는 미리 정의된 문자 앞에 백슬래시를 추가하는 addlashes() 함수를 반환합니다.

PHP는 미리 정의된 문자 앞에 백슬래시를 추가하는 addlashes() 함수를 반환합니다.

黄舟
黄舟원래의
2017-11-02 09:45:442154검색

각 큰따옴표(") 앞에 백슬래시 추가:

<?php 
$str = addslashes(&#39;What does "yolo" mean?&#39;);
echo($str); 
?>

정의 및 사용법

addslashes() 함수는 미리 정의된 문자 앞에 백슬래시가 있는 문자열을 반환합니다.

미리 정의된 문자는 다음과 같습니다.

작은따옴표(' )

큰따옴표(")

백슬래시()

NULL

팁: 이 함수는 데이터베이스 쿼리문 문자열뿐만 아니라 데이터베이스에 저장된 문자열에 적합한 문자를 준비하는 데 사용할 수 있습니다.

참고: 기본적으로 PHP 지시어 Magic_quotes_gpc가 켜져 있으며 모든 GET, POST 및 COOKIE 데이터에 대해 자동으로 addlashes()를 실행합니다. Magic_quotes_gpc에 의해 이스케이프된 문자열에는 addlashes()를 사용하지 마십시오. 이렇게 하면 이중 이스케이프가 발생하게 됩니다. 이러한 상황이 발생하면 함수 get_magic_quotes_gpc()를 사용하여 이를 감지할 수 있습니다.

Syntax

addslashes(string)
Parameters Description
string 필수입니다. 이스케이프할 문자열을 지정합니다.

기술 세부 정보

반환 값: 이스케이프된 문자열을 반환합니다.
PHP 버전: 4+

更多实例

向字符串中的预定义字符添加反斜杠:

<?php
$str = "Who&#39;s Peter Griffin?";
echo $str . " This is not safe in a database query.<br>";
echo addslashes($str) . " This is safe in a database query.";
?>

php addslashes函数的作用是在预定义的字符前面加上反斜杠,这些预定义字符包括:

单引号(')

双引号(")

反斜杠(\)

NULL

addslashes函数经常使用在向数据库插入数据时,比如有一个字符串

$str="my name&#39;s wxp";

现在要将这个字符串插入到数据库表中,由于该字符串有单引号',这样很可能与mysql拼接字符串的单引号'冲突,导致SQL语句不正确,也就无法正常执行插入操作,此时我们需要使用addslashes函数处理这个字符串。如:

$str="my name&#39;s wxp";echo addslashes($str);//输出my name\'s wxp

然后在拼接mysql字符串:

$sql="insert into student(student_name)values(&#39;".addslashes($str)."&#39;)";
mysql_query($sql);

此时字符串被插入到数据库,那么大家是否知道插入的字符串是带反斜杠还是不带反斜杠呢?恐怕很多人都会认为肯定是带反斜杠的字符串。其实这个答案是错误的,插入的字符串是没有带反斜杠。至于为什么插入的字符串在数据库中是没有加反斜杠,请大家继续看下面讲解。

如果字符串$str="my name's wxp"是使用POST和GET提交的数据,这个时候插入数据库中的数据是带反斜杠的,由此可知addslashes只是在POST和GET数据插入数据库时才会把反斜杠同时插入到数据库,其他情况下不会将反斜杠插入到数据库。

위 내용은 PHP는 미리 정의된 문자 앞에 백슬래시를 추가하는 addlashes() 함수를 반환합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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