GoravelGoravel
首页
视频
  • English
  • 简体中文
GitHub
首页
视频
  • English
  • 简体中文
GitHub
  • 前言

    • 升级指南

      • 从 v1.14 升级到 v1.15
      • 从 v1.13 升级到 v1.14
      • 历史版本升级
    • 贡献指南
    • 优秀扩展包
  • 入门指南

    • 安装
    • 配置信息
    • 文件夹结构
    • 编译
  • 核心架构

    • 请求周期
    • 服务容器
    • 服务提供者
    • Facades
  • 基本功能

    • 路由
    • HTTP 中间件
    • 控制器
    • 请求
    • 响应
    • 视图
    • Grpc
    • Session
    • 表单验证
    • 日志
  • 综合话题

    • Artisan 命令行
    • 缓存系统
    • 事件系统
    • 文件储存
    • 邮件
    • 队列
    • 任务调度
    • 本地化
    • 扩展包开发
    • 颜色
    • Strings
    • 辅助函数
  • 安全相关

    • 用户验证
    • 用户授权
    • 加密解密
    • 哈希
  • ORM

    • 快速入门
    • 模型关联
    • 数据库迁移
    • 数据填充
    • 模型工厂
  • 测试相关

    • 快速入门
    • HTTP Tests
    • Mock

控制器

  • 简介
  • 定义控制器
    • 创建控制器
  • 资源型控制器

简介

为了代替在单独路由中以闭包形式定义所有的请求处理逻辑,可以使用控制器来进行整合。控制器被存放在 app/http/controllers 目录中。

定义控制器

下面是一个基础控制器类的例子:

package controllers

import (
  "github.com/goravel/framework/contracts/http"
  "github.com/goravel/framework/facades"
)

type UserController struct {
  // Dependent services
}

func NewUserController() *UserController {
  return &UserController{
    // Inject services
  }
}

func (r *UserController) Show(ctx http.Context) http.Response {
  return ctx.Response().Success().Json(http.Json{
    "Hello": "Goravel",
  })
}

路由定义:

package routes

import (
  "github.com/goravel/framework/facades"

  "goravel/app/http/controllers"
)

func Web() {
  userController := controllers.NewUserController()
  facades.Route().Get("/{id}", userController.Show)
}

创建控制器

go run . artisan make:controller UserController
go run . artisan make:controller user/UserController

资源型控制器

如果您将应用程序中的每个模型都视为资源,那么通常对应用程序中的每个资源都执行相同的操作。例如,假设您的应用程序中包含一个 Photo 模型和一个 Movie 模型。用户可能可以创建,读取,更新或者删除这些资源。

Goravel 的资源路由通过单行代码即可将典型的「CURD (增删改查)」路由分配给控制器。首先,我们可以使用 Artisan 命令 make:controller 的 --resource 选项来快速创建一个控制器:

go run . artisan make:controller --resource PhotoController

这个命令将会生成一个控制器 app/http/controllers/photo_controller.go。其中包括每个可用资源操作的方法。接下来,您可以给控制器注册一个资源路由:

facades.Route().Resource("photos", controllers.NewPhotoController())
请求方式请求URI行为
GET/photosIndex
POST/photosStore
GET/photos/{photo}Show
PUT/PATCH/photos/{photo}Update
DELETE/photos/{photo}Destroy
Edit this page
Prev
HTTP 中间件
Next
请求