给初学者的30条PHP最佳实践(荒野无灯)


Posted in PHP onAugust 02, 2011

1,和PHP手册成为好朋友
2,打开Error Reporting
Error reporting 在 PHP 开发时是很有帮助的. 你可以在你代码中发现先前你没有发现的错误,因为并不是所有的BUG都会让程序运行不了的。当产品正式使用时,才有必要关掉错误报告,不然顾客看到一堆奇怪的字符不知道那是什么意思。
3,使用IDE
IDE (集成开发环境,Integrated Development Environments)对于开发者来说是很有帮助的工具.
荒野在这里推荐netbeans IDE 。
4. 试着使用一个PHP 框架
5.学习DRY方法
DRY 代表 Don't Repeat Yourself,它是一个有价值的编程概念,不管是什么语言。DRY编程,顾名思义,是确保你不写多余的代码。
6.使用空格缩进代码来提高可读性
7. “Tier” your Code
给你的应用程序分层,分成不同部位的不同组成部分的代码。这使得您可以轻松地在未来改变你的代码。 如常用的MVC模式。
8. 总是使用 <?php ?>
9.使用有意义的,一致的命名约定
10.注释、注释、注释
11.安装MAMP/WAMP
12.给你的脚本限制运行时间
通常PHP脚本的运行时间被限制为30秒,超过这个时间PHP将抛出一个致命错误。
13.使用OOP
14.知道双引号和单引号的不同
15.不要在网站的根目录放phpinfo()
16.永远不要信任你的用户
17.加密存储密码
Rebuttal:
Keep in mind, however, that MD5 hashes have long since been compromised. They're absolutely more secure than not, but, with the use of an enormous “rainbow table,” hackers can cross reference your hash. To add even more security, consider adding a salt as well. A salt is basically an additional set of characters that you append to the user's string.
18.使用可视化数据库设计工具
如 DBDesigner 和 MySQL Workbench
19.使用输出缓冲
Rebuttal: Though not required, it's generally considered to be a good practice to go ahead and append the “ob_end_flush();” function as well to the bottom of the document. P.S. Want to compress the HTML as well? Simply replace “ob_start();” with “ob_start(‘ob_gzhandler')”;
Refer to this Dev-tips article for more information.

<!DOCTYPE html> 
<?php ob_start('ob_gzhandler'); ?> 
<html lang="en"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<title>untitled</title> 
</head> 
<body> </body> 
</html> 
<?php ob_end_flush(); ?>

20.保护你的代码避免SQL注射
$username = mysql_real_escape_string( $GET['username'] ); 
$id = $_GET['id']; 
$statement = $connection->prepare( "SELECT * FROM tbl_members WHERE id = ?" ); 
$statement->bind_param( "i", $id ); 
$statement->execute();

By using prepared statements, we never embed the user's inputted data directly into our query. Instead, we use the “bind_param” method to bind the values (and escaping) to the query. Much safer, and, notably, faster when executing multiple CRUD statements at once.
21.尝试ORM (object relational mapping)
ORM libraries for PHP like Propel, and ORM is built into PHP frameworks like CakePHP.
22.缓存数据库驱动页面
如:
// TOP of your script 
$cachefile = 'cache/'.basename($_SERVER['SCRIPT_URI']); 
$cachetime = 120 * 60; // 2 hours 
// Serve from the cache if it is younger than $cachetime 
if (file_exists($cachefile) && (time() - $cachetime < filemtime($cachefile))) { 
include($cachefile); 
echo "<!-- Cached ".date('jS F Y H:i', filemtime($cachefile))." -->"; 
exit; 
} 
ob_start(); // start the output buffer 
// Your normal PHP script and HTML content here 
// BOTTOM of your script 
$fp = fopen($cachefile, 'w'); // open the cache file for writing 
fwrite($fp, ob_get_contents()); // save the contents of output buffer to the file 
fclose($fp); // close the file 
ob_end_flush(); // Send the output to the browser

23.使用缓存系统
24.验证Cookie数据
Cookie data, like any data passed on the Web, can be harmful. You can validate cookie data with either the htmlspecialchars() or mysql_real_escape_string().
25.使用静态文件缓存系统
如Smarty的是一个内置缓存的强大的模板系统。
26.分析你的代码
Profiling your code with a tool like xdebug can help you to quickly spot bottlenecks and other potential problems in your PHP code. Some IDEs like Netbeans have PHP profiling capabilities as well.
27.编码标准
如 Pear标准。
28. Keep Functions Outside of Loops
You take a hit of performance when you include functions inside of loops. The larger the loop that you have, the longer the execution time will take. Take the extra time and line of code and place the function outside of the loop.
Editor's Note: Think of it this way. Try to remove as many operations from the loop as possible. Do you really need to create that variable for every iteration of the loop? Do you really need to create the function each time? Of course not.
29.不要复制不额外的变量(事实上这一条值得怀疑,见下面的说明)
如:
$description = strip_tags($_POST['description']); 
echo $description;

