0

0

在 Drupal 中创建自定义页面的完整指南

聖光之護

聖光之護

发布时间:2025-10-03 18:47:00

|

952人浏览过

|

来源于php中文网

原创

在 drupal 中创建自定义页面的完整指南

本教程旨在指导开发者如何在 Drupal 中创建一个简单的自定义页面,显示 "Hello, world"。我们将详细介绍模块的创建、路由配置、控制器编写等步骤,并提供示例代码,帮助读者快速上手 Drupal 的模块开发。通过本教程,你将掌握在 Drupal 中构建自定义页面的基本方法,为更复杂的模块开发奠定基础。

创建自定义模块

在 Drupal 中创建自定义页面,通常需要创建一个自定义模块。模块是 Drupal 功能扩展的基本单元。

  1. 创建模块目录: 在 modules/custom 目录下创建一个名为 hello 的目录。这是我们自定义模块的根目录。如果 modules/custom 目录不存在,请先创建它。

  2. 创建 hello.info.yml 文件: 在 hello 目录下创建一个名为 hello.info.yml 的文件,用于描述模块的基本信息。

    name: Hello World Module
    description: Creates a page showing "Hello World".
    package: Custom
    
    type: module
    core_version_requirement: ^8 || ^9 || ^10
    • name: 模块的名称。
    • description: 模块的描述。
    • package: 模块所属的包,通常设置为 "Custom"。
    • type: 模块类型,设置为 "module"。
    • core_version_requirement: Drupal 核心版本要求,确保模块与 Drupal 版本兼容。

定义路由

路由定义了 URL 路径与控制器之间的映射关系。

  1. 创建 hello.routing.yml 文件: 在 hello 目录下创建一个名为 hello.routing.yml 的文件,用于定义路由。

    hello.my_page:
      path: '/hello'
      defaults:
        _controller: '\Drupal\hello\Controller\ExampleController::myPage'
        _title: 'My first page in D9'
      requirements:
        _permission: 'access content'
    • hello.my_page: 路由的名称,必须唯一。
    • path: URL 路径,用户访问该路径时将触发该路由。
    • defaults: 定义了控制器和页面标题。
      • _controller: 指定控制器类和方法,格式为 \Drupal\{模块名}\Controller\{控制器类名}::{方法名}。
      • _title: 页面的标题。
    • requirements: 定义了访问权限。
      • _permission: 指定用户需要拥有的权限才能访问该页面。access content 是一个常用的权限,允许用户访问内容。

创建控制器

控制器负责处理请求并返回响应。

中小企业网站系统前台源码(SmallBusinessStarterKit)
中小企业网站系统前台源码(SmallBusinessStarterKit)

小型企业入门套件(The Small Business Starter Kit)提供了一个商业宣传网站的完整演示,他适合中小型企业。使用他创建的网站支持自定义模板,具有先进的功能,包括:内容和数据管理的SQL和XML数据源整合。该源码包含C#和VB两个版本,只有前台部分源码,微软官方截止到51aspx发布源码时还没有提供后台代码。小型企业网站入门套件的关键页面包括:产品分类显示新闻发布显示商户认证

下载
  1. 创建 src/Controller 目录: 在 hello 目录下创建一个名为 src 的目录,然后在 src 目录下创建一个名为 Controller 的目录。

  2. 创建 ExampleController.php 文件: 在 src/Controller 目录下创建一个名为 ExampleController.php 的文件,用于定义控制器类。

     'Hello, world',
        ];
      }
    }
    • namespace: 命名空间必须与模块目录结构一致。
    • class ExampleController: 控制器类名。
    • extends ControllerBase: 继承 ControllerBase 类,提供了一些常用的方法。
    • public function myPage(): 控制器方法,用于处理请求并返回响应。
      • return ['#markup' => 'Hello, world'];: 返回一个包含 HTML 标记的渲染数组,Drupal 将渲染该数组并显示在页面上。

启用模块并清除缓存

  1. 启用模块: 登录 Drupal 管理后台,进入 admin/modules 页面,找到 "Hello World Module" 模块,勾选并启用它。

  2. 清除缓存: 进入 admin/config/development/performance 页面,点击 "清除所有缓存" 按钮。

访问页面

浏览器中输入 /hello 或 index.php/hello 即可访问自定义页面,看到 "Hello, world" 的内容。

注意事项

  • 命名空间: 确保命名空间与模块目录结构一致,这是最常见的错误。
  • 缓存: 在修改模块代码后,必须清除缓存才能使更改生效。
  • 权限: 确保用户拥有访问该页面的权限。
  • 服务器配置: 如果出现 "Page not found" 错误,可能是服务器配置问题,例如 URL 重写未启用。

总结

通过以上步骤,你已经成功创建了一个简单的 Drupal 自定义页面。这个例子虽然简单,但涵盖了 Drupal 模块开发的基本要素。你可以基于此扩展功能,创建更复杂的模块。建议学习 PHP 的面向对象编程和 Symfony 框架的基础知识,以便更好地利用 Drupal 的强大功能。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2602

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1626

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1510

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

40

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号