【利用AI让知识体系化】入门Egg框架(含实战)(二)

简介: 【利用AI让知识体系化】入门Egg框架(含实战)

【利用AI让知识体系化】入门Egg框架(含实战)(一)https://developer.aliyun.com/article/1426068


3.2 模板渲染和视图

在 Egg.js 应用中,模板渲染和视图也是实现页面展示和用户交互的重要组成部分。

模板渲染

Egg.js 默认使用模板引擎 nunjucks,支持多种模板文件格式,如 .html.nunjucks.nj 等。

在 Egg.js 中,可以通过 app.view.use('nunjucks', nunjucks) 方法启用 nunjucks 模板引擎,然后使用 this.ctx.render() 方法渲染模板文件。通常,模板文件的根目录是 /app/view,渲染的文件名不需要后缀,例如:

// 启用模板引擎
const nunjucks = require('nunjucks');
module.exports = app => {
  app.view.use('nunjucks', nunjucks.configure('app/view', {
    autoescape: true
  }));
};
// 控制器中渲染模板文件
class HomeController extends Controller {
  async index() {
    const { ctx } = this;
    await ctx.render('index', { data: 'hello world' });
  }
}

在上述代码中,模板文件的根目录是 app/view,渲染的文件名是 index。在控制器中,使用 this.ctx.render() 方法渲染模板文件,并传入需要注入的数据对象。

视图

在 Egg.js 应用中,视图的实现方式和其他框架类似。视图通常是由模板引擎根据模板文件渲染生成,可以通过模板引擎向视图中注入数据来实现动态页面展示和用户交互的效果。

与模板引擎相关的视图文件通常位于 /app/view 目录下,可以根据需要自行组织子目录。在控制器中,通过 this.ctx.render() 方法渲染视图,并通过第二个参数传入要注入的数据对象。

在 Egg.js 应用中,可以使用多种模板引擎,根据需要进行选择和配置。同时,视图的实现方式也可以和其他框架一样,通过 HTML、CSS 和 JavaScript 等前端技术实现视图的效果。

3.3 静态资源和文件上传

在 Egg.js 应用中,静态资源和文件上传也是实现页面展示和用户交互的重要组成部分。

静态资源

在 Egg.js 应用中,可以使用 egg-static 插件提供静态资源服务。在项目中安装 egg-static 插件:

npm i egg-static --save

安装完毕之后,在应用的 config/config.default.js 里面配置静态文件存放路径:

exports.static = {
  prefix: '/public/',
  dir: path.join(appInfo.baseDir, 'app/public'),
};

在上述代码中,prefix 是访问静态资源的 URI 的前缀,dir 是静态资源存放的目录,根据实际需求进行配置。

之后使用以下代码启用中间件,在路由之前处理静态资源的请求:

// config/config.default.js
module.exports = app => {
  app.config.coreMiddleware.unshift('static');
};

文件上传

在 Egg.js 应用中,可以使用 egg-multipart 插件实现文件上传。安装 egg-multipart 插件:

npm i egg-multipart --save

安装完毕之后,在应用的 config/plugin.js 文件中启用插件,并定义插件的配置:

exports.multipart = {
  mode: 'file',
  fileSize: '10mb',
  whitelist: [
    '.jpeg',
    '.jpg',
    '.png',
    '.gif',
    '.bmp',
    '.txt',
    '.doc',
    '.docx',
    '.zip',
    '.rar',
    '.gzip',
  ],
};

在控制器中,可以通过 this.ctx.request.files 获取上传的文件:

async upload() {
  const { ctx } = this;
  const file = ctx.request.files[0];
  const { name, path } = file;
  // 处理上传的文件
  ...
  ctx.body = { name, path };
}

上传的文件会被存储在 Egg.js 应用的临时文件夹中,使用 this.ctx.request.files 获取上传的文件路径,可以对文件进行后续的处理或保存。结果被序列化为一个对象,包含文件的名称、路径和大小等信息。

以上是 Egg.js 中处理静态资源和文件上传的常用方法,可以根据实际需求进行定制和配置

3.4 数据库连接和操作

