github上有哪些优秀的PHP项目来学习?

https://segmentfault.com/q/1010000008463479

http://www.nowamagic.net/librarys/veda/detail/535

https://www.jb51.net/article/24043.htm

从学习PHP到现在工作,能写出一些简单的企业站,虽然能实现功能,但是回头来看自己写的代码,水平太低,毫无美感,有时候自己都没眼看了,想请问各位有优秀的开源的PHP项目能提供学习吗?模仿高水平的我觉得比自己瞎琢磨要好太多了,拜谢各位!

Oreilly系列的《PHP经典实例》,适合学习短小的代码片段实现。
《深入PHP 对象、模式与实践》对于面向对象和模式的思想介绍比较好,以及一些必备技能如单元测试等
Oreilly系列的《Modern PHP》,是很多干货,告诉你最好该怎么写

框架方面,CodeIgniter是比较小巧且曾经比较火的框架(现在也很优秀),可以用来看看源码。但现在最流行的是Laravel,有一本书叫《Laravel框架关键技术解析》,这不是讲Laravel用法的,是作者解读Laravel源码的

二、怎样的PHP代码才算优秀

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

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

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

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

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

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

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

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

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

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

1 <?php 
2 if (isset($_GET['query'])) 
3
4    echo '<p>Search results for query: '
5    htmlspecialchars($_GET['query'], ENT_QUOTES), '.</p>'
6
7 ?>

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

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

猜你喜欢

转载自blog.csdn.net/hrbsfdxzhq01/article/details/88828093