Heim > PHP-Framework > YII > Erstellen Sie eine Q&A-Website mit dem Yii-Framework

Erstellen Sie eine Q&A-Website mit dem Yii-Framework

WBOY
Freigeben: 2023-06-21 09:36:02
Original
1229 Leute haben es durchsucht

Yii-Framework ist ein leistungsstarkes PHP-Framework, das Entwicklern dabei helfen kann, schnell leistungsstarke, skalierbare Webanwendungen zu erstellen. In diesem Artikel wird erläutert, wie Sie mit dem Yii-Framework eine Q&A-Website erstellen.

  1. Umgebungsvorbereitung

Bevor wir beginnen, müssen wir sicherstellen, dass die erforderliche Software und Tools wie PHP und MySQL in der lokalen Entwicklungsumgebung korrekt konfiguriert wurden. Gleichzeitig müssen wir auch das Yii-Framework installieren, um die spätere Entwicklungsarbeit zu erleichtern.

Die Installation des Yii-Frameworks ist sehr einfach. Führen Sie einfach den folgenden Befehl aus:

composer create-project yiisoft/yii2-app-basic <project_name>
Nach dem Login kopieren

wobei <project_name> der Name des aktuellen Projekts ist. <project_name>为当前项目的名称。

  1. 数据库设计

在创建问答网站之前,我们需要先设计好相关的数据库结构。在本文中,我们将使用以下的数据库表:

  • user:用于存储用户信息,包括用户名、密码、邮箱等;
  • question:用于存储问题信息,包括问题的标题、内容、发布时间等;
  • answer:用于存储回答信息,包括回答的内容、回答时间等。

这里我们使用MySQL作为后端数据库,并通过以下命令创建对应的数据库和表格:

CREATE DATABASE IF NOT EXISTS my_db;
USE my_db;

CREATE TABLE IF NOT EXISTS `user` (
  `id` INT UNSIGNED AUTO_INCREMENT,
  `username` VARCHAR(64) NOT NULL,
  `password` VARCHAR(64) NOT NULL,
  `email` VARCHAR(64) NOT NULL,
  `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
);

CREATE TABLE IF NOT EXISTS `question` (
  `id` INT UNSIGNED AUTO_INCREMENT,
  `title` VARCHAR(255) NOT NULL,
  `content` TEXT,
  `user_id` INT UNSIGNED NOT NULL,
  `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  FOREIGN KEY (`user_id`) REFERENCES user(`id`)
);

CREATE TABLE IF NOT EXISTS `answer` (
  `id` INT UNSIGNED AUTO_INCREMENT,
  `content` TEXT,
  `question_id` INT UNSIGNED NOT NULL,
  `user_id` INT UNSIGNED NOT NULL,
  `created_at` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  FOREIGN KEY (`question_id`) REFERENCES question(`id`),
  FOREIGN KEY (`user_id`) REFERENCES user(`id`)
);
Nach dem Login kopieren

注意,我们在表格中设置了外键用于关联不同的数据表。

  1. 创建模型

在Yii框架中,模型是用于操作数据库的最常用的工具。我们需要创建对应的模型文件来操作之前创建的数据库表格。

在应用根目录下的models文件夹中,我们创建三个模型文件User.phpQuestion.phpAnswer.php。以User.php为例,代码如下:

<?php
namespace appmodels;

use yiidbActiveRecord;

class User extends ActiveRecord
{
    public function rules()
    {
        return [
            [['username', 'password', 'email'], 'required'],
            ['email', 'email'],
            ['username', 'unique'],
        ];
    }

    public static function findByUsername($username)
    {
        return static::findOne(['username' => $username]);
    }

    public function validatePassword($password)
    {
        return $this->password === md5($password);
    }

    public function getQuestions()
    {
        return $this->hasMany(Question::className(), ['user_id' => 'id']);
    }

    public function getAnswers()
    {
        return $this->hasMany(Answer::className(), ['user_id' => 'id']);
    }
}
Nach dem Login kopieren

在这个文件中,我们定义了模型的属性、验证规则、查询方法和关联关系等。

  1. 创建控制器

控制器是用于处理路由和响应请求的工具。在应用根目录下的controllers文件夹中,我们创建三个控制器文件SiteController.phpQuestionController.phpAnswerController.php。以SiteController.php为例,代码如下:

