Express使用

news2025/1/20 10:47:32

文章目录

  • Express 使用
    • 概述
    • 下载Express
    • 简单使用
    • Express 生成器
      • 安装生成器
      • 使用
    • 基本路由
      • 使用路由
      • 获取请求数据
      • 获取路由参数
      • 处理请求体
    • 设置响应
      • 方式一:兼容http模块
      • 方式二:express的响应方法
      • 其他响应
    • 中间件
      • 简介
      • 全局中间件
      • 路由中间件
      • 静态资源中间件
    • Router
      • 简介
      • 使用
      • 路由前缀
    • EJS 模板引擎
      • 简介
      • 安装EJS
      • 语法
      • 简单使用
      • 配合html使用
      • 设置模板引擎
    • 文件上传

Express 使用

概述

express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架。

官方网址:https://www.expressjs.com.cn

下载Express

npm i express

简单使用

一、创建js文件,写入下面代码:

// 导入express
const express = require("express");

// 创建应用对象
const app = express();

// 创建路由规则
app.get("/home", (request, response) => {
  response.end("hello express server");
});

// 启动服务,并监听端口
app.listen(9000, () => {
  console.log("服务器启动了");
});

二、执行命令:

node <"文件名">
//或
nodemon <"文件名">

三、在浏览器输入http://127.0.0.1:9000/home就能访问了。

Express 生成器

安装生成器

npm install -g express-generator

使用

一、使用express -e myapp命令,创建名为myapp的Express应用程序。

在这里插入图片描述

二、使用npm i命令,安装依赖。

三、使用npm start命令运行项目。

四、在浏览器端通过http://127.0.0.1:3000就能访问Express程序。

基本路由

官方定义: 路由确定了应用程序如何响应客户端对特定端点的请求。

使用路由

语法

一个路由的组成有:请求方法、路径、回调函数。

格式如下:

app.<method> (path, callback)

使用

// 导入express
const express = require("express");

// 创建应用对象
const app = express();

// 首页路由
app.get("/", (request, response) => {
  response.end("首页");
});

// get请求
app.get("/home", (request, response) => {
  response.end("home页面");
});

// post请求
app.post("/login", (request, response) => {
  response.send("登录成功");
});

// 匹配所有的请求方法
app.all("/search", (request, response) => {
  response.send("搜索成功");
});

// 定义404
app.all("*", (request, response) => {
  response.send("404 Not Found");
});

// 启动服务,并监听端口
app.listen(9000, () => {
  console.log("服务器启动了");
});

获取请求数据

const express = require("express");

const app = express();