在 Egg.js 应用中,可以使用 egg-sequelize 插件连接和操作 MySQL、PostgreSQL、SQLite 和 MSSQL 等关系型数据库。

连接数据库

在 Egg.js 应用中,可以在 config/config.default.js 中配置数据库连接信息:

const Sequelize = require('sequelize');
exports.sequelize = {
  dialect: 'mysql',
  host: 'localhost',
  port: 3306,
  database: 'testdb',
  username: 'testuser',
  password: 'testpass',
  define: {
    timestamps: true,
    paranoid: true,
    underscored: true,
    freezeTableName: true,
  },
  timezone: '+08:00',
  dialectOptions: {
    dateStrings: true,
    typeCast: true,
  },
  pool: {
    max: 5,
    min: 0,
    idle: 10000,
  },
};

在以上示例中,定义了连接MySQL测试数据库的相关信息,通过 exports.sequelize 属性导出。其中,

  • dialect 定义了要连接的数据库类型。
  • hostport 定义了数据库的主机名和端口号。
  • database 定义了要连接的数据库名称。
  • usernamepassword 定义了连接数据库的用户名和密码。

操作数据库

一般情况下,我们会在控制器中操作数据库。以下是一个示例,以获取用户列表为例:

class UserController extends Controller {
  async index() {
    const { ctx } = this;
    const users = await ctx.model.User.findAll();
    ctx.body = users;
  }
}

使用 ctx.model.xxx 可以访问模型对象。在数据库查询时,通常会使用 await 关键字,待查询结束后获取返回的结果即可。

除此以外,还有很多其他的操作数据库的方法,可根据需求进行探索和使用。

需要注意的是,不同数据库的连接方式、查询方式等可能会有所不同,具体的实现方式需参考具体数据库的文档,并结合 Egg.js 的使用方式进行实现。

3.5 Cookie 和 Session

在 Egg.js 应用中,Cookie 和 Session 是管理 HTTP 请求和响应的重要组成部分。

Cookie

Cookie 是一种用于存储小量数据的机制。在 Egg.js 应用中,可以通过 this.cookies.set() 方法设置 Cookie,通过 this.cookies.get() 方法获取 Cookie。例如:

// 设置 cookie
this.cookies.set('username', 'testuser');
// 获取 cookie
const username = this.cookies.get('username');

在以上示例中,this.cookies.set() 方法设置了一个名为 username 的 Cookie,值为 testuserthis.cookies.get() 方法获取名为 username 的 Cookie 的值,并将其保存在 username 变量中。

除了设置和获取 Cookie 之外,还可以通过设置 Cookie 的属性修改其有效期、域和路径等信息。例如:

this.cookies.set('username', 'testuser', {
  maxAge: 3600 * 1000, // 1 hour
  httpOnly: true,
});

在以上示例中,maxAge 属性设置 Cookie 的失效时间,单位为毫秒;httpOnly 属性设置 Cookie 是否仅允许服务器访问,防止 XSS 攻击。

Session

Session 是一种在客户端和服务器端之间存储用户数据的机制。在 Egg.js 应用中,可以使用 egg-session 插件实现 session 管理。首先,在应用中安装 egg-session 插件:

npm i egg-session --save

配置及启用 session:

// config/config.default.js
exports.session = {
  key: 'SESSION_ID',
  maxAge: 86400000,
  httpOnly: true,
  encrypt: true,
};
// app.js
app.use(session(app));

在以上示例中,exports.session 配置了 Session 的名称、有效期、是否仅允许服务器访问和是否需要加密传输。在 app.js 文件中启用了 session 中间件。

在路由中使用 Session:

await ctx.session.set('username', 'testuser');
const username = await ctx.session.get('username');

在以上示例中,使用 ctx.session.set() 方法设置 Session 的值,使用 ctx.session.get() 方法获取 Session 的值。

需要注意的是,Session 的数据量较大时、过于频繁的操作 Session 都会对应用性能产生影响,因此在使用时应当权衡利弊,根据实际需求合理配置和使用。


【利用AI让知识体系化】入门Egg框架(含实战)(三)https://developer.aliyun.com/article/1426070

相关文章
|
24天前
|
存储 人工智能 分布式计算
Parquet 文件格式详解与实战 | AI应用开发
Parquet 是一种列式存储文件格式,专为大规模数据处理设计,广泛应用于 Hadoop 生态系统及其他大数据平台。本文介绍 Parquet 的特点和作用,并演示如何在 Python 中使用 Pandas 库生成和读取 Parquet 文件,包括环境准备、生成和读取文件的具体步骤。【10月更文挑战第13天】
189 60
|
14天前
|
机器学习/深度学习 人工智能 自然语言处理
探索AI的奥秘:机器学习入门指南
【10月更文挑战第30天】本篇文章是一份初学者友好的机器学习入门指南,旨在帮助读者理解并开始实践机器学习。我们将介绍机器学习的基本概念,包括监督学习、无监督学习和强化学习等。我们还将提供一些实用的代码示例,以帮助读者更好地理解和应用这些概念。无论你是编程新手,还是有一定经验的开发者,这篇文章都将为你提供一个清晰的机器学习入门路径。
32 2
|
28天前
|
人工智能 安全 决策智能
OpenAI推出实验性“Swarm”框架,引发关于AI驱动自动化的争论
OpenAI推出实验性“Swarm”框架,引发关于AI驱动自动化的争论
|
22天前
|
人工智能 API 决策智能
swarm Agent框架入门指南:构建与编排多智能体系统的利器 | AI应用开发
Swarm是OpenAI在2024年10月12日宣布开源的一个实验性质的多智能体编排框架。其核心目标是让智能体之间的协调和执行变得更轻量级、更容易控制和测试。Swarm框架的主要特性包括轻量化、易于使用和高度可定制性,非常适合处理大量独立的功能和指令。【10月更文挑战第15天】
156 6
|
30天前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
23天前
|
存储 人工智能 Java
Neo4j从入门到精通:打造高效知识图谱数据库 | AI应用开发
在大数据和人工智能时代,知识图谱作为一种高效的数据表示和查询方式,逐渐受到广泛关注。本文从入门到精通,详细介绍知识图谱及其存储工具Neo4j,涵盖知识图谱的介绍、Neo4j的特点、安装步骤、使用方法(创建、查询)及Cypher查询语言的详细讲解。通过本文,读者将全面了解如何利用Neo4j处理复杂关系数据。【10月更文挑战第14天】
88 6
|
24天前
|
人工智能 资源调度 数据可视化
【AI应用落地实战】智能文档处理本地部署——可视化文档解析前端TextIn ParseX实践
2024长沙·中国1024程序员节以“智能应用新生态”为主题,吸引了众多技术大咖。合合信息展示了“智能文档处理百宝箱”的三大工具:可视化文档解析前端TextIn ParseX、向量化acge-embedding模型和文档解析测评工具markdown_tester,助力智能文档处理与知识管理。
|
14天前
|
机器学习/深度学习 人工智能 算法
AI赋能大学计划·大模型技术与应用实战学生训练营——吉林大学站圆满结营
10月30日,由中国软件行业校园招聘与实习公共服务平台携手魔搭社区共同举办的AI赋能大学计划·大模型技术与产业趋势高校行AIGC项目实战营·吉林大学站圆满结营。
|
5天前
|
机器学习/深度学习 人工智能 自然语言处理
当前AI大模型在软件开发中的创新应用与挑战
2024年,AI大模型在软件开发领域的应用正重塑传统流程,从自动化编码、智能协作到代码审查和测试,显著提升了开发效率和代码质量。然而,技术挑战、伦理安全及模型可解释性等问题仍需解决。未来,AI将继续推动软件开发向更高效、智能化方向发展。
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
AI在医疗领域的应用及其挑战
【10月更文挑战第34天】本文将探讨人工智能(AI)在医疗领域的应用及其面临的挑战。我们将从AI技术的基本概念入手,然后详细介绍其在医疗领域的各种应用,如疾病诊断、药物研发、患者护理等。最后,我们将讨论AI在医疗领域面临的主要挑战,包括数据隐私、算法偏见、法规合规等问题。
29 1

热门文章

最新文章