<?php
namespace appcontrollers;

use yiiwebController;

class SiteController extends Controller
{
    public function actionIndex()
    {
        return $this->render('index');
    }
}
Nach dem Login kopieren

在这个文件中,我们定义了一个名为actionIndex的方法,用于渲染首页模板。

  1. 创建视图

视图是应用程序的用户界面部分,我们需要创建对应的视图文件来渲染内容。在应用根目录下的views文件夹中,我们创建三个文件夹sitequestionanswer,分别对应之前创建的三个控制器。

views/site文件夹中,我们创建一个名为index.php的文件,用于渲染首页模板。代码如下:

<h1>Welcome to the Question & Answer website!</h1>
Nach dem Login kopieren

views/question文件夹中,我们创建一个名为index.php的文件,用于渲染问题列表页面。代码如下:

<h1>Questions</h1>

<?php foreach ($questions as $question): ?>
  <div>
    <h2><?= $question->title ?></h2>
    <p><?= $question->content ?></p>
  </div>
<?php endforeach; ?>
Nach dem Login kopieren

views/answer文件夹中,我们创建一个名为create.php的文件,用于渲染回答编辑页面。代码如下:

<h1>Create Answer</h1>

<?= $this->render('_form', ['model' => $model]) ?>
Nach dem Login kopieren
  1. 创建路由

在Yii框架中,路由是用于将URL地址映射到对应的控制器和方法。我们需要在应用根目录下的config文件夹中的web.php文件中创建对应的路由规则。代码如下:

return [
    'components' => [
        'urlManager' => [
            'enablePrettyUrl' => true,
            'showScriptName' => false,
            'rules' => [
                '' => 'site/index',
                'question' => 'question/index',
                'answer/create/<question_id:d+>' => 'answer/create',
            ],
        ],
    ],
];
Nach dem Login kopieren

注意,我们在answer/create路由中使用了动态参数question_id,这个参数将在创建回答时用到。

  1. 创建授权系统

在问答网站中,用户需要进行登录才能进行提问和回答。我们需要创建一个基本的授权系统来实现用户登录和注册的功能。

SiteController.php中,我们添加了两个方法actionLoginactionSignup,用于渲染登录和注册页面。在UserController.php中,我们添加了一个名为actionCreate的方法,用于处理用户注册请求。具体代码实现略。

  1. 实现问答功能

在问答网站中,用户需要进行提问和回答。我们需要创建相关的功能来实现这两个操作。

QuestionController.php中,我们添加了两个方法actionIndexactionCreate,用于渲染问题列表和问题编辑页面。在QuestionController.php中,我们创建了一个名为actionCreate的方法,用于处理问题创建请求。具体代码实现略。

AnswerController.php中,我们创建了一个名为actionCreate

    Datenbankdesign🎜🎜🎜Bevor wir eine Q&A-Website erstellen, müssen wir zunächst die relevante Datenbankstruktur entwerfen. In diesem Artikel verwenden wir die folgenden Datenbanktabellen: 🎜
    🎜user: wird zum Speichern von Benutzerinformationen verwendet, einschließlich Benutzername, Passwort, E-Mail usw.; 🎜🎜question: wird zum Speichern von Frageninformationen verwendet, einschließlich Fragentitel und Inhalt , Veröffentlichungszeit usw.; 🎜🎜Antwort: Wird zum Speichern von Antwortinformationen verwendet, einschließlich Antwortinhalt, Antwortzeit usw. 🎜
