AdonisJS 框架教程:构建全栈 Web 应用程序

简介: AdonisJS 框架教程:构建全栈 Web 应用程序

AdonisJs是什么?

AdonisJs 是一个基于 Laravel 的 Node.js 框架。它实现了依赖注入和提供者的相似概念、优美的代码和直观的设计。AdonisJs 旨在为开发人员带来工作中的快乐和轻松,这就是为什么它蔑视用于全栈 Web 应用程序开发的一致且富有表现力的 API。

这个 Laravel 风格的 MVC 框架专注于创建可扩展、稳定和可扩展的 Web 应用程序的核心方面,例如:

  • 愉快的开发者体验
  • 一致的API
  • 速度和生产力
  • 支持邮件、身份验证、数据验证、Redis 等

AdonisJs 优点和缺点

让我们来看看 AdonisJs 最显着的优缺点。

优点

  • 文件夹结构:  AdonisJs 提供了一个方便的文件夹结构,可以很容易地保持井井有条。
  • 验证器:  AdonisJs 提供了一个专用的验证提供程序,可以轻松验证用户输入
  • Lucid ORM:  AdonisJs 对 MariaDB 和 MySQL 等数据库具有一流的支持。
  • ICO 和服务提供商:  AdonisJs 提供了一种通过 IOC 管理依赖项的简单方法。服务提供商可以管理生命周期依赖性。
  • 安全性:  AdonisJs 附带了一些工具来保护网站免受常见的 Web 攻击,例如跨站点伪造保护。
  • 测试:  AdonisJS 使开发人员能够编写功能单元测试来测试他们的 Web 应用程序,从而减轻了手动测试的挑战。

 缺点

  • 社区: 由于 AdonisJs 比较新且不太受欢迎,因此用户和支持社区很小。这意味着如果您遇到困难,您不太可能找到支持。
  • 文档:  AdonisJs 的文档目前不成熟,这意味着某些部分不完整。
  • 插件: 由于 AdonisJs 的受欢迎程度和年代久远,可用的插件较少
  • 未经过“实战测试”: 由于使用 AdonisJs 构建的大型网站较少,因此与其他框架相比,它尚未经过生产实战测试。

AdonisJs文件夹结构

现在我们有了一个正常运行的应用程序,让我们在开始我们的第一个应用程序之前了解更多关于它的文件结构。AdonisJs 具有 MVC 结构,可以轻松组织文件。这种结构使我们能够保持井井有条并在以后扩展文件。

复习: 模型视图控制器 (MVC) 架构由三部分组成:

  1. 模型:用于维护数据的最低级别的模式。
  2. 查看:这使用户能够查看数据。
  3. Controller:控制Model和View的软件代码。

让我们看看 AdonisJs 文件夹结构并定义一些关键术语。

网络异常,图片无法展示
|

应用程序

app 文件夹包含应用程序逻辑,包括:

  • 控制器: 它们控制逻辑流。控制器可以与路由绑定在一起。
  • 中间件: 中间件包含要在 HTTP 请求之前或之后执行的方法。
  • 模型: 这些定义了数据库模型和关系。

可以在 app 文件夹中创建更多文件夹,如 Validators、Exceptions、Helpers 和 ModelFilter。

配置

这是我们的应用程序配置存储的地方。我们也可以在这里创建我们的配置文件。

数据库

我们使用此文件夹来存储迁移、种子和工厂。

民众

这是我们放置静态文件的地方,例如图像、CSS 和 JavaScript 文件。它们将直接通过 HTTP 调用。

资源

这是我们放置视图模板和 Edge 模板文件的地方。

开始

这些文件用于加载应用程序。这也是我们可以创建 Events、Redis 和 Hooks 等文件的地方。

.env

.env 文件位于根文件夹中。它将包含与我们的工作环境相关的所有变量。开发和生产通常有不同的设置。

高手

ace 文件用于执行特定于项目的命令。

包.json

这是一个标准的 Node.js 文件。

服务器.js

该文件引导 HTTP 服务器。

创建一个基本的应用程序

现在我们已经熟悉了 AdonisJs,让我们学习如何实际制作我们的第一个应用程序。入门非常简单。首先,您必须从官方网站下载 AdonisJs,或者您现在可以跟随 Educative 的嵌入式编码小部件。

我们将从adonis可执行文件开始创建我们的第一个应用程序。在这个例子中,我们将制作一个博客应用程序。

adonis new blog
复制代码

此命令创建一个名为 blog 的新项目。接下来,我们将cd进入启动服务器的目录。

cd blog
npm run dev
复制代码

输出:

[nodemon] starting `node --harmony_proxies server.js`
info adonis:framework serving app on http://localhost:3333
复制代码

创建路线

start/routes.js文件定义了供用户访问的 URL 模式,作为 Web 应用程序的入口点。当用户请求 URL 时,Adonis 会在 中找到 URL 模式start/routes.js,因此如果模式匹配,Adonis 会处理该路由内的逻辑。

我们可以将路由与控制器绑定为逻辑处理程序,并将路由附加到中间件和验证器。

AdonisJs 提供了一个渲染视图的默认路由welcome.njk。要从头开始,我们必须先删除它。下面,我们实现了为主页和联系页面注册 2 个不同路由的代码。

'use strict'
const Route = use('Route')
Route.on('/').render('home')
Route.on('/contact').render('contact')
复制代码

创建控制器

控制器处理应用程序逻辑。它们与我们的模型、视图和助手相关联。控制器响应 HTTP 请求,因此它们不应该包含在其他文件中。

提示: 尝试将控制器重构到单独的文件中,以避免代码混乱。

'use strict'
class TestController {
 hello(){
   return 'Hello from Controller'
 }
}
module.exports = TestController
复制代码

输出:

“来自控制器的问候”

app/Controllers/Http/TestController.js文件中,我们创建了一个名为hello(). 我们在第 20 行访问控制器。TestController是控制器的名称,hello是方法的名称。

网络异常,图片无法展示
|

创建视图

视图是用户可见的组件。视图以扩展名保存在 resources/views 目录中.njk。下面,我们从上面为我们的页面创建两个视图。

./ace make:view home
./ace make:view contact
复制代码

Ace 是 Adonis 的命令行实用工具,用于制作视图、控制器和模型。

我们可以在我们创建的文件中使用 HTML 添加到我们的视图。在下面的示例中,使用 Bootstrap 进行设计。

<!DOCTYPE html>
<html>
<head>
  <link rel="stylesheet" href="https://cdn.rawgit.com/twbs/bootstrap/v4-dev/dist/css/bootstrap.css">
  <link rel="stylesheet" href="/style.css">
</head>
<body>
  <div class="container">
    <div class="header clearfix">
      <nav>
        <ul class="nav nav-pills pull-xs-right">
          <li class="nav-item"><a href="/" class="nav-link">Home</a></li>
          <li class="nav-item"><a href="/about" class="nav-link">About</a></li>
          <li class="nav-item"><a href="/contact" class="nav-link">Contact</a></li>
        </ul>
        <h3 class="text-muted"> Adonis Blog </h3>
      </nav>
    </div>
    <section>
      {% block content %}{% endblock %}
    </section>
  </div>
</body>
</html>
复制代码

从那里,我们可以将基本模板扩展到其他视图并在文件中添加 CSS public/style.css

AdonisJs 应用程序的一部分

现在我们知道如何创建一个基本的应用程序,但使用 Adonis 仍然有很多问题。让我们回顾一下您需要了解的其他一些重要术语。

中间件

中间件是一组在 HTTP 请求到达路由器之前或之后运行的函数。中间件分为三种类型:

  • 服务器: 在请求到达路由器系统之前执行
  • 全局: 当路由模式匹配 URL 请求时执行。
  • named: 依附于特定路由或路由组并为之执行

中间件在文件夹内创建app/Middleware并在文件内注册start/kernel.js

网络异常,图片无法展示
|

例如,我们可以创建命名身份验证中间件,以便只有登录用户才能访问该站点。

'use strict';
class AuthRequired {
 async handle ({ auth, response }, next) {
   try {
     await auth.check()
   } catch (error) {
     return response.json({
       error: "Unauthorized access"
     })
   }
   // call next() to advance the request
   await next()
 }
}
module.exports = AuthRequired;
复制代码

请求方法

请求对象提供获取请求信息的方法。我们可以在start/route.js文件中创建到 URL 的路由。AdonisJs 使用全局中间件为任何 URL 请求创建一个请求对象。

全局中间件默认完成这个BodyParser。请求方式有很多种。下面我们列举几个:

  • request.all() :返回一个包含所有请求数据(包括查询参数和请求体数据)的对象。
  • request.get() :返回包含查询参数数据的对象。
  • request.post() :返回一个对象,其中包含来自提交表单的请求正文数据。
  • request.input(key) :返回指定键的值。


相关文章
|
7天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
81 44
|
2天前
|
缓存 前端开发 JavaScript
构建高性能与用户体验并重的现代Web应用
构建高性能与用户体验并重的现代Web应用
15 5
|
4天前
|
监控 前端开发 JavaScript
探索微前端架构:构建可扩展的现代Web应用
【10月更文挑战第29天】本文探讨了微前端架构的核心概念、优势及实施策略,通过将大型前端应用拆分为多个独立的微应用,提高开发效率、增强可维护性,并支持灵活的技术选型。实际案例包括Spotify和Zalando的成功应用。
|
2天前
|
前端开发 JavaScript jenkins
构建高效、可维护的Web应用
构建高效、可维护的Web应用
15 2
|
3天前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP是一种流行的服务器端脚本语言,自诞生以来在Web开发领域占据重要地位。从简单的网页脚本到支持面向对象编程的现代语言,PHP经历了多次重大更新。本文探讨PHP的现代演进历程,重点介绍其在Web开发中的应用及框架创新,如Laravel、Symfony等。这些框架不仅简化了开发流程,还提高了开发效率和安全性。
9 3
|
2天前
|
前端开发 JavaScript 开发工具
从框架到现代Web开发实践
从框架到现代Web开发实践
8 1
|
6天前
|
SQL 安全 PHP
探索PHP的现代演进:从Web开发到框架创新
PHP 自发布以来一直在 Web 开发领域占据重要地位,历经多次重大更新,从简单的脚本语言进化为支持面向对象编程的现代语言。本文探讨 PHP 的演进历程,重点介绍其在 Web 开发中的应用及框架创新。自 PHP 5.3 引入命名空间后,PHP 迈向了面向对象编程时代;PHP 7 通过优化内核大幅提升性能;PHP 8 更是带来了属性、刚性类型等新特性。
14 3
|
6天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
8天前
|
前端开发 JavaScript
Bootstrap Web 前端 UI 框架
Bootstrap 是快速开发 Web 应用程序的前端工具包。
22 3
|
8天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
26 2

热门文章

最新文章