隨著網路媒體的普及,新聞網站的需求也日益增長。如果你打算創建一個新聞網站,可以考慮使用Yii框架來建立你的網站。 Yii是一種流行的PHP框架,它的設計目的是使Web應用程式的開發更加簡單和高效。
Yii框架具有許多優點,其中包括:
- 高效率的效能
Yii框架是一種快速的框架,它能夠處理大量的並發請求。這是因為Yii框架採用了一些最新的PHP技術,並且使用了多種快取機制來提高網站效能。這個特性對於新聞網站來說非常重要,因為它需要能夠應對高流量的情況。
- 靈活且易於擴展
Yii框架非常靈活,能夠輕鬆地擴展和自訂。如果你需要增加新的功能或修改現有的功能,Yii框架提供了非常清晰的擴充介面和類別庫。這意味著你可以輕鬆地編寫新的模組或插件,並將它們整合到你的網站中。
- 安全性高
Yii框架以安全性為設計原則,提供了一系列的安全防護機制。這些機制包括輸入過濾、資料加密、驗證和授權等功能。這些機制是必要的,以確保你的新聞網站不會受到駭客攻擊或其他的安全威脅。
現在,我們來看看如何使用Yii框架建立一個新聞網站。
第一步,安裝Yii框架
在開始之前,你需要安裝Yii框架。 Yii框架有兩種安裝方式:透過Composer或手動下載。在這裡,我選擇Composer安裝方式。如果你還沒有安裝Composer,請先安裝Composer並將其加入你的系統路徑。
在終端機中,進入你的專案目錄,執行以下指令安裝Yii框架:
1 | composer require yiisoft/yii2-app-basic
|
登入後複製
這個指令將安裝Yii Basic應用程式範本和Yii核心函式庫。安裝完成後,你可以執行以下命令運行Yii應用程式:
這個命令將開啟一個本機Web伺服器並執行你的Yii應用程式。你可以在瀏覽器中開啟http://localhost:8080,查看你的網站首頁。
第二步,設計你的新聞網站資料庫
在創建任何網路應用程式之前,你需要設計你的資料庫。假設我們的新聞網站需要以下資料庫表格:
- news: 儲存新聞的標題、內容、日期和作者等資訊
- category: 儲存新聞的分類資訊
- user: 儲存新聞網站的使用者資訊
在Yii框架中,你可以使用Migrations工具來建立、更新和管理你的資料庫。你可以使用以下指令建立一個新的Migration:
1 | ./yii migrate/create create_news_table
|
登入後複製
這個指令將會建立一個名為create_news_table
的Migration類,這個類別將會用來建立news
#表格和其它相關的表格(例如,category
和user
表格)。
在create_news_table
類別中,你需要使用Yii框架的資料庫API來建立你的資料庫表。例如,以下是建立news
表格的範例程式碼:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <?php
use yiidbMigration;
class m210816_100000_create_news_table extends Migration
{
public function safeUp()
{
$this ->createTable( 'news' , [
'id' => $this ->primaryKey(),
'title' => $this ->string()->notNull(),
'content' => $this ->text(),
'category_id' => $this ->integer(),
'user_id' => $this ->integer(),
'created_at' => $this ->timestamp()->defaultExpression( 'CURRENT_TIMESTAMP' ),
]);
$this ->addForeignKey( 'fk_news_category' , 'news' , 'category_id' , 'category' , 'id' , 'CASCADE' , 'CASCADE' );
$this ->addForeignKey( 'fk_news_user' , 'news' , 'user_id' , 'user' , 'id' , 'CASCADE' , 'CASCADE' );
}
public function safeDown()
{
$this ->dropForeignKey( 'fk_news_category' , 'news' );
$this ->dropForeignKey( 'fk_news_user' , 'news' );
$this ->dropTable( 'news' );
}
}
|
登入後複製
在這個程式碼中,我們使用Yii框架的createTable
方法來建立news
表格,接著以addForeignKey
方法定義外鍵約束,保證了資料的一致性。
有了Migration類,你可以使用如下指令執行Migration,來建立新的資料庫表格:
這個指令將會建立新的資料庫表格和它相關的表格。
第三步,建立Yii模型
在Yii框架中,模型是用來表示業務邏輯和資料的核心部分,也是MVC架構模式中的一部分。在Yii框架中,模型是用來處理資料的最簡單、最有力的方式。
要建立一個模型,你可以使用以下指令:
1 | ./yii generate/model News --tableName=news
|
登入後複製
這個指令將會建立一個名為News
的模型,並關聯到news
表格。接著,你需要使用以下程式碼自訂你的模型:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | <?php
namespace appmodels;
use Yii;
class News extends yiidbActiveRecord
{
public static function tableName()
{
return 'news' ;
}
public function rules()
{
return [
[[ 'title' ], 'required' ],
[[ 'content' ], 'string' ],
[[ 'category_id' , 'user_id' ], 'integer' ],
[[ 'created_at' ], 'safe' ],
[[ 'title' ], 'string' , 'max' => 255],
];
}
public function attributeLabels()
{
return [
'id' => 'ID' ,
'title' => 'Title' ,
'content' => 'Content' ,
'category_id' => 'Category ID' ,
'user_id' => 'User ID' ,
'created_at' => 'Created At' ,
];
}
}
|
登入後複製
在這個程式碼中,我們定義了News
模型的表格名稱和驗證規則,也定義了每個屬性的標籤(用於顯示給使用者的文字)。你可以透過這個模型存取和修改資料表,例如:
1 2 3 4 5 6 | $news = new News();
$news ->title = 'Hello, World!' ;
$news ->content = 'Welcome to my news website.' ;
$news ->category_id = 1;
$news ->user_id = 1;
$news ->save();
|
登入後複製
這將在news
表格中加入一則新聞。
第四步,建立Yii控制器和視圖
在Yii框架中,控制器是用來處理使用者要求並呈現回應的部分。控制器可將使用者請求路由到正確的操作,並使用特定的視圖檔案來呈現回應。
要建立一個控制器,你可以使用以下指令:
1 | ./yii generate/controller News
|
登入後複製
這將會建立一個名為NewsController
的控制器。接著,你需要在控制器中加入一些操作,例如:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | <?php
namespace appcontrollers;
use Yii;
use appmodelsNews;
use yiiwebController;
class NewsController extends Controller
{
public function actionIndex()
{
$news = News::find()->all();
return $this ->render( 'index' , [
'news' => $news ,
]);
}
public function actionView( $id )
{
$news = News::findOne( $id );
return $this ->render( 'view' , [
'news' => $news ,
]);
}
public function actionCreate()
{
$news = new News();
if ( $news ->load(Yii:: $app ->request->post()) && $news ->save()) {
return $this ->redirect([ 'view' , 'id' => $news ->id]);
}
return $this ->render( 'create' , [
'news' => $news ,
]);
}
public function actionUpdate( $id )
{
$news = News::findOne( $id );
if ( $news ->load(Yii:: $app ->request->post()) && $news ->save()) {
return $this ->redirect([ 'view' , 'id' => $news ->id]);
}
return $this ->render( 'update' , [
'news' => $news ,
]);
}
public function actionDelete( $id )
{
$news = News::findOne( $id );
$news -> delete ();
return $this ->redirect([ 'index' ]);
}
}
|
登入後複製
在這個程式碼中,我們定義了五個操作:Index
、View
、Create
、Update
和Delete
。這將視圖文件呈現給用戶,並根據用戶的請求回傳回應。
為了建立這些操作的視圖文件,例如:
app/views/news/index.php
app/views/news/view.php
app/views/news/create.php
app/views/news/update.php
你需要添加如下代码:
1 2 3 4 5 6 7 8 9 10 11 12 | <?php foreach ( $news as $item ): ?>
<div>
<h2><?= $item ->title ?></h2>
<p><?= $item ->content ?></p>
<p><?= $item ->created_at ?></p>
<p>Author: <?= $item ->user_id ?></p>
<p>Category: <?= $item ->category_id ?></p>
<a href= "<?= Yii::$app->urlManager->createUrl(['news/view', 'id' => $item->id]) ?>" >View</a>
<a href= "<?= Yii::$app->urlManager->createUrl(['news/update', 'id' => $item->id]) ?>" >Update</a>
<a href= "<?= Yii::$app->urlManager->createUrl(['news/delete', 'id' => $item->id]) ?>" > Delete </a>
</div>
<?php endforeach ; ?>
|
登入後複製
在这个代码中,我们用循环遍历新闻,然后为每个新闻输出标题、内容、日期、作者和分类,以及三个按钮View、Update和Delete。
第五步,定义Yii路由和URL规则
在Yii框架中,路由和URL规则告诉Yii框架如何将用户请求路由到正确的控制器和操作。
默认情况下,Yii框架使用/controller/action
格式的URL,例如/news/index
。但是你可以自定义路由和URL规则,例如将/news
路由到NewsController
的Index
操作。
要定义路由和URL规则,你可以使用如下代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | 'urlManager' => [
'enablePrettyUrl' => true,
'enableStrictParsing' => true,
'showScriptName' => false,
'rules' => [
[ 'class' => 'yiiestUrlRule' , 'controller' => 'news' ],
'news' => 'news/index' ,
'news/create' => 'news/create' ,
'news/<id:d+>' => 'news/view' ,
'news/<id:d+>/update' => 'news/update' ,
'news/<id:d+>/delete' => 'news/delete' ,
],
],
|
登入後複製
在这个代码中,我们使用规则数组来自定义路由和URL规则。例如,我们将news
路由到NewsController
的Index
操作,而将news/create
路由到NewsController
的Create
操作。
第六步,测试Yii应用程序
现在,你已经创建了一个新闻网站,并使用Yii框架构建了它。要测试你的新闻网站,你可以在终端中运行如下命令启动本地Web服务器:
然后在浏览器中打开http://localhost:8080,查看你的新闻网站。
最后,当你为你的新闻网站添加更多功能时,你可以根据你的业务需要扩展Yii框架的功能。Yii框架提供了许多工具和类库,可以帮助你尽可能快地开发出高效、安全和易于扩展的Web应用程序。
以上是使用Yii框架建立新聞網站的詳細內容。更多資訊請關注PHP中文網其他相關文章!