🎜Hier verwenden wir MySQL als Backend-Datenbank und erstellen die entsprechende Datenbank und Tabelle mit den folgenden Befehlen: 🎜rrreee🎜Beachten Sie, dass wir Fremdschlüssel in der Tabelle festgelegt haben, um verschiedene Datentabellen zuzuordnen. 🎜
    🎜Erstellen Sie ein Modell🎜🎜🎜Im Yii-Framework sind Modelle die am häufigsten verwendeten Werkzeuge zum Betreiben von Datenbanken. Wir müssen entsprechende Modelldateien erstellen, um die zuvor erstellten Datenbanktabellen zu betreiben. 🎜🎜Im Ordner models im Stammverzeichnis der Anwendung erstellen wir drei Modelldateien User.php, Question.php, Answer .php. Am Beispiel von User.php lautet der Code wie folgt: 🎜rrreee🎜In dieser Datei definieren wir die Attribute des Modells, Validierungsregeln, Abfragemethoden, Beziehungen usw. 🎜
      🎜Erstellen Sie einen Controller🎜🎜🎜Controller sind Tools, die zur Weiterleitung und Beantwortung von Anfragen verwendet werden. Im Ordner controllers im Stammverzeichnis der Anwendung erstellen wir drei Controller-Dateien SiteController.php, QuestionController.php, AnswerController.php . Am Beispiel von SiteController.php lautet der Code wie folgt: 🎜rrreee🎜In dieser Datei definieren wir eine Methode namens actionIndex zum Rendern der Homepage-Vorlage. 🎜
        🎜Erstellen Sie eine Ansicht🎜🎜🎜Die Ansicht ist der Benutzeroberflächenteil der Anwendung. Wir müssen die entsprechende Ansichtsdatei erstellen, um den Inhalt darzustellen. Im Ordner views im Stammverzeichnis der Anwendung erstellen wir jeweils drei Ordner site, question und answer entsprechend den drei zuvor erstellten Controllern. 🎜🎜Im Ordner views/site erstellen wir eine Datei mit dem Namen index.php zum Rendern der Homepage-Vorlage. Der Code lautet wie folgt: 🎜rrreee🎜Im Ordner views/question erstellen wir eine Datei mit dem Namen index.php zum Rendern der Fragenlistenseite. Der Code lautet wie folgt: 🎜rrreee🎜Im Ordner views/answer erstellen wir eine Datei mit dem Namen create.php zum Rendern der Antwortbearbeitungsseite. Der Code lautet wie folgt: 🎜rrreee
          🎜Erstellen Sie eine Route🎜🎜🎜Im Yii-Framework wird Routing verwendet, um URL-Adressen entsprechenden Controllern und Methoden zuzuordnen. Wir müssen die entsprechenden Routing-Regeln in der Datei web.php im Ordner config im Stammverzeichnis der Anwendung erstellen. Der Code lautet wie folgt: 🎜rrreee🎜Beachten Sie, dass wir den dynamischen Parameter question_id in der Route answer/create verwendet haben, der beim Erstellen der Antwort verwendet wird. 🎜
            🎜Erstellen Sie ein Autorisierungssystem🎜🎜🎜Auf der Q&A-Website müssen sich Benutzer anmelden, um Fragen zu stellen und zu beantworten. Wir müssen ein grundlegendes Autorisierungssystem erstellen, um Benutzeranmelde- und Registrierungsfunktionen zu implementieren. 🎜🎜In SiteController.php haben wir zwei Methoden actionLogin und actionSignup zum Rendern von Anmelde- und Registrierungsseiten hinzugefügt. In UserController.php haben wir eine Methode namens actionCreate hinzugefügt, um Benutzerregistrierungsanfragen zu verarbeiten. Die spezifische Codeimplementierung wird weggelassen. 🎜
              🎜Implementieren Sie die Frage- und Antwortfunktion🎜🎜🎜Auf der Frage-und-Antwort-Website müssen Benutzer Fragen stellen und beantworten. Wir müssen relevante Funktionen erstellen, um diese beiden Operationen zu implementieren. 🎜🎜In QuestionController.php haben wir zwei Methoden actionIndex und actionCreate zum Rendern der Fragenliste und der Fragenbearbeitungsseite hinzugefügt. In QuestionController.php haben wir eine Methode namens actionCreate erstellt, um Fragenerstellungsanfragen zu verarbeiten. Die spezifische Codeimplementierung wird weggelassen. 🎜🎜In AnswerController.php haben wir eine Methode namens actionCreate erstellt, um Anfragen zur Antworterstellung zu verarbeiten. Die spezifische Codeimplementierung wird weggelassen. 🎜
              1. Testen

              Nach der oben genannten Entwicklungsarbeit haben wir eine grundlegende Q&A-Website fertiggestellt. Wir können die Problemliste öffnen, indem wir http://localhost/<project_name>来打开首页,通过访问http://localhost/<project_name>/question besuchen. Wir können auch über registrierte Benutzer Fragen stellen und beantworten.

Das obige ist der detaillierte Inhalt vonErstellen Sie eine Q&A-Website mit dem Yii-Framework. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage