首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

php中的双引号与单引号的基本使用

我们可以直接在函数中使用字符串,或者把它存储在变量中 字符串是一个非常要的知识,在开发中,有的使用单引号,有的使用双引号,这个是有区别的 在PHP语言中声明字符串有三种方式 用单引号声明 用双引号声明...用字界符声明(这个需要输入非常大段的字符串时才使用,不常用) 单引号声明 用英文半脚的单引号,将字符串包起来,字符串变量用于包含有字符的值 <?...,后面不想有空格,可以拿双大括号将变量包起来 双引号解析转义字符,单引号不解析转义字符,但单引号能解析'和\ 单引号效率要高于双引号,可以尽可能使用单引号 双引号和单引号可以互插,双引号中插入单引号,单引号中插入变量...同理可推,单引号当中要插入一个单引号显示出来的时候,也可以在单引号声明的字符串中的单引号前面加上(反斜线,转义字符),将单引号的意义(限定字符区间)去掉 6....> 以上就是关于php当中双引号与单引号的使用,在面试的时候,有时候也会问到 而在开发当中,也是很常用的

57820

解决ThinkPHP升级5.1后输出字符被转义的问题。

最近给博客升级框架,由于从5.0过渡到5.1要修改的地方还蛮多的,加上之前一些代码在实际运行中略显低效,索性就把后端重构一下。...把一些关键部位调整到位后刷新页面,发现原先用于输出备案信息的地方被转义输出成字符串了,印象中TP模版输出默认是使用htmlspecialchars函数的,既然能原样输出字符串,所以和后端改造的关联不大。...TP最近升级的很是生猛,只好去翻下手册了,在模版章节,使用函数部分,TP给了这样一个说法:为了避免出现XSS安全问题,默认的变量输出都会使用 htmlentities 方法进行转义输出。...如果不想被转义,那只需要在变量后面加上raw方法即可,如:{$anji|raw} 除了raw方法,TP还给了一个配置方法,在template.php配置中添加一项'default_filter' =>...htmlentities()和htmlspecialchars()的区别。 一直用htmlspecialchars函数,htmlentities别说用了,一点印象都没有(汗,还是手册看少了)。

3K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在PHP中,cookie和session的使用

    PHP工作原理:PHP通过setcookie函数进行Cookie的设置,任何从浏览器发回的Cookie,PHP都会自动的将他存储在$_COOKIE的全局变量之中,因此我们可以通过$_COOKIE['key...用途:PHP中的Cookie具有非常广泛的使用,经常用来存储用户的登录信息,购物车等,且在使用会话Session时通常使用Cookie来存储会话id来识别用户,Cookie具备有效期,当有效期结束之后,...header("Set-Cookie:cookie_name=value"); cookie的删除与过期时间 在PHP中删除cookie也是采用setcookie函数来实现。...一般情况下,大多是使用所有路径的,只有在极少数有特殊需求的时候,会设置路径,这种情况下只在指定的路径中才会传递cookie值,可以节省数据的传输,增强安全性以及提高性能。...使用session 在PHP中使用session非常简单,先执行session_start方法开启session,然后通过全局变量$_SESSION进行session的读写。

    4K70

    php字符串中转义成特殊字符实例讲解

    在php的字符串使用时,我们有学会一些转义字符,相信大家在记忆这些知识点的时候费了不少的功夫。...本篇我们为大家带来的是字符串的转义方法,涉及到特殊字符的使用,主要有两种方法可以实现:mysql库函数和转义函数。下面就这两种方法,在下文中展开详细的介绍。...1、转义字符说明 双引号中,所有转义字符都可正常使用。 单引号中,只有单引号转义字符可以使用("),别的都不可使用。...遇到这种情况时可以使用函数 get_magic_quotes_gpc() 进行检测。即get_magic_quotes_gpc()返回false时,再使用addslashes()进行特殊字符转义。...() 5.addcslashes()和stripcslashes() 6.htmlentities() 和html_entity_decode() 7.htmlspecialchars()和htmlspecialchars_decode

    1.9K00

    PHP中处理html相关函数集锦

    预定义的字符是: 3、htmlentities() 函数把字符转换为 HTML 实体。 4、addslashes() 函数在指定的预定义字符前添加反斜杠。...这些预定义字符是: 单引号 (‘) 双引号 (“) 反斜杠 (\) NULL 5、stripslashes 去掉字符串中的反斜线字符。若是连续二个反斜线,则去掉一个,留下一个。...stripslashes() 函数删除由 addslashes() 函数添加的反斜杠。 6、strip_tags 去掉字符串中任何 HTML标记和PHP标记,包括标记封堵之间的内容。...巧妙使用集锦: 比如你要和dede一样存入的是html实体,那么你可以把做如下处理 $content=htmlspecialchars($_POST[‘content’]); 那么你想去除这样的转换,就可以使用...PS:dedecms中村文章内容,存入数据库是经过htmlspecialchars过滤的,而discuz中存入的是html字符,我感觉要把过滤做好,存入什么格式都是可以的

    2.2K60

    有关PHP、HTML单引号、双引号转义以及转成HTML实体的那些事!

    一、单引号和双引号转义在PHP的数据存储过程中用得比较多,即往数据库里面存储数据时候需要注意转义单、双引号; 先说几个PHP函数: 1、addslashes — 使用反斜线引用(转义)字符串;   返回字符串...这些字符是单引号(')、双引号(")、反斜线(\)与 NUL(NULL 字符)。 一个使用 addslashes() 的例子是当你要往数据库中输入数据时。...例如,将名字 O'reilly 插入到数据库中,这就需要对其进行转义。大多数据库使用 \ 作为转义符:O\'reilly。这样可以将数据放入数据库中,而不会插入额外的 \。...当 PHP 指令 magic_quotes_sybase 被设置成on 时,意味着插入 ' 时将使用 ' 进行转义。...()将实体转成HTML代码,函数1的反函数 3、 htmlentities()这个是全部转换html实体,和htmlspecialchars()区别在于,这个函数是转义全部的字符,而htmlspecialchars

    4K70

    浅谈xss——跨站脚本攻击(四)

    函数 B .PHP输出到JS代码中,或者开发Json API的,则需要前端在JS中进行过滤: 1 .尽量使用innerText (IE )和textContent (Firefox ) ,也就是jQuery...的text ( )来输出文本内容 2 .必须要用innerHTML等等函数,则需要做类似php的 htmlspecialchars的过滤 C .其它的通用的补充性防御手段 1 .在输出html时,加上....在开发API时,检验请求的Referer参数 (作用:可以在一定程度上防止CSRF攻击) (缺陷:IE或低版本的浏览器中,Referer参数可以被伪造) 这里我们选用htmlentities()函数进行测试...存储型xss漏洞防范 存储型XSS对用户的输入进行过滤的方式和反射型XSS相同,这里我们使用htmlspecialchars()函数进行演示: htmlentities ( ) :把预定义的字符 "<...;" (小于)和 ">" (大于)转换为 HTML 实体 htmlspecialchars和 htmlentities的区别: htmlspecialchars 只转义 & ; 、 " 、'

    42520

    goto语法在PHP中的使用

    goto语法在PHP中的使用 在C++、Java及很多语言中,都存在着一个神奇的语法,就是goto。顾名思义,它的使用是直接去到某个地方。从来代码的角度来说,也就是直接跳转到指定的地方。...我们的PHP中也有这个功能,我们先来看看它是如何使用的: goto a; echo "1"; // 不会输出 a: echo '2'; // 2 代码运行到goto位置时,就跳转到了a:所在的代码行并继续执行下去...,也就是说无法跳出一个函数或类方法,也无法跳入到另一个函数 无法跳入到任何循环或者 switch 结构中 跳出循环或者 switch,通常的用法是用 goto 代替多层的 break 比如以下的代码都是无效的...另外还需要注意的,使用goto可能什么引起死循环,如下所示: b: echo 'b'; goto b; 代码执行到goto时,跳回了之前的b标签行,然后继续向下执行,又到goto了,成为了一个死循环...这就要仁者见仁智者见智的进行选择了,目前大多数语言的文档中都并不是很提倡使用这个语法,包括PHP。

    2.7K10

    trait能力在PHP中的使用

    trait能力在PHP中的使用 相信大家对trait已经不陌生了,早在5.4时,trait就已经出现在了PHP的新特性中。当然,本身trait也是特性的意思,但这个特性的主要能力就是为了代码的复用。...为了解决C++多重继承的混乱问题,大部分语言都是单继承多接口的形式,但这也会让一些可以复用的代码必须通过组合的方式来实现,如果要用到组合,不可避免的就要实例化类或者使用静态方法,无形中增加了内存的占用。...如果注释掉testB类中的test()方法,则会报错。因为程序无法区分出你要使用的是哪一个trait中的test()方法。我们可以使用insteadof来指定要使用的方法调用哪一个trait。...最后,trait中也是可以定义抽象方法的。这个抽象方法是引用这个trait的类所必须实现的方法,和抽象类中的抽象方法效果一致。...当然,越是灵活的东西越需要我们去弄明白它的一些使用规则,这样才能避免一些不可预见的错误。

    1.9K10

    PHP过滤表单字段

    PHP过滤表单字段 函数名 释义 介绍 htmlspecialchars 将与、单双引号、大于和小于号化成HTML格式 &转成& "转成" ' 转成' strip_tags 去掉HTML及PHP标记 去掉字符串中任何 HTML标记和PHP标记,包括标记封堵之间的内容。...magic_quotes_gpc函数在PHP中的作用是判断解析用户提示的数据,如包括有:post、get、cookie过来的数据增加转义字符“\”,以确保这些数据不会引起程序,特别是数据库语句因为特殊字符引起的污染而出现致命的错误...在magic_quotes_gpc=On的情况下,如果输入的数据有 单引号(’)、双引号(”)、反斜线()与 NUL(NULL 字符)等字符都会被加上反斜线。...正是因为这个选项必须为On,但是又让用户进行配置的矛盾,在PHP6中删除了这个选项,一切的编程都需要在magic_quotes_gpc=Off下进行了。

    3.1K20

    PHP代码审计笔记--XSS跨站脚本

    >'> 获取参数,在一个input元素的属性里输出这个变量,我们注意到这里使用的是单引号闭合,而函数默认只是转化双引号("), 不对单引号(')做转义。 因此,可以用单引号闭合, 测试语句: ?...常见的xss修复方法如下: 1、PHP提供了两个函数htmlentities()和htmlspecialchars() ,把一些预定义的字符转换为 HTML 实体。 防御代码示例: 2、其它的通用的补充性防御手段 1.在输出html时,加上Content Security Policy的Http Header (作用:可以防止页面被XSS攻击时,嵌入第三方的脚本文件等) (缺陷...:IE或低版本的浏览器可能不支持) 2.在设置Cookie时,加上HttpOnly参数 (作用:可以防止页面被XSS攻击时,Cookie信息被盗取,可兼容至IE6) (缺陷:网站本身的JS代码也无法操作...Cookie,而且作用有限,只能保证Cookie的安全) 3.在开发API时,检验请求的Referer参数 (作用:可以在一定程度上防止CSRF攻击) (缺陷:IE或低版本的浏览器中,Referer参数可以被伪造

    91631

    对PHP安全相关的函数

    addslashes() : 在将一些数据插入到数据库中时,这个函数会非常有用,它可以在单引号前加上反斜杠,使得数据在插入时不会出现错误。...但是它的使用与php.ini 中的一项设置有关系 — magic_quotes_gpc 1....htmlspecialchars(): 和上面的函数是一样的,但是它更常用一些,因为 htmlentities() 是将所有的有在html 标准中定义了的字符转换成他们对应的html实体,这样会是你的输出缺乏易读性...例如: & (和号) 成为 & ” (双引号) 成为 ” ‘ (单引号) 成为 ‘ < (小于) 成为 < > (大于) 成为 > 所以,在一些项目中,我还是常常使用 htmlspecialchars...他在安全这一方面做得更具体一些。 strip_tags(): 一般在输出时使用,将HTML、XML 以及 PHP 的标签剥去。

    91620

    php 自带过滤和转义函数

    分类: 函数名 释义 介绍 htmlspecialchars 将与、单双引号、大于和小于号化成HTML格式 &转成&“转成"‘ 转成'转成> htmlentities...addslashes 单双引号、反斜线及NULL加上反斜线转义 被改的字符包括单引号 (‘)、双引号(“)、反斜线 backslash (\) 以及空字符NULL。...stripslashes 去掉反斜线字符 去掉字符串中的反斜线字符。若是连续二个反斜线,则去掉一个,留下一个。若只有一个反斜线,就直接去掉。...nl2br() 将换行字符转成 strip_tags 去掉HTML及PHP标记 去掉字符串中任何 HTML标记和PHP标记,包括标记封堵之间的内容。...base64_decode base64解码 对使用 MIME base64 编码的数据进行解码 base64_encode base64编码 使用 MIME base64 对数据进行编码 rawurldecode

    1.3K30

    Redis 在PHP中的使用笔记

    (Windows+Linux) 继续推荐: phpredis 的使用文档(英文) phpredis 中文手册 ——《redis中文手册》 php版 【phpredis 中文手册下载】 —— 链接...Redis 类的命名空间是根 \ phpredis 的命令和参数和 redis.io 中的实际命令对应 ♫ 笔记 ①....事实上,更多时候 Redis 是在数据库和代码中间作为一个中间件使用,如果你发现你目前的数据库出现瓶颈,那么你就可以通过 Redis 来优化 ♬ 代码使用 可以参考视频 —— 【php 操作 redis...四种NoSQL数据库的比较: ? ②. rpoplpush 的使用场景 ? ③. Redis 在现实世界的 5 个用法 全页面缓存 排行榜 会话Session存储 队列 pub/sub 附录 ①....Redis Cluster 着眼于扩展性,在单个 redis 内存不足时,使用 Cluster 进行分片存储 Redis 学习笔记(十三)Redis Sentinel 介绍与部署 Redis 学习笔记

    99050

    final关键字在PHP中的使用

    final关键字在PHP中的使用 final关键字的使用非常简单,在PHP中的最主要作用是定义不可重写的方法。什么叫不可重写的方法呢?就是子类继承后也不能重新再定义这个同名的方法。...() function testA(){ echo 'This is class childA', PHP_EOL; } } 而如果在类定义前加上这个关键字的话,则类也是不可继承的...答案当然是否定的,接口的意义本身就是定义一个契约让实现类来实现,如果定义了final关键字,那么接口的意义就不存在了,所以从语言层面来说接口以及接口中的方法就不能使用final关键字。...Fatal error: Access type for interface method C::testC() must be omitted final function testC(); } 在Java...中,final还可以用来定义常量,但在PHP中,类常量是通过const来定义的。

    2.3K20

    在PHP中strpos函数的正确使用方式

    首先简单介绍下 strpos 函数,strpos 函数是查找某个字符在字符串中的位置,这里需要明确这个函数的作用,这个函数得到的是位置。 如果存在,返回数字,否则返回的是 false。...而很多时候我们拿这个函数用来判断字符串中是否存在某个字符,一些同学使用的姿势是这样的 // 判断‘沈唁志博客’中是否存在‘博客’这个词 if (strpos('沈唁志博客', '博客')) {...echo '不存在'; } 输出了’不存在’;原因是因为 ‘沈’ 在‘沈唁志博客’中的第 0 个位置;而 0 在 if 中表示了 false,所以,如果用 strpos 来判断字符串中是否存在某个字符时...必须使用===false 必须使用===false 必须使用===false 重要的事情说三遍,正确的使用方式如下 // 判断‘沈唁志博客’中是否存在‘博客’这个词 if (strpos('沈唁志博客...原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:在PHP中strpos函数的正确使用方式

    5.2K30
    领券