可以写成如下:
echo strip_tags($_POST['description']);
Rebuttal: In reference to the comment about “doubling the memory,” this actually is a common misconception. PHP implements “copy-on-write” memory management. This basically means that you can assign a value to as many variables as you like without having to worry about the data actually being copied. While it's arguable that the “Good” example exemplified above might make for cleaner code, I highly doubt that it's any quicker.
也就是说PHP实现“copy-on-write” 的内存管理方式,上面第一种代码并不会存在占用双倍内存的情况。因此Rebuttal严重怀疑第二种方式的代码是否真的比前面的快。
30.更新到最新版本的PHP
31.减少数据库查询次数
32.勇敢地提问
StackOverflow等都是好去处。
PHP 相关文章推荐
Discuz 5.0 中读取纯真IP数据库函数分析
Mar 16 PHP
php对gzip文件或者字符串解压实例参考
Jul 25 PHP
php如何调用webservice应用介绍
Nov 24 PHP
基于PHP一些十分严重的缺陷详解
Jun 03 PHP
destoon数据库表说明汇总
Jul 15 PHP
php常用文件操作函数汇总
Nov 22 PHP
基于PHP代码实现中奖概率算法可用于刮刮卡、大转盘等抽奖算法
Dec 20 PHP
PHP检测数据类型的几种方法(总结)
Mar 04 PHP
PHP控制反转(IOC)和依赖注入(DI)
Mar 13 PHP
OAuth认证协议中的HMACSHA1加密算法(实例)
Oct 25 PHP
PHP单例模式模拟Java Bean实现方法示例
Dec 07 PHP
微信公众号之主动给用户发送消息功能
Jun 22 PHP
使用ThinkPHP自带的Http类下载远程图片到本地的实现代码
Aug 02 #PHP
linux下使用ThinkPHP需要注意大小写导致的问题
Aug 02 #PHP
理解和运用PHP中的多态性[译]
Aug 02 #PHP
应用开发中涉及到的css和php笔记分享
Aug 02 #PHP
PHP源代码数组统计count分析
Aug 02 #PHP
linux下为php添加curl扩展的方法
Jul 29 #PHP
php中修改浏览器的User-Agent来伪装你的浏览器和操作系统
Jul 29 #PHP
You might like
支持php4、php5的mysql数据库操作类
2008/01/10 PHP
功能强大的php分页函数
2016/07/20 PHP
PHP抽象类与接口的区别实例详解
2019/05/09 PHP
Jquery调用webService远程访问出错的解决方法
2010/05/21 Javascript
jquery中get,post和ajax方法的使用小结
2014/02/04 Javascript
JavaScript实现向OL列表内动态添加LI元素的方法
2015/03/21 Javascript
Javascript实现商品秒杀倒计时(时间与服务器时间同步)
2015/09/16 Javascript
js ajaxfileupload.js上传报错的解决方法
2016/05/05 Javascript
ionic实现可滑动的tab选项卡切换效果
2020/04/15 Javascript
Bootstrap基本插件学习笔记之轮播幻灯片(23)
2016/12/08 Javascript
JS实现一次性弹窗的方法【刷新后不弹出】
2016/12/26 Javascript
Angular弹出模态框的两种方式
2017/10/19 Javascript
微信小程序ajax实现请求服务器数据及模版遍历数据功能示例
2017/12/15 Javascript
js实现点击按钮复制文本功能
2020/07/20 Javascript
r.js来合并压缩css文件的示例
2018/04/26 Javascript
JavaScript设计模式之代理模式实例分析
2019/01/16 Javascript
postman自定义函数实现 时间函数的思路详解
2019/04/17 Javascript
node.js使用yargs处理命令行参数操作示例
2020/02/11 Javascript
Vue常用传值方式、父传子、子传父及非父子实例分析
2020/02/24 Javascript
[03:03]2014DOTA2西雅图国际邀请赛 Alliance战队巡礼
2014/07/07 DOTA
[01:20]DOTA2 齐天大圣至宝动态展示
2016/12/13 DOTA
Python常见数据结构详解
2014/07/24 Python
wxpython实现图书管理系统
2018/03/12 Python
使用Python+Appuim 清理微信的方法
2021/01/26 Python
HTML5 FormData 方法介绍以及实现文件上传示例
2017/09/12 HTML / CSS
SportsDirect.com马来西亚:英国第一体育零售商
2018/11/21 全球购物
波兰在线儿童和婴儿用品零售商:pinkorblue
2019/06/29 全球购物
Bed Bath & Beyond加拿大官网:购买床上用品、浴巾、厨房电器等
2019/10/04 全球购物
求职推荐信范文
2013/12/01 职场文书
大学生思想汇报范文
2013/12/31 职场文书
医学院毕业生自荐信范文
2014/03/06 职场文书
临床医师个人自我评价
2014/04/06 职场文书
小学生倡议书范文
2014/05/13 职场文书
“学党章、守党纪、讲党规”学习心得体会
2016/01/14 职场文书
Java实战之用Swing实现通讯录管理系统
2021/06/13 Java/Android
TS 类型兼容教程示例详解
2022/09/23 Javascript