`

PHP代码的优与劣

    博客分类:
  • php
阅读更多

简介

一段简单的代码却能有那么多的“考点”,你能答出几个呢?

  我在SitePoint做面试官的时候一定会问的问题是:你认为PHP代码 的优劣体现在哪里?因为这个问题可以让我大体知道应聘者是哪种类型的程序员,而不是单纯地考察他对PHP函数的掌握程度(这一点Zend的PHP认证做得不错,雅虎的PHP程序员面试题也属于此类)。

  重要的是,这个问题可以让我知道应聘者是否经历过这样的事情——从一个懒散程序员手中接过一段凌乱的代码 进行重用,或者要帮助团队中的其他成员来处理这类事情。

  诚然,对于这个问题我自己并没有一个满意的答案,不过我知道哪些答案是我想听到的:

  优良的PHP代码 应该是结构化的。大段的代码应该被分割整理成一个个函数或方法,而那些不气眼的小段代码则应该加上注释,以便日后清楚它们的用途。而且应该尽可能地把前台代码如HTML、CSS、Javascript等从程序中分离出来。PHP的面向对象编程 特性可以很好地帮助程序员将代码整理有序。

  优良的PHP代码 应该是规范化的。无论是为变量名和函数名设定命名规则,还是对一些会重复使用的过程如数据库操作和错误处理进行标准化,抑或是简单到规定好代码是怎样缩进的,这些规范化都可以让代码的可读性大大提高。

  优良的PHP代码 应该是自适应的。PHP有许多特性如magic quotes和short tags,这些特性的打开和关闭会影响到程序的运行。所以,一个好的程序员应该在他的代码中加如适当的语句来使程序能够根据环境进行调整。

  优良的PHP代码 应该是安全的。虽然PHP是一种高效、灵活的语言,没有固定的框架,但却把安全问题留给了程序员们。对潜在安全漏洞的深刻理解,如跨站脚本攻击(XSS)、跨站请求伪造(CSRF)、代码注入漏洞、字符编码循环漏洞等,对于今天的专业程序员来说是至关重要的。

  当应聘者在回答这些问题的时候,我就能清楚地知道是否该录用他。当然,有时程序员并不能很好地阐明这个问题,这时我们会让他们做一些PHP测试。测试中的许多问题表面上看起来非常简单,但这也给了应聘者们一个展现自我的机会,因为只要观察得仔细,就能找出问题。

  下面这一小段“劣质”的PHP代码 是一道简化了的测试题。这种问题就像在问:你该怎样优化这段代码?

<?
echo("<p>Search results for query: " .
    $_GET['query'] . ".</p>");
?>

  这段代码 的主要问题在于它把用户提交的数据直接显示到了网页上,从而产生XSS漏洞。其实有很多方法可以填补这个漏洞。那么,什么代码是我们想要的呢?

<?
echo("<p>Search results for query: " .
    htmlspecialchars($_GET['query']) . ".</p>");
?>

  这是最低要求。XSS漏洞用htmlspecialchars函数填补了,从而屏蔽了非法字符。

<?php   
if (isset($_GET['query']))  
{  
  echo '<p>Search results for query: ',  
      htmlspecialchars($_GET['query'], ENT_QUOTES), '.</p>';  
}  
?> 

  能写出这样代码 的人应该是我想要录用的人了。

  • <?被替换成了<?php ,这样更符合XML规范。
  • 在输出$_GET['query']的值之前先判断它是否为空。
  • echo命令中多余的括号被去掉了。
  • 字符串用单引号限定,从而节省了PHP从字符串中搜索可替换的变量的时间。
  • 用逗号代替句号,节省了echo的时间。
  • 将ENT_QUOTES标识传递给htmlspecialchars函数,从而保证单引号也会被转义。虽然这并是最主要的,但也算是一个良好习惯。

  可惜的是,能给出这样让人满意答复的程序员少之又少。我们花了3个月的时间才招聘到让我们满意的程序员。

  那么,你会怎样回答文章开头提出的问题呢?你认为PHP代码 的优劣体现在哪里?你认为一个PHP程序员还应具有哪些品质?

分享到:
评论

相关推荐

    php优质代码

    本人整理的优质代码 ,基本上是写PHP程序需要的一些代码 ,有需要的PY可以拿去

    php聊天代码 韩国开源系统

    php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码php聊天代码...

    代码规范+-+PHP+代码风格检查_修复工具_修复脚本_php_php编程_

    在实践中,持续集成(CI/CD)流程常常与代码风格检查相结合,每次提交时都进行风格检查,确保新代码符合规范。这有助于保持代码库的整洁,降低维护成本,并提升团队合作的效率。 总的来说,PHP编程规范和相关的代码...

    php代码编写器

    在Sublime Text中编写Java代码,可以享受到与PHP类似的编辑体验,如代码高亮、自动完成等,同时也可以通过插件增加Java开发的功能,如Javatar提供Java相关的代码补全和错误检查。 总的来说,一个好的代码编写器,如...

    php统计php代码行数程序

    在PHP编程环境中,有时我们需要了解项目中PHP代码的规模,比如为了分析代码复杂性、评估开发工作量或者优化性能。这时,我们可以编写一个程序来统计PHP代码的行数。下面将详细讲解如何实现这样一个功能,以及相关的...

    360通用php防护代码

    360通用php防护代码 -----------------使用方法------------------------------------------------------------------ 1.将360_safe3.php传到要包含的文件的目录 2.在页面中加入防护,有两种做法,根据情况二选一...

    优秀的PHP程序员至少应该了解PHP代码的优缺点

    标题和描述中提到的核心知识点是,优秀的PHP程序员需要理解PHP代码的优缺点,这涉及到代码的结构化、规范化、自适应性和安全性。以下是对这些方面更详细的解释: 1. 结构化代码:良好的PHP代码应该遵循模块化和分层...

    PHP精粹编写高效PHP代码 书本源码

    8. **PHP与Web安全**:安全是任何Web开发的重要一环。书中可能讲解了如何防止SQL注入、XSS攻击、CSRF等安全问题,以及使用PHP的安全功能,如过滤输入、加密敏感数据等。 9. **测试驱动开发**:TDD(Test-Driven ...

    优一家教网源代码php

    【优一家教网源代码PHP】是一套完整的网站开发资源,专为建立家教服务平台而设计。这个源代码是用PHP编程语言编写的,PHP是一种广泛使用的开源脚本语言,尤其在Web开发领域中占据重要地位。其核心优势在于其灵活性、...

    PHP在线压缩代码PHP在线压缩代码

    PHP在线压缩代码PHP在线压缩代码PHP在线压缩代码PHP在线压缩代码

    易语言PHP代码翻译器源码

    《易语言PHP代码翻译器源码解析与应用探讨》 在IT行业中,代码翻译器扮演着重要的角色,它能够帮助开发者理解和转化不同编程语言之间的代码,从而提高开发效率和跨平台兼容性。本文将深入探讨易语言PHP代码翻译器...

    PHP劫持跳转代码

    下面我们将详细探讨PHP劫持跳转的常见方式、如何检测与防止这类问题,以及如何处理已知的"PHP劫持跳转代码.php"文件。 1. **PHP跳转函数**: - `header()` 函数是PHP中最常见的实现跳转的函数,例如 `header(...

    PHP源码 php代码 10个救人的php代码

    10个救人的php代码 php源码 php代码

    php代码管理系统 管理你自己的代码

    一、PHP基础与代码管理的重要性 PHP,全称为“Hypertext Preprocessor”(超文本预处理器),是一种开放源码的服务器端脚本语言,尤其适合Web开发并可嵌入HTML中。它的灵活性和强大的功能使得PHP成为许多网站和应用...

    PHP代码审计文档.zip

    第19课:PHP代码审计之会话认证漏洞mp4 第18课:PHP伪协议mp4 第17课:PHP弱类型mp4 第16课:PHP代码审计之反序列化漏润mp4 第15课:PHP代码审计之变量盖漏洞mp4 第14课PHP代码审计之任意文件读取及删除漏洞mp4 第13课...

    PHP加密软件PHP代码加密

    "PHP加密软件"和"PHP代码加密"就是针对这一需求提出的解决方案,旨在保护源代码不被未经授权的人查看、复制或修改,确保商业机密和知识产权的安全。 PHP加密技术主要有以下几种形式: 1. **源代码混淆**:这是最...

    Oracle PHP代码生成器(专业的为Oracle生成代码)--- PHP为Oracle生成高质量代码的工具

    PHP的威力不用我多说,PHP与数据库的关系更不用我说,玩过的人都知道。 之前介绍过一款PHP的MySQL代码生成器,现在给出全系列的,供各位玩家慢慢去研究吧! Oracle PHP 代码生成器是一个功能强大的,使您可以产生高...

    php留言板代码,php留言板

    11. **错误处理与日志记录**:良好的错误处理机制可以捕捉并记录运行时错误,帮助开发者调试和优化代码。 12. **响应式设计**:考虑到不同设备的访问需求,现代留言板通常会采用响应式布局,适应手机、平板电脑和...

    政府门户网站PHP代码下载

    本资源提供了“政府门户网站PHP代码下载”,涵盖了完整的源代码,这将对开发者或者学习者提供极大的便利。 首先,PHP 5.2.3是这个项目所基于的PHP版本。在2007年发布的PHP 5.2系列,引入了许多新特性,比如增强了...

    PHP图书管理系统代码资源

    对于初学者来说,通过分析和理解这个系统的代码,可以深入理解PHP与MySQL的结合应用,以及如何构建一个简单的Web应用程序。同时,它也可以作为进一步改进和扩展的基础,例如添加用户认证、权限控制、图书评论等功能...

Global site tag (gtag.js) - Google Analytics