我们使用Phpstorm打开我们的项目目录,展开项目目录文件夹。

Symfony项目其实也是composer项目,如果你新拿到一个Symfony项目, 你可以在控制台中使用composer install命令来安装这个项目所需要的依赖包。

现在我们看一下项目的目录结构。

bin目录下是console文件。如果你没有安装Symfony命令行工具,我们可以使用php bin/console来查看所有可用的命令。

在开发过程中,我们会大量的使用命令行工具来辅助开发。如果你安装了Symfony命令行工具,你可以使用Symfony console命令,来使用命令行工具。

它的底层也是调用了项目的console文件。

config目录是我们的配置文件目录,一些第三方的包包括一些项目的配置文件都在config目录中。通常使用yaml文件来进行配置。在Symfony中,yaml配置文件使用四个空格来进行排版。

public是我们Symfony项目的入口目录,index.php文件就在这里。如果我们项目有一些CSS或者JS资源,也存放在public目录中。它是可以公开访问的目录。

src目录是我们的源码目录,我们编写的所有代码都在src目录中。

var目录是缓存文件和日志文件目录。

vendor目录,当我们安装第三方的包或者Symfony组件时,所有的组件都会安装在vendor目录中。vendor目录中的文件不能修改。如果组件版本更新的话,修改的文件将会丢失。

我们来使用PHP内置的服务器来启动项目,我们可以使用Symfony命令行工具的serve命令来启动项目。在http://127.0.0.1:8000端口,我们就可以访问我们的项目了。

Symfony默认给了我们一个页面。我们没有编写任何一行代码,但是仍然可以访问这个页面。这是Symfony为我们提供的占位符页面。虽然它已经显示了,但这个页面仍然是404错误的页面。 我们刷新看一下错误代码,仍然是404。

下面我们将创建我们第一个页面。我们打开composer.json文件,Symfony为我们安装了symfony/flex这个组件。flex组件是Symfony的composer插件。使用flex我们很方便的就可以把Symfony的组件或者第三方的包,安装到Symfony中,并且进行自动化的配置。

Symfony中为了自动化的安装组件或者包并进行自动化的配置,提出了一个recipe的概念。它的中文翻译就是食谱。我们打开symfony.sh这个网站。在这里我们可以查看所有Symfony的组件和第三方的包。

当我们安装这个页面上的任意的包时,recipe就是这个包对应的配置文件。它就像食谱一样,指引这个包如何和我们的Symfony项目集成。 Symfony的flex组件将会自动下载对应的recipe配置文件,到我们的项目中,来完成这个包和我项目的集成。

我们想快速的开发我们第一个页面,我们搜索组件makermaker组件下方一个official官方这个标签。代表这是官方提供的包,官方提供的包都可以使用别名来进行安装。 如果是社区贡献的包,它没有别名的概念。

回到项目,我们使用composer req maker --dev来安装这个包。包安装完成后,我们在composer.json文件中,我们看到require-dev下,maker-bundle已经安装成功了。

require-dev下的包仅用于开发环境,当我们在生产环境下部署项目时,我们可以使用composer install --no-dev来忽略掉dev下所有的bundle。

我们再次查看symfony console命令,这时它就给我们生成了make命令,所有的make命令都是由maker-bundle提供的。我们使用make命令来创建我们的第一个页面。

Symfony是MVC框架,MVC的C就是controller。当有请求访问的时候,controller负责读取请求的参数,然后根据请求参数来执行不同的数据操作,最后返回一个响应对象,然后响应对象发送到浏览器。

我们在控制台中输入symfony console make:controller命令,来创建controller。这里报错了,它提示我们缺少了一个包。我们复制这个命令安装一下。

再次使用make:controller命令,我们需要输入controller类名,这里输入TestController。命令行会在src/Controller目录中创建对应的controller类。

这一行是PHP8.0提供的原生注解。Route是个路由,当我们访问/test路径时,Symfony会调用controller的index方法,最终会返回json方法提供的数据。

我们按command键点击json(windows系统按ctrl键),最终响应的是JsonResponse响应对象。我们回到首页输入/test,它返回了一个json字串。这不是我们想要的结果。

我们需要它显示一个页面,回到项目手动创建一个Response对象,这里输入HTML代码。

    #[Route("/test", name: "test")]
public function index(): Response
{
return new Response(<<<EOF
<html>
<head>
<title>这是我们的第一个页面</title>
</head>
<body>
<h1>Hello world</h1>
</body>
</html>
EOF
);
}

回到页面刷新,我们第一个页面它显示了。我们看到我们的源代码,就是刚才自己写的代码。

在下一节我们将讲解一下HTTP协议和Symfony是如何处理这个/test请求的。

本文转载于:https://www.teebb.com/content/first-page

