为什么那么多人吐糟PHP 也没说原因
这个问题已被关闭,原因:
回复内容:
为什么那么多人吐糟PHP 也没说原因
客观的回答:
1.PHP语言以及环境,与其他主流语言及其环境相比,很差,这是缺点。
2.PHP在互联网发展史上曾经非常辉煌,Web2.0基本上是它的功劳。而且那个年代能赚钱的基本上也都是PHP的,这些是优点。
所以,由于PHP有矛盾如此激烈的缺点与优点,所以才会产生巨大的争议与话题。其他语言由于没有这么激烈的矛盾,所以不会出现这种情况。
我之前写过很久 PHP, 但现在是 PHP 黑,简单说一下原因。
-
语法设计不合理
这个诚然有历史原因,但确实是不合理。
- 命名空间用(
\
)分隔,简直丧心病狂;对象成员用(->
)访问,略显繁琐 - 函数名不区分大小写,老版本的类名也不区分大小写,而变量名却区分大小写
- 数组的写法繁琐(
array()
),直到 5.4 才有简写语法([]
) - 这样
function test_array(array $input_array)
, 可以限制参数的类型,适用于类和数组,却不适用于int
和string
-
unset
,echo
,empty
,list
长得像函数,却不是函数 - 直到 5.4 才支持
func()[0]
这种写法 - 大部分内部函数默认不会抛出异常,导致 PHP 中存在两套独立的错误处理机制
- 命名空间用(
-
很多被弃用的功能仍被广泛使用,新的功能被普及得很慢
这个是使用者的事情,但情况就是如此。
在开源软件中更为突出,比如 WordPress 为了尽可能兼容旧的 PHP 版本,没法用上例如匿名函数(5.3), 数组简写语法(5.4) 这种能够大幅改善代码可读性的功能。
下面是一些被弃用的功能,这些功能大多是设计上存在失误,后来因为可能导致潜在的问题被弃用,但因为网络上互相转载的一些不靠谱教程,所以很多人依然在使用。
__autoload
-
mysql_*
系列函数 - Register Globals
- Magic Quotes
- Safe Mode
-
缺少好用的包管理器和依赖管理方案
PHP 和 Python, Ruby, Node.js 在使用领域上是有一定重叠的,我们来比较一下包的数量:
- PHP Composer: 46k
- Python PyPI: 53k
- Ruby Gems: 94k
- Node.js NPM: 116k
虽然包的数量不代表质量,但是代表了人们是否愿意发布和使用包。
Composer 在 PHP 中的普及率恐怕不及上面其他三款包管理器,比如作为最火的博客程序 WordPress, 和国内的 Typecho 都没有使用 Composer, 而是直接在源代码中包含所有依赖。
-
必须为每个请求创建一个单独的进程
PHP 必须为每个请求创建一个进程(或线程),这导致在高并发的情况下会占用大量内存。
在 PHP 中很难创建一个资源,并让它可以在全局范围内,可以被所有请求访问到,只能通过外部的数据库或缓存来实现。亦没有办法定义一项任务,独立于其他请求运行,只能通过单独的任务队列来解决。虽然这两个问题并不严重,但无法轻量级地维护全局的状态,算是一个缺憾。
-
PHP 是为 Web 优化的编程语言
- 可以直接用
$_GET
和$_POST
访问来自客户端的 GET 和 POST 数据 - 可以用
<?php ?>
的方式嵌入到 HTML 文件中
现在大多数 Web 程序,往往都是 MVC 架构,在这种架构下,具有额外语法糖的 PHP 并不会比通用编程语言更好用。
相反的方面,虽然 PHP 可以用于 Web 之外的场景,但坑实在是多。例如缺少好用的异步流程控制的方案等。
- 可以直接用
黑某种语言只能说明此人见识少,语言只是工具,适用于不同的场合,不喜欢可以不用。你都不用了怎么有资格黑。
比如有些人说php的shell功能弱,人家php天生就是为web开发设计,你要拿筷子当叉子用,还说人家不好用。
比如说php性能差,殊不知很多.Net和Java的初学者写出来的网站,一堆的性能bug,难道这不是php设计上的优点。
有优点当然也有缺点,关键看你怎么用。黑PHP的人估计是想不明白为啥国内大的互联网公司都用PHP
php上手简单 没什么难度
黑他只是为了显示自己学的语言有多好
黑他才能显得自己水平高
Python c c++ 语言也都有自己不足的地方 你也去黑黑
对php了解一些了你就使劲黑吧
有句话说 程序员应该为自己的行为负责 但是实际上很少有程序员做的到这点 于是有c++ c# java这种强类型语言来约束程序员的行为
php显然缺少这些条条框框 而且php弱类型的实现的却有一些诟病的地方
同意 @我是谁啊2015_73720 的说法,总不能说手机没有单反拍照好用,就说手机设计不合理,人家生来就不是做这件事的,做好本职工作就足够了。
更新换代速度慢是注定的,庞大的用户量不是PHP说升级就能升级的,至少要用户配合。微软这样致力推广Windows的更新,现在还不是一样有不少用人XP的?
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
请注意
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
PHP是世界上最好的语言,没有之一
这种问题以后少问,如果PHP不好,那么怎么还那么多公司用?
PHP不死,这种问题这轮不到你们这些人来评论!
PHP是世界上最好的语言,没有之一
来自知乎的回答
楼上好多 大神啊!!!
自以为是的 大婶。。。
不懂就乱黑。。。笑

使用数据库存储会话的主要优势包括持久性、可扩展性和安全性。1.持久性:即使服务器重启,会话数据也能保持不变。2.可扩展性:适用于分布式系统,确保会话数据在多服务器间同步。3.安全性:数据库提供加密存储,保护敏感信息。

在PHP中实现自定义会话处理可以通过实现SessionHandlerInterface接口来完成。具体步骤包括:1)创建实现SessionHandlerInterface的类,如CustomSessionHandler;2)重写接口中的方法(如open,close,read,write,destroy,gc)来定义会话数据的生命周期和存储方式;3)在PHP脚本中注册自定义会话处理器并启动会话。这样可以将数据存储在MySQL、Redis等介质中,提升性能、安全性和可扩展性。

SessionID是网络应用程序中用来跟踪用户会话状态的机制。1.它是一个随机生成的字符串,用于在用户与服务器之间的多次交互中保持用户的身份信息。2.服务器生成并通过cookie或URL参数发送给客户端,帮助在用户的多次请求中识别和关联这些请求。3.生成通常使用随机算法保证唯一性和不可预测性。4.在实际开发中,可以使用内存数据库如Redis来存储session数据,提升性能和安全性。

在无状态环境如API中管理会话可以通过使用JWT或cookies来实现。1.JWT适合无状态和可扩展性,但大数据时体积大。2.Cookies更传统且易实现,但需谨慎配置以确保安全性。

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Linux新版
SublimeText3 Linux最新版

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Atom编辑器mac版下载
最流行的的开源编辑器

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中