溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

laravel與thinkphp有哪些區(qū)別

發(fā)布時(shí)間:2020-12-31 14:49:51 來源:億速云 閱讀:173 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下laravel與thinkphp有哪些區(qū)別,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

1、渲染模版方式的不同

在Laravel框架里,使用return view()來渲染模版;而ThinkPHP里則使用了$this->display()的方式渲染模版。

2、在實(shí)際開發(fā)中我們常常遇到這樣的問題,就是開發(fā)地點(diǎn)不固定。

這就造成了我們需要頻繁的更改數(shù)據(jù)庫(kù)配置,給開發(fā)工作造成了麻煩。TP依然沒有避免這個(gè)"災(zāi)難",在laravel框架中,.env環(huán)境文件的出現(xiàn)解決了這個(gè)麻煩。我們只需要在不同的工作地點(diǎn)配置好.env文件就不避再進(jìn)行配置,因?yàn)闊o(wú)論是git還是svn,“.env是不會(huì)隨著文件一起提交到服務(wù)器的”。

3、Laravel框架提供了大量的閉包

作為菜鳥的我目前只使用了use方法,即如何在函數(shù)內(nèi)部使用外層變量。

4、post傳值中注意點(diǎn)不同

在Laravel框架里,由于其考慮到了跨站攻擊,所以如果使用form表單以post方式進(jìn)行傳值時(shí),如果不再form表單中加入{{csrf_field()}}則會(huì)報(bào)出TokenMethodnotfound的語(yǔ)法錯(cuò)誤,而TP框架則需要自己手動(dòng)完成防止跨站攻擊的代碼。

5、條件判斷語(yǔ)句書寫方式的差異

Laravel框架里if else判斷語(yǔ)句和foreach語(yǔ)句,書寫時(shí)必須以@if開頭,以@endif結(jié)尾。如果沒有則報(bào)語(yǔ)法錯(cuò)誤,@foreach @endforeach同理;而TP框架則和PHP語(yǔ)法規(guī)則使用方式一致,直接用if esle語(yǔ)句判斷和foreach循環(huán)遍歷。

6、Laravel里內(nèi)置了大量的方法供開發(fā)者使用

在實(shí)際應(yīng)用中更接近于"讓對(duì)象完成一切"的開發(fā)思想,比如在后臺(tái)表單驗(yàn)證的時(shí)候,Laravel內(nèi)置了大量的驗(yàn)證方法。例如對(duì)用戶名的驗(yàn)證:我們可以使用validate方法里'username'=>'required'(不能為空)|alpha_dash(必須數(shù)字字母下劃線)|between:6,18(在多少位數(shù)之間);還內(nèi)置了例如email;same:字段名;diff:字段名等大量的方法極大的提高了開發(fā)速度。

7、加密方式

在TP框架中,我們對(duì)用戶名密碼進(jìn)行加密時(shí)使用md5();的方式進(jìn)行加密。但md5的缺點(diǎn)在于其可以逆向破解,而且在同等規(guī)則下同樣的密碼md5加密出的字符串是有可能出現(xiàn)相同的,這就降低其安全性。但在Laravel框架中內(nèi)置了"哈希"Hash加密單向加密方法,且同樣的參數(shù)加密出的字符串是絕對(duì)不會(huì)出現(xiàn)相同的情況,這就提高了安全性。

8、建表

Laravel在數(shù)據(jù)庫(kù)建表上有自己獨(dú)立內(nèi)置的結(jié)構(gòu),可以完全不用借助原生SQL語(yǔ)句或者SQLyogEnt、Navicat這樣的建表工具進(jìn)行數(shù)據(jù)庫(kù)的建立,增刪改查和數(shù)據(jù)交互。我想這可能是它牢牢占據(jù)NO.1的一大亮點(diǎn),在ThinkPHP中則需要我們借助SQL語(yǔ)句或者建表工具去逐步完善數(shù)據(jù)。