《Symfony 5全面开发》教程03、使用Controller创建第一个页面的更多相关文章

  1. 微信小程序开发教程(二)创建第一个微信小程序

    在安装完“微信Web开发者工具”之后,通过开发者的微信扫码进入后,如图. 点击“添加项目”,填入之前获得的AppID(无AppID可忽略),输入项目名称“Hello WXapplet”,选定本地文件夹 ...

  2. 微信小程序从零开始开发步骤(二)创建小程序页面

    上一章注册完小程序,添加新建的项目,大致的准备开发已经完成,本章要分享的是 要创建一个简单的页面了,创建小程序页面的具体几个步骤: 1. 在pages 中添加一个目录 选中page,右击鼠标,从硬盘打 ...

  3. cocos2d-x游戏开发(二)之创建第一个项目

    配置好开发环境之后,尝试创建一个cocos项目 (1)打开cocos2d-x安装目录,如D:\DIY\cocos2d-x-3.3 看到目录下有可执行文件 download-deps 以及 setup ...

  4. Android快乐贪吃蛇游戏实战项目开发教程-03虚拟方向键(二)绘制一个三角形

    该系列教程概述与目录:http://www.cnblogs.com/chengyujia/p/5787111.html 一.绘制三角形 在上一篇文章中,我们已经新建了虚拟方向键的自定义控件Direct ...

  5. iOS开发教程:Storyboard全解析-第一部分

    本文转载至http://blog.csdn.net/chang6520/article/details/7945845 感谢原文作者分享     故事版(Storyboard)是一个能够节省你很多设计 ...

  6. Android教程-01 Android Studio创建第一个项目

    视频教程建议采用超清模式, 关注更多视频订阅我的优酷 最近一直使用Android Studio 简单把Android Studio介绍下 1. 首先介绍下 Android Studio的快捷键 由于之 ...

  7. Android快乐贪吃蛇游戏实战项目开发教程-01项目概述与目录

    一.项目简介 贪吃蛇是一个很经典的游戏,也很适合用来学习.本教程将和大家一起做一个Android版的贪吃蛇游戏. 我已经将做好的案例上传到了应用宝,无病毒.无广告,大家可以放心下载下来把玩一下.应用宝 ...

  8. Android开发教程大全介绍

    Android是由谷歌在2007年推出的一个开放系统平台,主要针对移动设备市场,目前版本为Android 4.0.Android基于Linux,开发者可以使用Java或C/C++开发Android应用 ...

  9. [ABP教程]第三章 创建、更新和删除图书

    Web应用程序开发教程 - 第三章: 创建,更新和删除图书 关于本教程 在本系列教程中, 你将构建一个名为 Acme.BookStore 的用于管理书籍及其作者列表的基于ABP的应用程序. 它是使用以 ...

随机推荐

  1. golang中的RPC开发-2

    RPC简介 远程过程调用(Remote Procedure Call,RPC)是一个计算机通信协议 该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序员无需额外地为这个交互作用编程 如果 ...

  2. gin中multipart/urlencoded绑定

    package main import ( "fmt" "github.com/gin-gonic/gin" "net/http" ) ty ...

  3. Filter的拦截路径

    Filter的拦截路径 精确匹配 <url-pattern>/target.jsp</url-pattern> 以上配置的路径,表示请求地址必须为:http://ip.port ...

  4. iptables的概念与底层原理(详解)

    目录 一:iptables 1.iptables简介 2.什么是防火墙? 3.防火墙种类 二:iptables基本介绍 1.解析内容 三:iptables流程(讲解) 1.流入本机 2.解析(流入本机 ...

  5. Matplotlib直方图绘制技巧

    情境引入 我们在做机器学习相关项目时,常常会分析数据集的样本分布,而这就需要用到直方图的绘制. 在Python中可以很容易地调用matplotlib.pyplot的hist函数来绘制直方图.不过,该函 ...

  6. 【建议收藏】Redis超详细入门教程大杂烩

    写在前边 Redis入门的整合篇.本篇也算是把2021年redis留下来的坑填上去,重新整合了一翻,点击这里,回顾我的2020与2021~一名大二后台练习生 NoSQL NoSQL(NoSQL = N ...

  7. Lesson3——NumPy 数据类型

    NumPy 教程目录 NumPy 数据类型 numpy 支持的数据类型比 Python 内置的类型要多很多,基本上可以和 C 语言的数据类型对应上,其中部分类型对应为 Python 内置的类型. 下表 ...

  8. 如何将EDI报文转换为CSV格式文件?

    如果您对EDI项目实施有一定的了解,想必您一定知道,在正式开始EDI项目实施之前,都会有EDI顾问与您接洽,沟通EDI项目需求.其中,会包含EDI通信双方使用哪种传输协议,传输的报文是符合什么标准的, ...

  9. libcurl库openssl编译

    openssl编译 win32: perl Configure  no-shared VC-WIN32 --prefix=E:/lib/openssl-1.1.1 linux: ./config -f ...

  10. java多线程编程(一)

    一.概念基础 进程:正在进行中的程序(直译). 线程:就是进程中一个负责程序执行的控制单元(执行路径) 一个进程中可以多执行路径,称之为多线程. 一个进程中至少要有一个线程. 开启多个线程是为了同时运 ...