深入理解:单一入口、MVC、ORM、CURD、ActiveRecord概念

下面我会详细讲解这五个概念的含义以及它们在 web 开发中的应用。

下面我会详细讲解这五个概念的含义以及它们在 web 开发中的应用。

单一入口

单一入口即指整个 web 应用只有一个入口文件,不同的 URL 请求通过路由映射到不同的控制器,由控制器负责调用相应的模型和视图完成处理和输出的过程。使用单一入口设计可以提高代码可维护性,降低耦合度,同时也能够提高系统的安全性。

示例:一个简单的单一入口的实现方式是在一个 PHP 文件中统一处理不同的请求,具体实现可以使用路由解析,例如:

<?php
// 引入路由类
require_once 'Route.php';

// 定义路由规则
Route::add('/', function() {
    echo '首页';
});

Route::add('/about', function() {
    echo '关于我们';
});

Route::add('/contact', function() {
    echo '联系我们';
});

// 执行路由匹配
Route::run('/');

MVC

MVC 是一种软件架构模式,将应用程序分为三个部分:模型(Model)、视图(View)和控制器(Controller)。模型负责处理数据和状态,视图负责呈现界面,控制器负责处理用户输入并更新模型和视图。使用 MVC 可以将应用程序的代码分隔开来,提高代码的可维护性,降低耦合度。

示例:以一个简单的博客应用为例,实现一个基于 MVC 架构的博客系统,我们可以将代码分为以下三个部分:

  1. 模型层(Model):实现对博客文章的增删改查操作。
class Post
{
    public function getPosts()
    {
        // 查询所有博客文章的数据
    }

    public function createPost($data)
    {
        // 创建一篇博客文章
    }

    public function updatePost($id, $data)
    {
        // 更新指定 ID 的博客文章
    }

    public function deletePost($id)
    {
        // 删除指定 ID 的博客文章
    }
}
  1. 视图层(View):实现对应用程序界面的呈现。
<h1>博客文章列表</h1>
<ul>
    <?php foreach ($posts as $post) { ?>
        <li>
            <h2><?php echo $post['title']; ?></h2>
            <p><?php echo $post['content']; ?></p>
        </li>
    <?php } ?>
</ul>
  1. 控制器层(Controller):实现对用户请求的处理。
class PostController
{
    protected $post;

    public function __construct()
    {
        $this->post = new Post();
    }

    public function index()
    {
        $posts = $this->post->getPosts();
        View::render('posts/index.php', ['posts' => $posts]);
    }

    public function create()
    {
        // 处理博客文章的创建请求
    }

    public function edit($id)
    {
        // 处理博客文章的编辑请求
    }

    public function update($id)
    {
        // 处理博客文章的更新请求
    }

    public function delete($id)
    {
        // 处理博客文章的删除请求
    }
}

ORM

ORM(Object-Relational Mapping)是一种程序设计技术,它将数据库和面向对象编程语言之间的数据映射关系固化到代码中,使得数据库表中的每一行数据可以对应到具体的对象,从而简化了程序员的编码工作。使用 ORM 可以使得开发者不需要编写 SQL 语句,从而提高代码编写效率。

示例:以 PHP 语言为例,假设我们有一个用户表 users,使用 ORM 实现对该表的操作:

// 定义用户模型类,继承 Orm 类
class User extends Orm {
    // 定义用户模型所关联的数据表名
    protected $table = 'users';

    // 定义用户模型对应的数据表的主键字段名,Ork 会自动使用该字段名进行数据查询和更新操作
    protected $primaryKey = 'id';

    // 定义用户模型所包含的字段名
    protected $fields = ['id', 'name', 'email', 'password'];

    // 可选,定义用户模型所对应的表中的字段名与 PHP 属性名的映射关系,方便 ORM 自动转换数据类型
    protected $formFields = [
        'id' => 'int',
        'name' => 'string',
        'email' => 'string',
        'password' => 'string'
    ]
}

// 查找 ID 为 1 的用户
$user = User::where('id', 1)->first();

// 更新用户信息
$user->name = '张三';
$user->email = 'zhangsan@qq.com';
$user->save();

CURD

CURD 是指增删改查四种操作。在 web 应用中,CURD 操作通常指对数据库中的数据进行增加、删除、修改和查询。

示例:以 PHP 语言为例,实现对博客文章的增删改查操作:

class PostController
{
    protected $post;

    public function __construct()
    {
        $this->post = new Post();
    }

    // 查询所有博客文章
    public function index()
    {
        $posts = $this->post->getPosts();
        View::render('posts/index.php', ['posts' => $posts]);
    }

    // 显示创建博客文章的表单
    public function create()
    {
        View::render('posts/create.php');
    }

    // 处理博客文章的创建请求
    public function store()
    {
        $data = $_POST;
        $this->post->createPost($data);
        header('Location: /posts');
    }

    // 显示编辑博客文章的表单
    public function edit($id)
    {
        $post = $this->post->getPostById($id);
        View::render('posts/edit.php', ['post' => $post]);
    }

    // 处理博客文章的更新请求
    public function update($id)
    {
        $data = $_POST;
        $this->post->updatePost($id, $data);
        header('Location: /posts');
    }

    // 处理博客文章的删除请求
    public function delete($id)
    {
        $this->post->deletePost($id);
        header('Location: /posts');
    }
}

ActiveRecord

ActiveRecord 是一种面向对象的设计模式,它将业务对象和数据库表中的行一一映射,使得操作业务对象就是在操作数据库表中的行记录。在 web 应用中,ActiveRecord 可以用于封装数据库操作的详细细节,简化代码编写,提高程序代码的可维护性。

示例:以 PHP 语言为例,使用 ActiveRecord 实现对博客文章的增删改查操作:

// 定义博客文章模型
class Post extends ActiveRecord
{
    protected static $table = 'posts';
    protected static $primaryKey = 'id';

    public $id;
    public $title;
    public $content;
    public $author;

    public function getPosts()
    {
        $posts = self::findAll();
        return $posts;
    }
}

// 创建一篇博客文章
$post = new Post();
$post->title = '示例文章';
$post->content = '这是一篇示例文章';
$post->author = 'Admin';
$post->save();

// 查询所有博客文章的数据
$posts = Post::findAll();

// 更新一篇博客文章
$post = Post::findOne(1);
$post->title = '更新后的示例文章';
$post->save();

// 删除一篇博客文章
$post = Post::findOne(1);
$post->delete();

本文标题为:深入理解:单一入口、MVC、ORM、CURD、ActiveRecord概念

基础教程推荐