8.1、首先我們需要建立模型:我用的是gitbash。gitbash是Windows下的命令工具,基于msys GNU環(huán)境,有g(shù)it分布式版本控制工具,主要應(yīng)用于git。但是在Laravel里也可以直接使用:php artisan make:model Models/GoodsModel -m 完成模型的創(chuàng)建和建表結(jié)構(gòu)的創(chuàng)建(/database/migrations)。

8.2、向goods數(shù)據(jù)表填充數(shù)據(jù),要注意數(shù)據(jù)的類型是嚴(yán)格區(qū)分的,并且一定要加。添加完后使用php artisan migrate命令完成表的創(chuàng)建。

Schema::create('goods', function (Blueprint $table) {

$table->increments('id')->comment('商品主鍵');

$table->string('title')->comment('商品的標(biāo)題');

8.3、假設(shè)某個(gè)字段不符合要求或者需要添加字段怎么辦?無(wú)須擔(dān)心,從github中pull下項(xiàng)目后在數(shù)據(jù)表里直接修改,只需要用:

php artisan migrate:refresh

9、ORM

在介紹建表時(shí)已經(jīng)使用了創(chuàng)建模型的命令:

php artisan make:model  XXX;

Laravel里模型是對(duì)面向?qū)ο箝_發(fā)思想最好的詮釋,讓對(duì)象幫我們完成需求。

摘自5.1手冊(cè):(Laravel 的 Eloquent ORM 提供了漂亮、簡(jiǎn)潔的 ActiveRecord 實(shí)現(xiàn)來和數(shù)據(jù)庫(kù)進(jìn)行交互。每個(gè)數(shù)據(jù)庫(kù)表都有一個(gè)對(duì)應(yīng)的「模型」可用來跟數(shù)據(jù)表進(jìn)行交互。你可以通過模型查找數(shù)據(jù)表內(nèi)的數(shù)據(jù),以及將記錄添加到數(shù)據(jù)表中。)

本人在實(shí)際使用中也實(shí)實(shí)在在的感受到了通過創(chuàng)造模型對(duì)數(shù)據(jù)表操作帶來的便利,譬如:批量賦值,跨表查詢,刪除模型和軟刪除,模型關(guān)聯(lián),當(dāng)然這些在TP框架中也可以利用模型實(shí)現(xiàn)。這一點(diǎn)屬于仁者見仁智者見智,根據(jù)個(gè)人喜好而定。

10、session的用法

10.1、ThinkPHP對(duì)Session操作進(jìn)行了封裝,并且無(wú)需引入就可以使用,Session的啟動(dòng)會(huì)在應(yīng)用初始化的時(shí)候自動(dòng)執(zhí)行,所以無(wú)需手動(dòng)使用Session::start() 來啟動(dòng)Session。

使用Session類操作和普通方式調(diào)用$_SESSION來操作并沒有本質(zhì)不同,只是Session類很多參數(shù)可以根據(jù)項(xiàng)目配置來靈活設(shè)置,最常用的操作方法示例:

// 檢測(cè)Session變量是否存在:Session::is_set('name');

// 給Session變量賦值:Session::set('name','value');

// 獲取Session變量:Session::get('name');

10.2、Laravel中Session的常用方法:

$request->session()->get('key');//獲取session里的某個(gè)鍵名

$request->session()->set('key','default');//設(shè)定一個(gè)默認(rèn)值,當(dāng)指定鍵名不存在便返回默認(rèn)值

$request->session()->all();//返回所有數(shù)據(jù)

session('k'=>$v);//寫入session保存數(shù)據(jù)

以及閃存數(shù)據(jù)session()->flash()和保留特定數(shù)據(jù)->keep(['','']);

也可以自定義session驅(qū)動(dòng)。

看完了這篇文章,相信你對(duì)“l(fā)aravel與thinkphp有哪些區(qū)別”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI