laravel框架與thinkPHP框架的差異
#主要差異:
1.渲染模版方式的不同:
在Laravel框架裡,使用return view()來渲染模版;
而ThinkPHP裡則使用了$this->display()的方式渲染模版;
2.在Laravel框架裡,由於其考慮到了跨站請求偽造, 所以如果使用form表單以post方式進行傳值時,如果不再form表單中加{{csrf_field()}}則會報出TokenMethodnotfound的語法錯誤;
#而TP框架則需要自己手動完成防止跨站攻擊的程式碼;
3.Laravel是一個重路由的框架(5.4),所有的功能都是由路由發起的,哪怕沒有控制器方法,只要寫了路由就能夠訪問,thinkPHP(3.2),必須要有控制器方法才能正常訪問;
4.laravel具有強大的社區化擴展,(composer擴展自動加載);
# 5.laravel具有強大的Blade模版引擎;
6.中間件,Laravel特點,可以實現訪問前後的處理,例如請求和返回,權限認證等;
7.條件判斷語句書寫方式的差異:
Laravel框架裡if else判斷語句和foreach語句書寫時必須以@if開頭 以@endif結尾,如果沒有則報語法錯誤,@foreach@endforeach同理;而TP框架則和PHP語法規則使用方式一致直接ifesle語句判斷和foreach循環遍歷
8.Laravel裡內置了大量的方法供開發者使用,在實際應用中更接近於"讓對象完成一切"的開發想法,例如在後台表單驗證的時候,Laravel內建了大量的驗證方法,例如對使用者名稱的驗證:我們使用可以validate方法裡'username'=>'required'(不能為空)|alpha_dash(必須數字字母下劃線)|between:6,18(在多少位數之間);還內置了例如email;same:字段名;diff:字段名等大量的方法極大的提高了開發速度;
9.加密方式在TP框架中我們對用戶名密碼進行加密時使用md5();的方式進行加密,但md5的缺點在於其可以逆向破解,而且在同等規則下同樣的密碼md5加密出的字串是有可能出現相同的,這就降低其安全性;但在Laravel框架中內置了"哈希"Hash加密單向加密方法,且同樣的參數加密出的字符串是絕對不會出現相同的情況這就提高了安全性;
10.在實際開發中我們常常遇到這樣的問題,就是開發地點不固定,這就造成了我們需要頻繁的更改資料庫配置,給開發工作造成了麻煩,TP依然沒有避免這個"災難";在laravel框架中,.env環境文件的出現解決了這個麻煩,我們只需要在不同的工作地點配置好.env文件就不必再進行配置,因為無論是git還是svn " .env是不會隨著檔案一起提交到伺服器的";
以上是laravel框架與thinkPHP框架的區別的詳細內容。更多資訊請關注PHP中文網其他相關文章!