优秀的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代码是一道简化了的测试题。这种问题就像在问:你该怎样优化这段代码?

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

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

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

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

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

后端开发程序员需要学习以下内容: 1. 编程语言:后端开发常用的编程语言有Java、Python、PHP、Ruby、Golang等。需要熟练掌握至少一种编程语言,并了解不同编程语言之间的区别和优缺点,选择最适合项目的编程语言。\[2\] 2. 数据库管理:后端开发涉及数据的存储、查询和管理,因此需要熟练掌握至少一种数据库的使用,如MySQL、Oracle、PostgreSQL等。了解数据库的基本原理和常用操作,能够进行数据的增删改查操作。\[2\] 3. Web框架:Web框架可以快速构建Web应用程序,通常包括路由、模板引擎、会话管理等功能。常用的Web框架有Spring、Django、Flask等,需要熟悉并掌握其中一种框架的使用。\[2\] 4. 网络协议:后端开发需要理解HTTP、TCP/IP等网络协议的工作原理和应用,能够进行网络通信和数据传输。了解常见的网络安全问题和防御措施。\[2\] 5. 服务器管理:后端开发需要部署Web应用程序到服务器上,因此需要了解Linux系统的基本操作和服务器管理知识,如Nginx、Apache等服务的配置和启动。\[2\] 6. 安全防御:后端开发需要对常见的安全漏洞进行预防和防御,如SQL注入、XSS攻击、CSRF攻击等。了解安全防御的基本原理和常用的防御措施。\[2\] 7. 性能优化:后端开发需要关注Web应用程序的性能,包括代码优化、数据库优化、缓存机制等。了解性能优化的基本原理和常用的优化方法。\[2\] 8. 测试与调试:后端开发需要进行单元测试、集成测试、性能测试测试,并在代码出现问题时进行调试和修复。了解常用的测试工具和调试技巧。\[2\] 需要注意的是,对于高流量、高并发的分布式系统,后端开发的工作会更加复杂和挑战性,需要深入了解分布式架构、负载均衡、高可用性等相关知识。\[3\] #### 引用[.reference_title] - *1* *3* [后端都需要学习什么?](https://blog.youkuaiyun.com/CBGCampus/article/details/126699527)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [后端程序员要掌握哪些知识?](https://blog.youkuaiyun.com/qq_45800977/article/details/130184553)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值