第八章认识Express框架
目录
Express模块化路由
基本概述
基本使用
基本构建
案例项目
Express接收请求参数
基本概述
基本类别
Express接收GET请求参数
Express接收POST请求参数
Express接收路由参数
Express模块化路由
基本概述
在Express中,路由是指确定应用程序如何响应对特定端点的客户端请求,包括获取、添加、更新和删除资源等。
当应用程序收到请求时,它通常需要确定如何响应该请求,这由路由来完成。在Express应用程序中,可以使用模块化路由来更好地组织路由代码并提高其可读性和可维护性。
模块化路由是指将路由器代码分解为多个小文件,并将每个文件映射到路由路径。
这样做的好处是可以在应用程序中轻松添加或删除路由路径,同时使代码更易于阅读和维护。使用Express的Router函数,可以轻松地将路由器添加到应用程序中,使其成为模块化的路由器。
每个Express路由器是一个中间件,它可以在其中定义一个或多个路由。
路由有一个HTTP方法,如get、post、put、delete等,以及一个指定路由路径的路径。
当路由被触发时,将执行一个或多个处理程序函数,这些函数将确定如何响应请求。可以使用app.use()方法将路由器添加到应用程序中。这样当收到请求时,Express将自动将请求路由到正确的路由器中。
基本使用
实现模块化路由需要用到express.Router()方法来创建一个新的路由器对象(route),然后使用route.get()和route.post()来注册当前模块路由对象下的二级路由,形成一个简单的模块化路由。
- express.Router()方法定义route对象的示例代码如下:
const route = express.Router();
//express.Router()表示创建模块化路由对象
提示:这行代码使用
express.Router()方法创建了一个新的路由对象route,该对象可以用来注册该模块下的路由处理函数,即该模块下的所有路由都会在route对象上定义,以实现模块化的路由设计。使用
express.Router()方法创建一个新的路由对象,可以避免使用全局的 app 对象来定义路由,提高代码的可读性,也更容易维护。这段代码中的
const是用来声明常量的关键字,而route则是该常量的名称。
- route对象可以定义二级路由,示例代码如下:
route.get('请求路径','请求处理函数');
route.post('请求路径','请求处理函数');
这两行代码使用
route.get()和route.post()方法来注册当前模块路由对象下的二级路由,具体来说:
route.get('请求路径', '请求处理函数')方法用于在route路由对象上定义 GET 请求的路由,其中'请求路径'指定路由路径,'请求处理函数'指定该路由的处理函数。route.post('请求路径', '请求处理函数')方法用于在route路由对象上定义 POST 请求的路由,其中'请求路径'指定路由路径,'请求处理函数'指定该路由的处理函数。通过这两个方法,可以在当前模块下定义所需的所有路由,即可实现模块化的路由设计。
- route对象创建成功后,使用app.use()注册route模块化路由,示例如下:
app.use('请求路径',route);
这行代码使用了
app.use()方法,将定义好的route路由对象注册到了 Express 应用中,并制定了该路由对象的请求路径。具体来说,
app.use('请求路径', route)的含义为:
请求路径:指定了路由所监听的路径,即当客户端发起该路径的请求时,会触发该路由对象中的相应路由处理函数。route:指定了该路由对象,即之前定义的express.Router()创建的路由对象。这行代码的作用是将路由对象注册到应用中,使得应用可以通过该路由对象来处理对应的二级路由请求。
综上所诉,模块化路由的基本使用的步骤如下:
- 创建一个模块化的路由对象:
const express = require('express'); const router = express.Router(); - 为路由对象添加一个或多个路由:
router.get('/', function(req, res) {res.send('Hello World!'); }); router.get('/user/:id', function(req, res) {res.send('user ' + req.params.id); }); - 把路由对象挂载到应用程序中的指定路径:
这个例子中,我们把路由对象挂载到app.use('/api', router);/api的路径下,因此访问/api或/api/user/:id时都会使用我们刚刚定义的路由规则。
完整的示例代码如下:
const express = require('express');
const app = express();// 创建一个模块化的路由对象
const router = express.Router();// 为路由对象添加一个或多个路由
router.get('/', function(req, res) {res.send('Hello World!');
});
router.get('/user/:id', function(req, res) {res.send('user ' + req.params.id);
});// 把路由对象挂载到应用程序中的指定路径
app.use('/api', router);// 启动应用程序
app.listen(3000, function() {console.log('App is listening on port 3000!');
});
这样,当我们访问 http://localhost:3000/api 时,会显示 Hello World!,访问 http://localhost:3000/api/user/123 时会显示 user 123。
代码注释
const express = require('express');导入 express 模块。
const app = express();创建一个 Express 应用程序实例。
const router = express.Router();创建一个模块化的路由对象。
router.get('/', function(req, res) {...}为路由对象添加一个 GET 请求处理函数,当用户访问路径为/时,返回Hello World!。
router.get('/user/:id', function(req, res) {...}为路由对象添加另一个 GET 请求处理函数,当用户访问路径为/user/:id时,返回user :id。:id是一个动态参数,表示用户 ID。
app.use('/api', router);把路由对象挂载到应用程序中的/api路径下,即当用户访问应用程序的/api路径时,使用该路由对象进行处理。
app.listen(3000, function() {...}启动应用程序,监听端口 3000,并在控制台输出"App is listening on port 3000!"。
基本构建
这个是为了更加直观的了解构建模块化路由的过程
- 创建一个模块化的路由对象
在 Express 应用程序中,可以使用 express.Router() 方法创建一个模块化的路由对象。这个方法返回一个路由对象,该对象表示一个完整的路由模块,可以在此对象中添加特定的 HTTP 请求方式和 URL 路径,然后在应用程序中使用该路由模块。
const express = require('express');
const router = express.Router();
- 定义路由规则
在路由对象上定义路由规则,可以使用各种 HTTP 请求方式(例如 get()、post()、put()、delete() 等)和 URL 路径。下面以 get() 方法为例说明:
router.get('/', (req, res) => {res.send('Hello World!');
});
该代码定义了一个 GET 请求方式的路由规则,当客户端向 URL 路径 / 发送请求时,会执行该处理程序,并返回字符串 'Hello World!'。
- 把路由对象导出
在路由模块中调用 module.exports 方法,将路由对象作为模块输出,该对象可以在应用程序中使用。例如:
module.exports = router;
- 在应用程序中使用路由模块
导入路由模块,在应用程序中使用 app.use() 方法挂载该模块。例如:
const router = require('./router');
app.use('/api', router);
此代码将路由模块 router 挂载到应用程序的 /api 路径上,当客户端向 /api 路径发送请求时,会执行该模块中定义的路由规则。
完整的模块化路由示例代码:
新建文件router.js:
const express = require('express');
const router = express.Router();router.get('/', (req, res) => {res.send('Hello World!');
});router.get('/users', (req, res) => {res.send('Users page');
});module.exports = router;
新建文件app.js:
const express = require('express');
const app = express();
const router = require('./router');app.use('/api', router);app.listen(3000, () => {console.log('Server started on port 3000');
});
注意:以上代码一般是在Express安装的目录下新建文件进行。
在此示例中,当客户端向 /api 路径发送 GET 请求时,会匹配到 router 中定义的第一个路由规则,并返回 'Hello World!'。当客户端向 /api/users 路径发送 GET 请求时,会匹配到 router 中定义的第二个路由规则,并返回 'Users page'。
案例项目
一个简单的项目,实现一个用户注册和登录系统。首先,我们需要安装和引入Express模块:
- 安装Express模块
npm install express --save
- 引入Express模块
const express = require('express');
const app = express();
接下来,我们可以定义一些路由和处理函数来实现注册和登录功能。
- 注册页面路由和处理函数
// 注册页面路由
app.get('/register', (req, res) => {res.send('注册页面');
});// 注册处理函数
app.post('/register', (req, res) => {// 处理注册请求
});
在上面的代码中,我们定义了一个GET请求的/register路由和一个POST请求的/register路由。GET请求的/register路由用于显示注册页面,POST请求的/register路由用于处理注册请求。
- 登录页面路由和处理函数
// 登录页面路由
app.get('/login', (req, res) => {res.send('登录页面');
});// 登录处理函数
app.post('/login', (req, res) => {// 处理登录请求
});
同样的,我们定义了一个GET请求的/login路由和一个POST请求的/login路由。GET请求的/login路由用于显示登录页面,POST请求的/login路由用于处理登录请求。
最后,我们需要监听端口并启动服务器。
- 启动服务器
app.listen(3000, () => {console.log('服务器已启动');
});
完整代码如下:
const express = require('express');
const app = express();// 注册页面路由
app.get('/register', (req, res) => {res.send('注册页面');
});// 注册处理函数
app.post('/register', (req, res) => {// 处理注册请求
});// 登录页面路由
app.get('/login', (req, res) => {res.send('登录页面');
});// 登录处理函数
app.post('/login', (req, res) => {// 处理登录请求
});// 启动服务器
app.listen(3000, () => {console.log('服务器已启动');
});
这是一个简单的用户注册和登录系统,只实现了页面和路由,并没有实现具体的处理逻辑。在实际项目中,我们需要根据业务需求实现具体的功能。
可以通过浏览器或者curl命令访问:
- 使用浏览器访问
在浏览器地址栏输入
http://localhost:3000/register或者http://localhost:3000/login来访问注册页面和登录页面。
- 使用curl命令访问
打开终端或命令行,输入以下命令:
curl http://localhost:3000/register或者:
curl http://localhost:3000/login执行后会输出页面内容。
Express接收请求参数
基本概述
Express是一款非常流行的Node.js Web框架,使用它能使我们轻松构建Web应用程序。在Web应用程序中,我们需要接收来自客户端发送的请求数据,这个过程中请求参数起着至关重要的作用。因此,使用Express接收请求参数是非常必要的,原因如下:
-
灵活性:当我们接收到请求参数后,可以根据参数的不同来执行不同的逻辑代码或者返回不同的输出结果,从而使我们的程序更加灵活。
-
安全性:对于不合法的请求参数,我们可以进行校验和过滤,避免一些安全问题的发生,提高我们程序的安全性。
-
交互性:通过接收请求参数,我们可以使程序更与用户进行交互,例如:接收用户的表单提交数据,登录验证等等。
-
数据处理:接收到请求参数后,我们可以对请求的数据进行处理,例如:入库,修改等等。
总之,Express是一款非常灵活、快速、扩展性强的Web框架,使用它接收请求参数,可以使我们的Web应用程序更加高效、可靠和安全。
基本类别
Express接收GET请求参数
Express框架中的req.query用于获取GET请求参数,框架内部会将GET参数转换为对象并返回。示例如下:
app.get('/',(req,res) => {res.send(req.query);
});
这段代码中有一行,写成了两行,让我们逐行来看:
app.get('/', (req, res) => {这一行表示使用 Express 应用程序对象
app的get方法,表示当应用程序接收到来自根路径/的 GET 请求时,会执行后续的回调函数。回调函数接收两个参数req和res,分别代表请求对象和响应对象。res.send(req.query);这一行使用
res.send方法将req.query返回给客户端作为响应的内容。req.query是一个对象,包含了发送到服务器的查询参数。当客户端发送 GET 请求时,Express 框架会将查询参数解析为一个对象,并将其作为req.query属性存储在请求对象中。因此,使用res.send(req.query)将查询参数作为响应返回给客户端。
案例:来演示如何使用Express接收GET请求参数。
首先需要安装Express框架:
npm install express --save
接下来,我们创建一个index.js文件,并引入Express框架:
const express = require('express');
const app = express();
然后,我们创建一个GET路由,用来接收参数:
app.get('/api/user', (req, res) => {const { name, age } = req.query;res.send(`Hello ${name}, you are ${age} years old!`);
});
以上代码中,我们在/api/user路径下创建了一个GET路由,当用户访问该路径时,框架会自动解析URL中的参数,并将其转换为一个对象,对象的属性名即为参数名,属性值即为参数值。
最后,我们添加一个监听端口的代码,启动应用:
const port = 3000;
app.listen(port, () => {console.log(`Server running at http://localhost:${port}`);
});
完整代码如下:
const express = require('express');
const app = express();app.get('/api/user', (req, res) => {const { name, age } = req.query;res.send(`Hello ${name}, you are ${age} years old!`);
});const port = 3000;
app.listen(port, () => {console.log(`Server running at http://localhost:${port}`);
});
现在,你可以通过访问http://localhost:3000/api/user?name=Tom&age=18来测试应用程序是否正常工作了。结果如下图

Express接收POST请求参数
Express框架中的req.body用于获取POST请求参数,需要借助第三方body-parser模块将POST参数转换为对象形式。(语法跟上述代码相同,只需要在res.send()输入rep.body即可)
在 Express 中,要获取 POST 请求中的参数,需要使用
req.body对象。但是,因为 Node.js 的核心模块http并没有提供直接获取 POST 参数的方法,所以我们需要使用第三方中间件来实现这个功能。其中,body-parser库是最常用的一种。在使用
body-parser库之前,需要使用npm命令将该库安装到项目中。可以通过在命令行中执行以下命令来安装:npm install body-parser安装好之后,在 Express 应用程序中引入该库,并将其添加为中间件即可。以下是一个简单的例子,假设我们有一张表单,其中有一个
name输入框和一个password输入框。当我们提交表单并发送 POST 请求时,我们需要从req.body对象中获取这些输入框的值:const express = require('express'); const bodyParser = require('body-parser'); const app = express();// 添加 body-parser 中间件 app.use(bodyParser.urlencoded({ extended: true }));app.post('/login', (req, res) => {const name = req.body.name;const password = req.body.password;// use name and password variables to authenticate user });在上面的例子中,
app.use函数用于加载body-parser中间件,并将其设置为处理 URL 编码的请求体。此时,req.body对象已经包含了表单提交的参数。注意,body-parser库会将 POST 请求的参数转换为对象形式,因此可以用req.body.name和req.body.password语法获取表单中的值。
案例:来演示如何使用Express接收POST请求参数。
首先需要安装Express框架和body-parser模块:
npm install express body-parser --save
接下来,我们创建一个index.js文件,并引入Express框架和body-parser模块:
const express = require('express');
const bodyParser = require('body-parser');
const app = express();
然后,我们需要在应用程序中使用body-parser中间件来处理POST请求中的参数:
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());
以上代码中,我们使用body-parser中间件来处理两种类型的POST请求参数:application/x-www-form-urlencoded和application/json。其中,urlencoded表示把参数转换为URL字符串的形式,json表示把参数转换为JSON对象的形式。
接下来,我们创建一个POST路由来接收参数:
app.post('/api/user', (req, res) => {const { name, age } = req.body;res.send(`Hello ${name}, you are ${age} years old!`);
});
以上代码中,我们在/api/user路径下创建了一个POST路由,当用户发起POST请求时,框架会自动解析请求体中的参数,并将其转换为一个对象,对象的属性名即为参数名,属性值即为参数值。
最后,我们添加一个监听端口的代码,启动应用:
const port = 3000;
app.listen(port, () => {console.log(`Server running at http://localhost:${port}`);
});
完整代码如下:
const express = require('express');
const bodyParser = require('body-parser');
const app = express();app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());app.post('/api/user', (req, res) => {const { name, age } = req.body;res.send(`Hello ${name}, you are ${age} years old!`);
});const port = 3000;
app.listen(port, () => {console.log(`Server running at http://localhost:${port}`);
});
现在,你可以使用POSTMAN等工具来发送POST请求,格式为application/x-www-form-urlencoded或application/json,参数为name和age,来测试应用程序是否正常工作了。
Express接收路由参数
在使用 Express 构建 Web 应用时,我们经常需要从客户端接收一些信息。其中一种方式是在 URL 中传递参数,这种参数通常称为路由参数或路径参数。在 Express 中,可以使用冒号 : 来定义路由参数。
Express接收路由参数的示例代码:
app.get('/find/:id', (reg,res) => {
res.send(req.params);
});
这段代码定义了一个 GET 请求的路由
/find/:id,其中:id是一个路由参数。当客户端请求/find/123时,Express 会将123解析为req.params.id,并将一个对象{ id: '123' }发送给客户端作为响应。代码中的
req.params是一个对象,它包含了所有的路由参数和它们的值。在本例中,它的值为{ id: '123' }。通过将整个对象发送回客户端,我们可以将所有的路由参数都包含在响应中,以便客户端可以根据需要进行处理。
案例:以下是一个简单的 Express 项目,它演示了如何接收和使用路由参数:
const express = require('express');
const app = express();// 定义一个路由处理程序,它匹配 '/students/:id' 路由
app.get('/students/:id', (req, res) => {const { id } = req.params;// 假设这里根据 id 从数据库中获取学生信息const student = { id, name: 'John Doe', age: 20 };res.send(student);
});app.listen(3000, () => {console.log('Server started on port 3000');
});
在上面的示例中,我们定义了一个路由处理程序,它匹配 /students/:id 路由,其中 :id 是路由参数。当客户端请求该路由时,我们从 req.params 中提取 id 参数,并使用它从数据库中获取学生信息。然后,我们将学生信息发送回客户端。
例如,如果客户端请求路径为 /students/123,则路由处理程序会响应:
{"id": "123","name": "John Doe","age": 20
}
当然,这只是一个简单的示例,实际上你可能需要更复杂的路由参数来访问数据库中的数据。
注意:可以使用类似`http://localhost:3000/students/123`的URL来访问此路由处理程序。其中,`123`是路由参数,可以是任何数字。此示例假设您已经启动了该应用程序并在端口3000上侦听连接。如果要在浏览器中进行测试,只需将上面的URL复制到浏览器地址栏中即可。
文章到此一游,修行结束打卡
相关文章:
第八章认识Express框架
目录 Express模块化路由 基本概述 基本使用 基本构建 案例项目 Express接收请求参数 基本概述 基本类别 Express接收GET请求参数 Express接收POST请求参数 Express接收路由参数 Express模块化路由 基本概述 在Express中,路由是指确定应用程序如何响应对…...
【K8s集群离线安装-kubeadm】
1、kubeadm概述 kubeadm是官方社区推出的一个用于快速部署kubernetes集群的工具。这个工具能通过两条指令快速完成一个kubernetes集群的部署。 2、环境准备 2.1 软件环境 软件版本操作系统CentOS 7Docker19.03.13K8s1.23 2.2 服务器 最小硬件配置:2核CPU、2G内存…...
python工具CISCO ASA设备任意文件读取
python漏洞利用 构造payload: /CSCOT/translation-table?typemst&textdomain/%2bCSCOE%2b/portal_inc.lua&default-language&lang../漏洞证明: 文笔生疏,措辞浅薄,望各位大佬不吝赐教,万分感谢。 免…...
TCP关闭的两种方法概述
一个TCP需要经过四次挥手才可以关闭连接,能够开启四次挥手的函数有两个: int close(int sockfd) int shutdown(int sockfd,int howto) 接下来就分别讲解一下这两个函数。 close()函数 函数原型 #include<unistd.h> int close(int sockfd)这个函…...
Git的Hooks机制
参考文章:详解如何在项目中使用git Hooks(husky、yorkie) git hooks钩子 git hooks是一些自定义的脚本,用于控制git工作的流程,分为客户端钩子和服务端钩子。 ~/work/step-time/ [master*] ll .git/hooks total…...
代码随想录算法训练营第四十九天|121. 买卖股票的最佳时机、122. 买卖股票的最佳时机 II
第九章 动态规划part10 121. 买卖股票的最佳时机 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最…...
Rust教程6:并发编程和线程通信
文章目录 线程初步join方法线程通信 Rust系列:初步⚙所有权⚙结构体和枚举类⚙函数进阶⚙泛型和特征 线程初步 在Rust中,开启多线程进行并发编程,只需调用thread::spawn,但这里有一个坑点,即spawn函数只有一个传入参…...
JVM在线分析-监控工具(jps, jstat, jstatd)
参考官方文档(jdk11) https://docs.oracle.com/en/java/javase/11/tools/troubleshooting-tools-and-commands.html#GUID-CB44BFBA-E5F9-4D80-8EE8-28E9F16BC451 1. 监控工具(jps, jstat, jstatd) jps -q Suppresses the output of the class name, J…...
Console LDAP 配置解密
之前通过短视频向大家介绍了 Console 如何集成 LDAP,但很多小伙伴反映按照视频里的配置后不成功。今天就结合小伙伴们反映的问题来跟大家详细介绍一下。 Console LDAP 完整的配置参数如下: 名称类型说明hoststringLDAP 服务器地址portintLDAP 服务器端口…...
node插件MongoDB(三)—— 库mongoose 的使用和数据类型(一)
前言 提示:使用mongoose 的前提是你安装了node和 MongoDB。 mongoose 官网文档:http://mongoosejs.net/docs/index.html 文章目录 前言一、安装二、基本使用1. 打开bin目录的mongod.exe文件2. 基本使用的代码(连接mongodb 服务)3.…...
基础(二)
基础(二) 字符串型 C风格:char 变量名[] “字符串值”; C风格:string 变量名 “字符串值” #include <iostream> using namespace std; #include <string>int main() {// C风格char str1[] "h…...
思维模型 目标效应
本系列文章 主要是 分享 思维模型,涉及各个领域,重在提升认知。明确目标,激发内在动机。 1 目标效应的应用 1.1 目标效应在教育领域的应用-棉花糖实验 美国斯坦福大学心理学系的教授米歇尔(Walter Mischel)曾经进行了…...
【从0到1设计一个网关】性能优化---Netty线程数配置与JVM参数配置
文章目录 Netty线程介绍Netty实战配置JVM参数与ZGCJVM与ZGC调优Netty线程介绍 在Netty中有两个比较重要的线程概念,一个是BOSS线程,一个是Woker线程。 Boss线程组: Boss线程组通常负责处理接受客户端连接的工作,即处理ServerSocketChannel的连接事件。 Boss线程会监听并接…...
node插件MongoDB(五)—— 库mongoose 的模块化(五)
文章目录 一、使用mongoose 模块化的原因二、准备工作2. 启动mongo.exe 和mongod.exe 两个程序连接数据库 三、基本模块的拆分1、基本逻辑2、代码3、代码图示说明 四、在index.js 中进一步的拆分1.拆分原因2.新建model文件夹存储文档的结构对象3.代码4.代码实际演示和注意点 一…...
Windows server 2008 R2 IIS搭建ASP网站教程
一、安装应用程序服务器 提示安装成功 二、添加角色服务asp 三、asp网站配置 放入源码 设置网站首页为index.asp: 设置应用程序池 四、设置网站目录属性 五、access数据库连接配置 Cd c:\Windows\System32\inetsrv appcmd list apppool /xml | appcmd set apppool /…...
Linux之基础开发工具gdb调试器的使用(三)
文章目录 一、Linux调试器-gdb使用1、安装gdb2、背景3、Debug和release4、区分Debug和release 二、Linux调试器-gdb命令演示1、显示指定行之后的代码(自动记录最后一条指令)2、断点1、打印断点2、查看断点3、删除断点4、使能(禁用/开启&#…...
advanced-css: No.1
本套教程学习来自视频:https://www.bilibili.com/video/BV1n94y1o7yS/?p7&spm_id_frompageDriver&vd_sourceb79be8283df9418cb45941cc0bd583c6 案例 实现效果图 代码 HTML: <!DOCTYPE html> <html lang"en"><head><meta c…...
最新宝塔面板第三方云端站点程序源码/第三方宝塔面板PHP源码/全开源ThinkPHP框架
源码简介: 实现宝塔面板第三方云端站点程序源码,这个是第三方宝塔面板 btcloud PHP源码,它还有云端使用记录、IP黑白名单、定时任务等功能。 这是一个使用PHP开发的宝塔面板第三方云端站点程序。 您可以利用此程序搭建属于自己的宝塔面板第三方云端&a…...
【Unity之UI编程】玩法面板的实现
👨💻个人主页:元宇宙-秩沅 👨💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨💻 本文由 秩沅 原创 👨💻 收录于专栏:UI_…...
栈和队列:栈
栈的概念: 栈: 一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端 称为栈顶,另一端称为栈底。 栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...
微软PowerBI考试 PL300-选择 Power BI 模型框架【附练习数据】
微软PowerBI考试 PL300-选择 Power BI 模型框架 20 多年来,Microsoft 持续对企业商业智能 (BI) 进行大量投资。 Azure Analysis Services (AAS) 和 SQL Server Analysis Services (SSAS) 基于无数企业使用的成熟的 BI 数据建模技术。 同样的技术也是 Power BI 数据…...
【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...
Psychopy音频的使用
Psychopy音频的使用 本文主要解决以下问题: 指定音频引擎与设备;播放音频文件 本文所使用的环境: Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...
pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)
目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关࿰…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)
在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马(服务器方面的)的原理,连接,以及各种木马及连接工具的分享 文件木马:https://w…...
Android第十三次面试总结(四大 组件基础)
Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: onCreate() 调用时机:Activity 首次创建时调用。…...
