增加这三行php代码的安全性能和兼容性
所属分类:
软件教程 / 编程开发
阅读数:
1734
收藏 0赞 0分享
今天在sitepoint上看到一篇文章,其中有一段是介绍如何改进以下的这行php代码。这段代码经常被他们用来测试应聘者。
CODE:
<?
echo("<p>Search results for query: " .$_GET['query'] . ".</p>");
?>
我觉得这段代码非常适合用来测试一个php开发人员是否合格。因为这段代码并没有要求太多记忆上的东西(例如函数的记忆),但是对安全,性能,兼容性上都做了考察。
大家也想想看如何改进代码。我在后面给出修改后的代码。
CODE:
<?php
if (isset($_GET['query']))
{
echo '<p>Search results for query: ',
htmlspecialchars($_GET['query'], ENT_QUOTES), '.</p>';
}
?>
改进的地方有 :
把php短标签(<?)换成了长标签(<?php),因为并非所有php环境都支持短标签
增加判断该全局变量是否存在,防止在某些环境下出现notice错误,而且在当前的例子里如果query无则没必要输出
把echo的”(”去掉,echo不是一个函数,没必要使用“(”
把字符串两边的双引号换成了单引号,提高了性能。因为双引号里的内容会被尝试进行变量和转义字符的解析。
对query这个get变量进行html过滤。防止输出html,这可能会带来包括xss在内的一些危险
echo后面的字符串之间的间隔使用逗号而不是句号。因为句号之间的字符串会先被连接起来然后再输出,而,号只是按顺序输出。在这个例子里显然不需要先连接字符串。(这一点我平时倒没太注意)
Notepad文件怎么添加扩展名?
Notepad文件怎么添加扩展名?Notepad++想要设计文件扩展名,该怎么设置呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0赞 0分享
VB6.0怎么编程窗体卸载事件?
VB6.0怎么编程窗体卸载事件?VB6.0想要编写一个窗体卸载事件,该怎么编写呢?下面我们就来看看详细的教程,很简单,需要的朋友可以参考下
收藏 0赞 0分享
VB6.0工具箱怎么添加拓展控件快捷方式?
VB6.0工具箱怎么添加拓展控件快捷方式?VB6.0想要要将常用的空间添加到工具箱中方便使用,该怎么添加呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0赞 0分享
VB菜单项怎么添加图片?
VB菜单项怎么添加图片?VB菜单项为了更方便讲述其功能,我们可以直接插入图片,该怎么插入图片呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0赞 0分享
Flutter 下载安装教程
这篇文章主要介绍了Flutter 下载安装教程,想学习Flutter的朋友可以参考一下
收藏 0赞 0分享
VisualStudio常用标准控件功能介绍
Visua lStudio编程开发很常用,vs中的控件也很多,今天我们就来详细介绍一下常用标准控件的使用方法,很简单的基础知识,需要的朋友可以参考下
收藏 0赞 0分享
vb系统软键盘怎么调用?
vb系统软键盘怎么调用?vb中可以直接使用系统自带的软键盘,但是需要自己调出来使用,该怎么调用软键盘呢?下面我们就来看看信息的教程,需要的朋友可以参考下
收藏 0赞 0分享
Authorware课件怎么设计文件的属性?
Authorware课件怎么设计文件的属性?Authorware中制作好课件以后,想要设置属性,该怎么设置文件属性呢?下面我们就来看看详细的教程,需要的朋友可以参考下
收藏 0赞 0分享
Authorware怎么插入文本框?
Authorware怎么插入文本框?Authorware中想要插入文本框,该怎么插入呢?下面我们就来看看Authorware文本框的插入方法,需要的朋友可以参考下
收藏 0赞 0分享
查看更多