目的: 為了防止sql注入,tid,goods_id都是正整數類型,防止人為了在後面追加 ?tid=1 or 1 這樣的語句.
原理: 不管你的參數多麼險惡,+0後都老老實實變成數值類型
比如 '?tid=1 or 1' , $_GET['tid']+0 後值變成1;
有學生問,你為什麼不用(int)強轉或intval來轉換.
1: 用哪種方式,目的都是一樣的
2: 用+0,只需要打2個字符,用(int)要打5個,intval()要打8個.
3: 對於+0,我不需要關心$tid是整型還是浮點型,還是大於2^32的長整型(如mysql中取得bigint), +0都能適應.
而用強轉,則會發生溢出,當然你可以說,我用float來轉,那不是還得分情況區別嗎.