app.all("/search", (request, response) => {
  // 获取请求方法
  console.log(request.method); 
  // 获取url
  console.log(request.url); 
  // 获取http版本
  console.log(request.httpVersion); 
  // 获取请求头
  console.log(request.headers); 
  // 获取指定请求头
  console.log(request.get("host"));
  // 获取url参数,是JSON对象格式
  console.log(request.query); 
  response.send("搜索成功");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

获取路由参数

路由参数指:URL路径中的参数。

app.all("/search/:keyword", (request, response) => {
  // 获取路由参数
  console.log(request.params.keyword);
  response.send("搜索成功");
});

处理请求体

Express没有内置获取请求体的API,需要借助第三方包body-parser

安装body-parser

npm i body-parser

使用

const express = require("express");
// 导入body-parser
const bodyParser = require("body-parser");

const app = express();

// 处理querystring格式,application/x-www-form-urlencoded
let urlParser = bodyParser.urlencoded({ extended: false });
// 处理json格式,application/json
let jsonParser = bodyParser.json();

// 设置中间件使用body-parser
app.all("/search1", urlParser, (request, response) => {
  console.log(request.body); //[Object: null prototype] { name: 'Tom', age: '18' }
  console.log(request.body.name); //Tom
  response.send("search1");
});

app.all("/search2", jsonParser, (request, response) => {
  console.log(request.body); //{ name: 'Jake', age: 19 }
  console.log(request.body.name); //Jake
  response.send("search2");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

设置响应

方式一:兼容http模块

const express = require("express");

const app = express();

app.all("/search", (request, response) => {
  // 设置http状态码
  response.statusCode = 404;
  // 设置http状态描述
  response.statusMessage = "Not Found";
  // 设置响应头
  response.setHeader("name", "Tom");
  response.setHeader("age", 18);
  // 设置响应体
  response.write("响应体1");
  response.write("响应体2");
  response.end("hello express");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

方式二:express的响应方法

const express = require("express");

const app = express();

app.all("/search", (request, response) => {
  //   response.status(404);
  //   response.set("name", "Tom");
  //   response.set("age", 18);
  //   response.send("响应体");
	
  // 连续调用
  response.status(404).set("name", "Tom").set("age", 18).send("响应体");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

其他响应

// 重定向
response.redirect("https://www.baidu.com/");
// 下载
response.download("./package.json");
// 响应JSON
let users = [
    { name: "Tom", age: 18, address: "北京" },
    { name: "Jake", age: 28, address: "上海" },
    { name: "Mike", age: 38, address: "广州" },
];
response.json(users);
// 响应文件
response.sendFile(__dirname + "/search.html");

中间件

简介

Express提供了全局中间件和路由中间件,用于处理应用程序的路由和请求。

中间件(Middleware)本质是一个回调函数。中间件函数可以像路由回调一样访问请求对象(request)、响应对象(response)。

全局中间件

全局中间件可以在应用程序的整个生命周期中使用,而不需要在每个组件中都使用。

express 允许使用 app.use() 定义多个全局中间件。

日志记录

const express = require("express");
const fs = require("fs");
const path = require("path");

const app = express();

// 定义全局中间件
function recordMiddleware(request, response, next) {
  let { url, ip } = request;
  fs.appendFileSync(path.resolve(__dirname, "access.log"), `${url} ${ip}\r\n`);
  next();
}

// 使用全局中间件
app.use(recordMiddleware);

app.all("/search", (request, response) => {
  response.send("search");
});
app.all("/home", (request, response) => {
  response.send("home");
});
app.all("/login", (request, response) => {
  response.send("login");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

判断是否登录

// 定义中间件
function checkLoginMiddleware(request, response, next) {
  if (request.query.token === "123") {
    next();
  } else {
    response.send("请先登录");
  }
}

// 可以设置多个全局中间件
app.use(recordMiddleware);
app.use(checkLoginMiddleware);

路由中间件

路由中间件通常用于处理路由请求。

app.all(
  "/search",
  recordMiddleware,
  checkLoginMiddleware,
  (request, response) => {
    response.send("search");
  }
);

静态资源中间件

express 内置处理静态资源的中间件。

const express = require("express");

const app = express();

// 设置静态资源中间件,讲public目录作为网站的跟目录
app.use(express.static("./public"));

app.all("/home", (request, response) => {
  response.send("home");
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

说明:

在这里插入图片描述

在当前文件夹下新建public文件夹,并在public文件夹里新建home.html网页,接着在public文件夹里新建css文件夹,在css文件夹里新建home.css样式。

这时访问http://127.0.0.1:9000/home,Express会返回“home”。

访问http://127.0.0.1:9000/home.html,Express会返回home.html的网页内容和css样式。

Router

简介

Express 中的 Router 是一个完整的中间件和路由系统,可以看做是一个小型的 app 对象。

Router的作用是对路由进行模块化,更好的管理路由。

路由的行为类似于中间件本身,因此您可以将其用作 app.use() 的参数或用作另一个路由的 use() 方法的参数。

使用

新建routes文件夹,在其中新建homeRouter.js文件并写入下面代码:

// 导入Express
const express = require("express");

// 创建路由器对象
const router = express.Router();

// 定义路由
router.get("/", (request, response) => {
  response.send("首页");
});

// 定义路由
router.get("/search", (request, response) => {
  response.send("search页面");
});

// 暴露路由器对象
module.exports = router;

在主文件中使用子路由:

const express = require("express");

const app = express();

// 引入子路由
const homeRouter = require("./routes/homeRouter");

// 使用子路由
app.use(homeRouter);

app.listen(9000, () => {
  console.log("服务器启动了");
});

说明:

在浏览器中输入http://127.0.0.1:9000/,Express返回“首页”;

输入http://127.0.0.1:9000/search,Express返回“search页面”。

路由前缀

// 设置路由前缀
app.use("/home", homeRouter);

说明:

在浏览器中输入http://127.0.0.1:9000/home,Express返回“首页”;

输入http://127.0.0.1:9000/home/search,Express返回“search页面”。

EJS 模板引擎

简介

模板引擎是分离 用户界面和业务数据 的一种技术。

EJS 是一个高效的 Javascript 的模板引擎。

官网: https://ejs.co/

中文站:https://ejs.bootcss.com/

安装EJS

npm i ejs

语法

<% code %> :执行js代码。
<%= code %>:输出转义的数据到模板上
<%- code %>:输出非转义的数据到模板上

简单使用

const express = require("express");
// 导入ejs
const ejs = require("ejs");

const app = express();

app.get("/", (request, response) => {
  let persons = ["张三", "李四", "王五"];
  // 渲染
  let html = ejs.render('<%= persons.join(",") %>', { persons });
  response.send(html);
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

配合html使用

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <p>姓名:<%= name %></p>
    <p>年龄:<%= age %></p>
    <ul>
      <% address.forEach(item => { %>
      <li><%= item %></li>
      <% }) %>
    </ul>
  </body>
</html>
const express = require("express");
const fs = require("fs");
// 导入ejs
const ejs = require("ejs");

const app = express();

app.get("/", (request, response) => {
  let name = "小明";
  let age = 18;
  let address = ["广东省", "广州市", "白云区"];
  // 读取html
  let html = fs.readFileSync("./index.html").toString();
  // 渲染
  let bodyData = ejs.render(html, { name, age, address });
  response.send(bodyData);
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

设置模板引擎

步骤一:新建views文件夹,在其中新建home.ejs文件,类似于HTML页面,可以使用ejs语法,写入下面代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <p>姓名:<%= name %></p>
    <p>年龄:<%= age %></p>
    <ul>
      <% address.forEach(item => { %>
      <li><%= item %></li>
      <% }) %>
    </ul>
  </body>
</html>

步骤二:在主文件中写入下面代码:

const express = require("express");
const path = require("path");

const app = express();

// 设置模板引擎
app.set("view engine", "ejs");
// 设置模板文件存放路径
app.set("views", path.resolve(__dirname, "views"));

app.get("/home", (request, response) => {
  let name = "小明";
  let age = 18;
  let address = ["广东省", "广州市", "白云区"];
  // 渲染
  response.render("home", { name, age, address });
});

app.listen(9000, () => {
  console.log("服务器启动了");
});

文件上传

文件上传需要解析请求体,可以使用第三方包formidable,安装如下:

npm install formidable

一、新建index.ejs视图文件:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>文件上传</title>
  </head>
  <body>
    <h2>文件上传</h2>
    <form action="/portrait" method="post" enctype="multipart/form-data">
      <p>用户名:<input type="text" name="username" /></p>
      <p>头像:<input type="file" name="portrait" /></p>
      <button>提交</button>
    </form>
  </body>
</html>

二、新建index.js路由文件:

const express = require("express");
const formidable = require("formidable");
var router = express.Router();

// /* GET home page. */
// router.get("/", function (req, res, next) {
//   res.render("index", { title: "Express" });
// });

router.get("/portrait", (request, response) => {
  response.render("portrait");
});
router.post("/portrait", (request, response) => {
  const form = formidable({
    multiples: true,
    // 上传文件的保存目录
    uploadDir: __dirname + "/../public/images",
    // 保持文件后缀名
    keepExtensions: true,
  });
  // 解析请求体
  form.parse(request, (err, fields, files) => {
    if (err) {
      next(err);
      return;
    }
    let url = "/images/" + files.portrait.newFilename;
    response.send(url);
  });
});

module.exports = router;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/418418.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SkyWalking服务应用

文章目录SkyWalking服务应用案例准备案例实施1.部署Elasticsearch服务2.部署SkyWalking OAP服务3.部署SkyWalking UI服务4.搭建并启动应用商城服务SkyWalking服务应用 案例准备 节点规划 IP主机名节点192.168.100.10node-1Skywalking实验节点192.168.100.20mall商城搭建节点…

【毕业设计】基于程序化生成和音频检测的生态仿真与3D内容生成系统----程序化生成地形算法设计

2 程序化生成地形算法设计 2.1 地形曲线的生成 2.1.1 初始化高度场 struct Make2DGridPrimitive : INode {virtual void apply() override {size_t nx get_input<NumericObject>("nx")->get<int>();nx std::max(nx, (size_t)1);size_t ny has_in…

适配器详解

目录 1、适配器简介 2、函数对象适配器 ​编辑 3、函数指针作为适配器 ptr_fun ​编辑 4、类中的成员函数作为适配器 mem_fun_ref 5、取反适配器 5.1、not1 一元取反适配器 ​编辑 5.2、not2 二元取反适配器 1、适配器简介 适配器 为算法 提供接口目前的适配器最多能扩…

第一次习题总结

目录 求第K个数 求逆序对的数量 数的三次方根 一维前缀和 二维前缀和&#xff08;子矩阵的和&#xff09; 求第K个数 思路&#xff1a;用快速选择&#xff0c;时间复杂度为O(N) sl和sr是左边和右边数的个数&#xff0c;当k<sl&#xff0c;即倒数第K个数在左边范围内&#x…

【JY】减隔震设计思考:隔震篇

【写在前文】随着隔标颁布&#xff0c;国内外大大小小的地震的经历。越来越多的人重视减隔震分析和设计&#xff0c;也听到不少的疑惑声音&#xff0c;个人也有一点热点问题的感悟与大家分享。在个人看来&#xff1a;建筑减隔震&#xff1a;七分构造三分算&#xff01;特别注意…

[Netty源码] Netty轻量级对象池实现分析 (十三)

文章目录1.对象池技术介绍2.如何实现对象池3.Netty对象池实现分析3.1 Recycler3.2 Handler3.3 Stack3.4 WeakOrderQueue3.5 Link4.总结1.对象池技术介绍 对象池其实就是缓存一些对象从而避免大量创建同一个类型的对象, 类似线程池。对象池缓存了一些已经创建好的对象, 避免需要…

uni-app--》什么是uniapp?如何开发uniapp?

&#x1f3cd;️作者简介&#xff1a;大家好&#xff0c;我是亦世凡华、渴望知识储备自己的一名在校大学生 &#x1f6f5;个人主页&#xff1a;亦世凡华、 &#x1f6fa;系列专栏&#xff1a;uni-app &#x1f6b2;座右铭&#xff1a;人生亦可燃烧&#xff0c;亦可腐败&#xf…

企业电子招投标采购系统源码——功能模块功能描述+数字化采购管理 采购招投标

​ 功能模块&#xff1a; 待办消息&#xff0c;招标公告&#xff0c;中标公告&#xff0c;信息发布 描述&#xff1a; 全过程数字化采购管理&#xff0c;打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力&#xff0c;为外…

HTTP API接口设计规范

1. 所有请求使用POST方法 使用post&#xff0c;相对于get的query string&#xff0c;可以支持复杂类型的请求参数。例如日常项目中碰到get请求参数为数组类型的情况。 便于对请求和响应统一做签名、加密、日志等处理 2. URL规则 URL中只能含有英文&#xff0c;使用英文单词或…

Docker配置DL envs教程

Docker容器与镜像的区别 Docker镜像类似于虚拟镜像&#xff0c;是一个只读的文件&#xff0c;包括进程需要运行所需要的可执行文件、依赖软件、库文件、配置文件等等。 而容器则是基于镜像创建的进程&#xff0c;可以利用容器来运行应用。 总结来说&#xff0c;镜像只读&#…

贾俊平《统计学》第七章知识点总结及课后习题答案

一.考点归纳 参数估计的基本原理 1置信区间 &#xff08;1&#xff09;置信水平为95%的置信区间的含义&#xff1a;用某种方法构造的所有区间中有95%的区间包含总体参数的真值。&#xff08;2&#xff09;置信度愈高&#xff08;即估计的可靠性愈高&#xff09;&#xff0c;则…

ABeam News | ABeam Consulting 荣获『SAP AWARD OF EXCELLENCE 2023』奖项

ABeam Consulting株式会社&#xff08;总裁兼CEO 鸭居 达哉、东京都千代田区、以下简称为ABeam Consulting&#xff09;在SAP 日本株式会社&#xff08;董事长 铃木洋史、东京都千代田区、以下简称为SAP日本&#xff09;表彰优秀合作伙伴的颁奖『SAP AWARD OF EXCELLENCE 2023』…

c3p0报错java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector

1. 问题由来 今天第一次学习到c3p0的时候&#xff0c;学习资料上使用的是0.9.1.2版本。 我偷懒使用的是0.9.2版本。但是运行的时候会报错&#xff1a; 网上搜索了一下这个错误&#xff0c;很多人说去安装mchange-commons-0.2.jar 这个包 但是我看学习资料上没有去另外安装这…

nodejs+vue 图书借阅管理系统

该系统的应用可以减少工作人员的劳动强度&#xff0c;提高工作效率与管理水平&#xff0c;具有很大的价值。它可以使图书这项借阅业务操作简单&#xff0c;成功率高&#xff0c;使网上图书管理系统的管理工作向一个新的层次迈进。本论文是以构建图书借阅为目标&#xff0c;使用…

《100天精通Python丨从快速入门到黑科技》 >>> 目录导航

文章目录一、100 天精通 Python 丨基础知识篇100 天精通 Python 丨基础知识篇 —— 01、C 站最全 Python 标准库总结100 天精通 Python 丨基础知识篇 —— 02、Python 和 Pycharm&#xff08;语言特点、学习方法、工具安装&#xff09;100 天精通 Python 丨基础知识篇 —— 03、…

基于AIGC的3D场景创作引擎概述

通过改变3D场景制作流程复杂、成本高、门槛高、流动性差的现状&#xff0c;让商家像玩转2D一样去玩转3D&#xff0c;让普通消费者也能参与到3D内容创作和消费中&#xff0c;真正实现内容生产模式从PGC/UGC过渡到AIGC&#xff0c;是我们3D场景智能创作引擎一直追求的目标。前言随…

【VMD-SSA-LSSVM】基于变分模态分解与麻雀优化Lssvm的负荷预测【多变量】(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

【C++基础】引用(引用的概念;引用的特性;常引用;使用场景:做输出型参数、大对象传参、做输出型返回值、返回大对象的引用);引用和指针的区别)

六、引用 6.1 引用的概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;它和它引用的变量共用同一块内存空间。&#xff08;语法上&#xff09; 格式&#xff1a;类型& 引用变量名(对象名) …

矮床酸阻滞技术及其在酸回收行业的应用

废酸是如何产生的&#xff1f; 为什么要进行废酸回收&#xff1f; 在轧钢厂在轧制过程中&#xff0c;铁与氧或铁与燃料燃烧时的生成物(CO2、H2O等)的化学作用&#xff0c;而形成一层氧化层&#xff0c;称为氧化皮。其实我们日常生活中接触到的金属件&#xff0c;尤其是铁件上的…

mmsegmentation 训练自己的数据集

一. MMSegmentation是什么&#xff1f; MMSegmentation 是一个基于 PyTorch 的语义分割开源工具箱&#xff0c;它是 OpenMMLab 项目的一部分。他与MMDetection类似&#xff0c;集成了各种语义分割算法&#xff0c;可以快速验证语义分割效果。 二. 环境准备 参考&#xff1a…