php作为弱类型语言的坑点

近日,怀着新语言的一门心思,在键盘上敲敲打打。golang的强类型有时候着实让人有点摸不着头脑(对于习惯了php的老人来说)
下面是一个golang的例子


再看看命令行


虽然if中间的var赋值user挺蠢的,而且就golang的强类型申明user类型之后再来var显得很小白,但是梳理整个逻辑,发现了一个重要的信息点,甚至是背心出了一身冷汗!

重现:最开始我想的是ResponseSuc里头统一返回user,所以就用了 if else
做user的数据处理,按照php的逻辑,第一个if里头不用var,直接 user=****
就行了,根本不用管类型。(所以var的出现,就是因为去掉var之后限制了user的类型而产生,为了语法不报错而不经过大脑,蠢哭)
结果看到了,就是第一个user打印出来了一大坨数据,而最下面的user没有数据。究其原因,就是因为两个user根本不是一个玩意儿

反思

php为弱类型语言,这种非同类型赋值简直写起来不要太舒服。然而golang的语法和php对比,终于让我发现,弱类型的严重缺陷,见下图



golang中if之前就已经开始报错,因为是非同类型的比较,程序根本运行不起来



php里头可见 0=="0"
是true的

同理,可以验证 null
, ""
等特殊的玩意儿
那么有什么影响呢


好吧,虽然用了谷歌,还是追到了腾讯的ip上 PHP弱类型在实战中导致的漏洞总结

附上php的类型比较图 php.net

最后,帖子浏览完,感觉大部分PHP系统可能都在裸奔!

友情链接
《刑法》案例查询