第八章认识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)的原则。…...
SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...
云原生核心技术 (7/12): K8s 核心概念白话解读(上):Pod 和 Deployment 究竟是什么?
大家好,欢迎来到《云原生核心技术》系列的第七篇! 在上一篇,我们成功地使用 Minikube 或 kind 在自己的电脑上搭建起了一个迷你但功能完备的 Kubernetes 集群。现在,我们就像一个拥有了一块崭新数字土地的农场主,是时…...
论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)
HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...
MVC 数据库
MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...
【Zephyr 系列 10】实战项目:打造一个蓝牙传感器终端 + 网关系统(完整架构与全栈实现)
🧠关键词:Zephyr、BLE、终端、网关、广播、连接、传感器、数据采集、低功耗、系统集成 📌目标读者:希望基于 Zephyr 构建 BLE 系统架构、实现终端与网关协作、具备产品交付能力的开发者 📊篇幅字数:约 5200 字 ✨ 项目总览 在物联网实际项目中,**“终端 + 网关”**是…...
leetcodeSQL解题:3564. 季节性销售分析
leetcodeSQL解题:3564. 季节性销售分析 题目: 表:sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...
实现弹窗随键盘上移居中
实现弹窗随键盘上移的核心思路 在Android中,可以通过监听键盘的显示和隐藏事件,动态调整弹窗的位置。关键点在于获取键盘高度,并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...
docker 部署发现spring.profiles.active 问题
报错: org.springframework.boot.context.config.InvalidConfigDataPropertyException: Property spring.profiles.active imported from location class path resource [application-test.yml] is invalid in a profile specific resource [origin: class path re…...
安宝特案例丨Vuzix AR智能眼镜集成专业软件,助力卢森堡医院药房转型,赢得辉瑞创新奖
在Vuzix M400 AR智能眼镜的助力下,卢森堡罗伯特舒曼医院(the Robert Schuman Hospitals, HRS)凭借在无菌制剂生产流程中引入增强现实技术(AR)创新项目,荣获了2024年6月7日由卢森堡医院药剂师协会࿰…...
