Maison  >  Article  >  cadre php  >  Créer un site Web de questions et réponses à l'aide du framework Yii

Créer un site Web de questions et réponses à l'aide du framework Yii

WBOY
WBOYoriginal
2023-06-21 09:36:021194parcourir

Yii framework est un framework PHP puissant qui aide les développeurs à créer rapidement des applications Web hautes performances et évolutives. Cet article explique comment utiliser le framework Yii pour créer un site Web de questions-réponses.

  1. Préparation de l'environnement

Avant de commencer, nous devons nous assurer que les logiciels et outils nécessaires tels que PHP et MySQL ont été correctement configurés dans le local environnement de développement. Dans le même temps, nous devons également installer le framework Yii pour faciliter les travaux de développement ultérieurs.

Installer le framework Yii est très simple, il suffit d'exécuter la commande suivante :

composer create-project yiisoft/yii2-app-basic <project_name>

4fc59f85b86f3cdcf539b23b3b2209e3 est le nom du projet en cours . 4fc59f85b86f3cdcf539b23b3b2209e3为当前项目的名称。

  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`)
);

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

  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']);
    }
}

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

  1. 创建控制器

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

<?php
namespace appcontrollers;

use yiiwebController;

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

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

  1. 创建视图

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

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

<h1>Welcome to the Question & Answer website!</h1>

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

<h1>Questions</h1>

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

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

<h1>Create Answer</h1>

<?= $this->render('_form', ['model' => $model]) ?>
  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',
            ],
        ],
    ],
];

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

  1. 创建授权系统

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

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

  1. 实现问答功能

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

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

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

    Conception de base de données#🎜🎜##🎜🎜##🎜🎜#Avant de créer un site Web de questions-réponses, nous devons d'abord concevoir la structure de la base de données appropriée. Dans cet article, nous utiliserons la table de base de données suivante : #🎜🎜#
    #🎜🎜#user : utilisée pour stocker les informations sur l'utilisateur, notamment le nom d'utilisateur, le mot de passe, l'e-mail, etc. ; question : utilisé pour stocker les informations sur la question, y compris le titre de la question, le contenu, l'heure de publication, etc. ; #🎜🎜##🎜🎜#answer : utilisé pour stocker les informations sur la réponse, y compris le contenu de la réponse, l'heure de réponse, etc. #🎜🎜#
#🎜🎜#Ici, nous utilisons MySQL comme base de données back-end et créons la base de données et la table correspondantes via les commandes suivantes : #🎜🎜#rrreee#🎜🎜#Notez que nous définissons les clés externes sont utilisés pour relier différents tableaux de données. #🎜🎜#
    #🎜🎜#Créer un modèle #🎜🎜##🎜🎜##🎜🎜#Dans le framework Yii, les modèles sont les outils les plus couramment utilisés pour faire fonctionner des bases de données. Nous devons créer les fichiers modèles correspondants pour faire fonctionner les tables de base de données créées précédemment. #🎜🎜##🎜🎜#Dans le dossier models sous le répertoire racine de l'application, nous créons trois fichiers modèles User.php, Question.php, <code>Answer.php. En prenant comme exemple User.php, le code est le suivant : #🎜🎜#rrreee#🎜🎜#Dans ce fichier, nous définissons les attributs du modèle, les règles de validation, les méthodes de requête et les relations, etc. #🎜🎜#
      #🎜🎜#Créer un contrôleur #🎜🎜##🎜🎜##🎜🎜#Les contrôleurs sont des outils utilisés pour gérer le routage et répondre aux requêtes. Dans le dossier controllers sous le répertoire racine de l'application, nous créons trois fichiers de contrôleur SiteController.php, QuestionController.php, AnswerController.php . En prenant SiteController.php comme exemple, le code est le suivant : #🎜🎜#rrreee#🎜🎜#Dans ce fichier, nous définissons une méthode nommée actionIndex pour rendre le modèle de page d'accueil. #🎜🎜#
        #🎜🎜#Créer une vue #🎜🎜##🎜🎜##🎜🎜#La vue est la partie de l'interface utilisateur de l'application, nous devons créer le fichier de vue correspondant pour restituer le contenu. Dans le dossier views sous le répertoire racine de l'application, nous créons respectivement trois dossiers site, question et answer correspondant aux trois contrôleurs créés précédemment. #🎜🎜##🎜🎜#Dans le dossier views/site, nous créons un fichier nommé index.php pour le rendu du modèle de page d'accueil. Le code est le suivant : #🎜🎜#rrreee#🎜🎜#Dans le dossier views/question, nous créons un fichier nommé index.php pour le rendu de la page de liste de questions . Le code est le suivant : #🎜🎜#rrreee#🎜🎜#Dans le dossier views/answer, nous créons un fichier nommé create.php pour le rendu de la page d'édition des réponses. Le code est le suivant : #🎜🎜#rrreee
          #🎜🎜#Create route#🎜🎜##🎜🎜##🎜🎜#Dans le framework Yii, le routage est utilisé pour mapper les adresses URL vers Contrôleurs et méthodes correspondants. Nous devons créer les règles de routage correspondantes dans le fichier web.php du dossier config dans le répertoire racine de l'application. Le code est le suivant : #🎜🎜#rrreee#🎜🎜#Notez que nous avons utilisé le paramètre dynamique question_id dans la route answer/create. Ce paramètre sera utilisé lorsque. créer la réponse. #🎜🎜#
            #🎜🎜#Créer un système d'autorisation#🎜🎜##🎜🎜##🎜🎜#Sur le site Web de questions-réponses, les utilisateurs doivent se connecter pour poser et répondre à des questions. Nous devons créer un système d'autorisation de base pour mettre en œuvre les fonctions de connexion et d'enregistrement des utilisateurs. #🎜🎜##🎜🎜#Dans SiteController.php, nous avons ajouté deux méthodes actionLogin et actionSignup pour le rendu de la page de connexion et d'inscription. Dans UserController.php, nous avons ajouté une méthode nommée actionCreate pour gérer les demandes d'enregistrement des utilisateurs. L'implémentation spécifique du code est omise. #🎜🎜#
              #🎜🎜# Implémenter la fonction de questions et réponses #🎜🎜##🎜🎜##🎜🎜# Dans le site Web de questions et réponses, les utilisateurs doivent poser et répondre à des questions. Nous devons créer des fonctions pertinentes pour mettre en œuvre ces deux opérations. #🎜🎜##🎜🎜#Dans QuestionController.php, nous avons ajouté deux méthodes actionIndex et actionCreate pour afficher la liste de questions et la page d'édition des problèmes. . Dans QuestionController.php, nous avons créé une méthode appelée actionCreate pour gérer les demandes de création de questions. L'implémentation spécifique du code est omise. #🎜🎜##🎜🎜#Dans AnswerController.php, nous avons créé une méthode nommée actionCreate pour gérer les demandes de création de réponses. L'implémentation spécifique du code est omise. #🎜🎜#
              1. Tests

              Après le travail de développement ci-dessus, nous avons réalisé un site Web de questions-réponses de base. Nous pouvons ouvrir la liste des problèmes en visitant http://localhost/4fc59f85b86f3cdcf539b23b3b2209e3来打开首页,通过访问http://localhost/4fc59f85b86f3cdcf539b23b3b2209e3/question. Nous pouvons également poser et répondre à des questions via des utilisateurs enregistrés.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn