溫馨提示×

溫馨提示×

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

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

如何安裝Laravel 4

發(fā)布時間:2021-09-29 14:30:22 來源:億速云 閱讀:124 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“如何安裝Laravel 4”,在日常操作中,相信很多人在如何安裝Laravel 4問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何安裝Laravel 4”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

0. 默認條件

本文默認你已經(jīng)有配置完善的PHP+MySQL運行環(huán)境,懂得PHP網(wǎng)站運行的基礎(chǔ)知識。跟隨本教程走完一遍,你將會得到一個基礎(chǔ)的包含登錄的簡單blog系統(tǒng),并將學(xué)會如何使用一些強大的Laravel插件和composer包(Laravel插件也是composer包)。

軟件版本:PHP 5.4+,MySQL 5.1+

1. 安裝

許多人被攔在了學(xué)習(xí)Laravel的第一步,安裝。并不是因為安裝教程有多復(fù)雜,而是因為【眾所周知的原因】。在此我推薦一個composer全量中國鏡像:http://pkg.phpcomposer.com/。推薦“修改 composer 的配置文件”方式配置。我在寫此教程時用此鏡像測試,安裝失敗,若你也出現(xiàn)這種情況,可以嘗試另一個composer中國鏡像:http://composer-proxy.com/。

鏡像配置完成后,切換到你想要放置該網(wǎng)站的目錄下,運行命令:

復(fù)制代碼 代碼如下:

composer create-project laravel/laravel learnlaravel

然后,稍等片刻,當(dāng)前目錄下就會出現(xiàn)一個叫 learnlaravel 的文件夾,這時候如果你通過瀏覽器訪問 learnlaravel/public/ 目錄,基本都會顯示 Error in exception handler.  ,這是因為 learnlaravel/app/storage 目錄沒有777權(quán)限,設(shè)置好權(quán)限即可看見頁面如下圖:

如何安裝Laravel 4

恭喜你~Laravel安裝成功!

不想配置鏡像的同學(xué),可以使用 Laravel 界非常著名的超超搞得安裝神器:https://github.com/overtrue/latest-laravel

2. 必要插件安裝及配置

我們使用著名的Sentry插件來構(gòu)建登錄等權(quán)限驗證系統(tǒng)。

打開 ./composer.json ,變更為:

復(fù)制代碼 代碼如下:

"require": {
 "laravel/framework": "4.2.*",
 "cartalyst/sentry": "2.1.4"
},

然后,在項目根目錄下運行命令

復(fù)制代碼 代碼如下:

composer update

然后稍等一會兒,它會提示 cartalyst/sentry 2.1.4安裝完成。

同理,我們將安裝一個開發(fā)用的非常強大的插件,way/generators,這是它在composer庫中的名字。在 composer.json中增加:

復(fù)制代碼 代碼如下:

"require-dev": {
    "way/generators": "~2.0"
},

放在“require”的下面。

運行 composer update,之后在 ./app/config/app.php 中增加配置:

復(fù)制代碼 代碼如下:

'Way\Generators\GeneratorsServiceProvider'

安裝完成過,在命令行中運行 php artisan,就可以看到這個插件帶來的許多新的功能。

有人會問,為什么用了國內(nèi)鏡像還是如此之慢?其實composer在update的時候最慢的地方并不是下載,而是下載之前的依賴關(guān)系解析,由于Laravel依賴的composer包非常之多,PHP腳本的執(zhí)行速度又比較慢,所以每次update等個兩三分鐘很正常,習(xí)慣就好。

3. 數(shù)據(jù)庫建立及遷移

數(shù)據(jù)庫配置文件位于 ./app/config/database.php,我們需要把“connections”中的“mysql”項改成我們需要的配置。下面是我的配置:

復(fù)制代碼 代碼如下:

'mysql' => array(
 'driver'    => 'mysql',
 'host'      => 'localhost',
 'database'  => 'laravel',
 'username'  => 'root',
 'password'  => 'password',
 'charset'   => 'utf8',
 'collation' => 'utf8_unicode_ci',
 'prefix'    => 'l4_',
),

 prefix為表前綴,這個Laravel會幫我們自動維護,大膽寫上不用擔(dān)心。

這時候你需要去數(shù)據(jù)庫建立此數(shù)據(jù)庫,然后在命令行中輸入:

復(fù)制代碼 代碼如下:

php artisan migrate --package=cartalyst/sentry

執(zhí)行完成后,你的數(shù)據(jù)庫里就有了5張表,這是sentry自己建立的。sentry在Laravel4下的配置詳情見 https://cartalyst.com/manual/sentry#laravel-4,我大致說一下:

在 ./app/config/app.php 中 相應(yīng)的位置 分別增加以下兩行:

復(fù)制代碼 代碼如下:

'Cartalyst\Sentry\SentryServiceProvider',
'Sentry' => 'Cartalyst\Sentry\Facades\Laravel\Sentry',

權(quán)限系統(tǒng)的數(shù)據(jù)庫配置到此為止。

我們的簡單blog系統(tǒng)將會有兩種元素,Article和Page,下面我們將創(chuàng)建articles和pages數(shù)據(jù)表,命令行運行:

復(fù)制代碼 代碼如下:

php artisan migrate:make create_articles_table --create=articles
php artisan migrate:make create_pages_table --create=pages

這時候,去到 ./app/database/migrations,將會看到多出了兩個文件,這就是數(shù)據(jù)庫遷移文件,過一會我們將操作artisan將這兩個文件描述的兩張表變成數(shù)據(jù)庫中真實的兩張表,放心,一切都是自動的。

下面,在***_create_articles_table.php中修改:

復(fù)制代碼 代碼如下:

Schema::create('articles', function(Blueprint $table)
{
 $table->increments('id');
 $table->string('title');
 $table->string('slug')->nullable();
 $table->text('body')->nullable();
 $table->string('image')->nullable();
 $table->integer('user_id');
 $table->timestamps();
});

在***_create_pages_table.php中修改:

復(fù)制代碼 代碼如下:

Schema::create('pages', function(Blueprint $table)
{
 $table->increments('id');
 $table->string('title');
 $table->string('slug')->nullable();
 $table->text('body')->nullable();
 $table->integer('user_id');
 $table->timestamps();
});

下面,就是見證奇跡的時刻,在命令行中運行:

復(fù)制代碼 代碼如下:

php artisan migrate

這時候數(shù)據(jù)庫中的articles表和pages表就建立完成了。

4. 模型 Models

接下來我們將接觸Laravel最為強大的部分,Eloquent ORM,真正提高生產(chǎn)力的地方,借用庫克的話說一句,鵝妹子英!

我們在命令行運行下列語句以創(chuàng)建兩個model:

復(fù)制代碼 代碼如下:

php artisan generate:model article
php artisan generate:model page

這時候,在 ./app/models/ 下就出現(xiàn)了兩個model文件。這兩個類繼承了Laravel提供的核心類 \Eloquent。

5. 數(shù)據(jù)庫填充

分別運行下列命令:

復(fù)制代碼 代碼如下:

php artisan generate:seed page
php artisan generate:seed article

這時,在 ./app/database/seeds/ 下就出現(xiàn)了兩個新的文件,這就是我們的數(shù)據(jù)庫填充文件。Laravel提供自動數(shù)據(jù)庫填充,十分方便。

generator默認使用Faker\Factory作為隨機數(shù)據(jù)生成器,所以我們需要安裝這個composer包,地址是 https://packagist.org/packages/fzaninotto/faker ,跟generator一起安裝在 require-dev 中即可。具體安裝請自行完成,可以參考Sentry和Generator,這是第一次練習(xí)。

接下來,分別更改這兩個文件:

復(fù)制代碼 代碼如下:

Article::create([
  'title'   => $faker->sentence($nbWords = 6),
  'slug'    => 'first-post',
  'body'    => $faker->paragraph($nbSentences = 5),
  'user_id' => 1,
]);
Page::create([
  'title'   => $faker->sentence($nbWords = 6),
  'slug'    => 'first-page',
  'body'    => $faker->paragraph($nbSentences = 5),
  'user_id' => 1,
]);

然后,我們需要在 DatabaseSeeder.php 中增加兩行,讓Laravel在seed的時候會帶上我們新增的這兩個seed文件。

復(fù)制代碼 代碼如下:

$this->call('ArticleTableSeeder');
$this->call('PageTableSeeder');

下面就要真正的把數(shù)據(jù)填充進數(shù)據(jù)庫了:

復(fù)制代碼 代碼如下:

php artisan db:seed

操作完成以后去數(shù)據(jù)庫看看,數(shù)據(jù)已經(jīng)填充進去了,article和page各10行。

到此,關(guān)于“如何安裝Laravel 4”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

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

AI