当前位置: 首页 > news >正文

【SpringBoot】基于mybatisPlus的博客系统

1.实现用户登录

在之前的项目登录中,我使用的是Session传递用户信息实现校验登录

现在学习了Jwt令牌技术后我尝试用Jwt来完成校验工作

Jwt令牌

令牌一词在网络编程一节我就有所耳闻,现在又拾了起来。

这里讲应用:令牌也就用于身份标识,类似于身份证,本质是一个字符串(类比身份证号)

JWT全称: JSON Web Token

官⽹: https://jwt.io/

 

1、Header(头部)头部包括令牌的类型(即JWT)及使用的哈希算法(如HMACSHA256或RSA)
 
2、Payload(负载)负载部分是存放有效信息的地方,里面是一些自定义内容
 
3、Signature(签名此部分⽤于防⽌jwt内容被篡改, 确保安全性

1.引入依赖

使用前我们需要引入依赖:

<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt-api -->
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-api</artifactId><version>0.11.5</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt-impl -->
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-impl</artifactId><version>0.11.5</version><scope>runtime</scope>
</dependency>
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-jackson</artifactId> <!-- or jjwt-gson if Gson is 
preferred --><version>0.11.5</version><scope>runtime</scope>
</dependency>

2.生成令牌(token)

接下来就是生成令牌了

既然JWT分了三部分,那我们就从这三个部分说起

Payload(负载):我们使用Map装用户的信息

        Map<String, Object> claims = new HashMap<>();claims.put("name", "zhangsan");claims.put("id", 1);

然后通过这个Map信息生成一个简单的token字符串:

        //生成Jwt令牌  无签名版String compact = Jwts.builder().addClaims(claims).compact();System.out.println(compact);

 Jwts.builder().addClaims(claims):将Map信息整合为一个JwtBuilder对象

compact():使用JwtBuilder生成一个token

 还可以传入JSON数据

        //生成Jwt令牌  还可以传入JSON数据(转成String)两者不能共存  但不建议使用setPayload()  它和后续的一些方法不兼容
//        String compact = Jwts.builder().setPayload("JSON_Data").compact();

 

将结果打印出来发现只有两段字符串

正常有三段分别存储令牌的三个部分

 完整生成流程:

        String compact = Jwts.builder().addClaims(claims).setIssuedAt(new Date())     //设置签发时间.signWith(key)        //设置签名.setExpiration(new Date(System.currentTimeMillis() + 30 * 60 * 1000))//设置过期时间  30分钟.compact();  //生成token

 Signature(签名):

这个过程还需要一个变量Key(就是一个很长的字符串 用于加密,生成签名)

Key也是解析的关键,所以我们要掌握  生成与获取

在这过程中还用到了Header(头部)中的算法

        //生成签名所需要的Key  手动版生成
//        Key key = Keys.hmacShaKeyFor("zxcvbnmasdfghjklqwertyuiop_zxcvbnmasdfghjklqwertyuiop".getBytes(StandardCharsets.UTF_8));//生成签名所需要的Key  自动版生成
//        Key key = Keys.secretKeyFor(SignatureAlgorithm.HS256);

两者结合一下,我们可以选择先自动生成一个再存为static final对象(或者使用对自己有特殊好意的字符串)

    private static final String secretString = "7C4CHbWRCam1zetXXwpk0NY8SAkhDlBO171kHnJSWTQ=";//根据生成的secretString实现静态Key完成多服务器共享private static final Key key = Keys.hmacShaKeyFor(secretString.getBytes(StandardCharsets.UTF_8));

如何获取生成Key的String呢?

通过  Encoders.BASE64.encode(key.getEncoded())换成String

        //借助这个方法生成一个StringKey key = Keys.secretKeyFor(SignatureAlgorithm.HS256);  //生成KeyString encode = Encoders.BASE64.encode(key.getEncoded());  //获取生成Key的密钥System.out.println(encode);SecretKey secretKey = Keys.hmacShaKeyFor(Decoders.BASE64.decode(encode)); //进行设置

然后将这个生成的String 放在secretString中

获取到token后我们怎么反向解析识别这个token呢?就像公安系统能识别身份证

因为token与Key联系紧密(token就是根据Key生成)

所以key变化就解析不成功 token变化也解析不成功(这就是实现强制登录的关键)

            //解析tokenString token = "eyJhbGciOiJIUzI1NiJ9.eyJuYW1lIjoiemhhbmdzYW4iLCJpZCI6MSwiaWF0IjoxNzQ1OTc3ODg3LCJleHAiOjE3NDU5Nzk2ODd9.wHE7XqoZOL1hIj1qCdBJu-K6iXSCfckb-qX1ndbrnuM";//根据Key来对token进行解析获得所存储的数据  key变化就解析不成功 token变化也解析不成功JwtParser build = Jwts.parserBuilder().setSigningKey(key).build();  //此时key已经固定Claims body = build.parseClaimsJws(token).getBody();System.out.println(body);

这就是JWT的部分实现,项目中大概就展示使用这些。

接下来我们将这些知识运用在项目中:

添加JwtUtils类实现   生成token  解析token   功能

其他类直接调用即可

生成token:传入Map信息返回token(校验工作用的东西)

/*** 生成token* @param claims 在token中存储的信息* @return token令牌*/public static String getToken(Map<String, Object> claims) {return  Jwts.builder().addClaims(claims).setIssuedAt(new Date())     //设置签发时间.signWith(key)        //设置签名.setExpiration(new Date(System.currentTimeMillis() + Constant.EXPIRATION_TIME))//设置过期时间  30分钟.compact();  //生成token}

将我们所需要用的常量放在Constant中

    //token过期时间public static final long EXPIRATION_TIME=5*1000;//Header中的tokenpublic static final String HEADER_TOKEN = "user_token";

还有些别的的直接放在这个类中也行:

    private static final String secretString = "7C4CHbWRCam1zetXXwpk0NY8SAkhDlBO171kHnJSWTQ=";//根据生成的secretString实现静态Key完成多服务器共享   key:相当于制作身份证的一种工艺private static final Key key = Keys.hmacShaKeyFor(secretString.getBytes(StandardCharsets.UTF_8));

解析token :

用于校验工作的

/*** 解析token* @param token  “身份证”* @return 简单理解为Map*/public static Claims parseToken(String token) {//根据Key来对token进行解析获得所存储的数据  key变化就解析不成功 token变化也解析不成功JwtParser build = Jwts.parserBuilder().setSigningKey(key).build();  //此时key已经固定//如果解析失败会爆出异常Claims body = null;try{body = build.parseClaimsJws(token).getBody();}catch(Exception e) {log.error("token校验失败 token:{}",token);}return body;}

当校验失败时我们可以选对不同的异常做出不同判断(这里作者太懒了)

比如:是token为空还是  内容错了

进入业务中:

Controller Service Mapper

Controller:

@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {@Resource(name = "UserService")private UserService userService;@RequestMapping("/login")//@Validated加了这个注解就会进行参数校验public UserLoginResponse login(@Validated @RequestBody UserLoginRequest userLoginRequest) {log.info("用户进行登录, userName:{}",userLoginRequest.getUserName());return userService.login(userLoginRequest);}
}

当我们传递参数与返回参数时,我们一般操作的都是JSON对象,所以要对参数进行封装。

UserLoginResponse :返回参数

@Data
@AllArgsConstructor
@NoArgsConstructor
public class UserLoginResponse {private Integer userId;private String token;
}

UserLoginRequest :传递参数

/*** 发送用于登录的数据*/
@Data
public class UserLoginRequest {@NotBlank(message = "用户名不能为空")@Length(min = 4, message = "用户名不能低于4位")private String userName;@NotBlank(message = "密码不能为空")@Length(min = 4, message = "密码不能低于4位")private String password;
}

这里使用了两个新注解@NotBlank  @Length

@NotBlank:校验参数(掌握它能判断参数是否为空 message为报错时的信息)

@Length:检验参数长度是否达标(我们在登录时名字太长或太短都会出现问题吧)

Service:

完成校验工作

1.先根据用户name从数据库中获取密码用于判断

(这一步建议将数据库代码放在一个方法中,方便下一次复用)

2.检验一下获取的用户信息是否存在

(userLoginRequest这个对象不用再检验,那两个注解已经完成了检验)

3.检验密码是否正确

4.如果用户信息对上了,将这个信息生成一个token并返回

@Service("UserService")
public class UserServiceImpl implements UserService {@Resourceprivate UserInfoMapper userInfoMapper;@Overridepublic UserLoginResponse login(UserLoginRequest userLoginRequest) {//参数校验  日志打印  异常捕获//参数在Controller层就已经完成校验  只用校验从数据库中的数据UserInfo userInfo = selectUserInfoByName(userLoginRequest.getUserName());if(userInfo == null || userInfo.getId() == null || userInfo.getId() < 1) {throw new BlogException("用户不存在");}//完成登录校验if(!userLoginRequest.getPassword().equals(userInfo.getPassword())) {throw new BlogException("用户密码错误");}账号密码正确的逻辑   往token中填装要记录的信息Map<String, Object> claims = new HashMap<>();claims.put("id", userInfo.getId());claims.put("name", userInfo.getUserName());return new UserLoginResponse(userInfo.getId(), JwtUtils.getToken(claims));}/*** 根据name查询User用户* @param userName 用户name* @return 用户信息*/public UserInfo selectUserInfoByName(String userName) {QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>();queryWrapper.lambda().eq(UserInfo::getUserName, userName).eq(UserInfo::getDeleteFlag, Constant.IS_DELETE);return userInfoMapper.selectOne(queryWrapper);}
}

2.实现强制登录

依然是使用拦截器完成

关于拦截器:实现

结构:即使是一个类也要创建一个包哦!

定义拦截器:

调用JwtUtils中我们写的方法进行校验

不符合预期的话再拦截之前记得向response传入一些值哦

@Slf4j
@Component
public class LoginInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//从header中获取tokenString token = request.getHeader(Constant.HEADER_TOKEN);//利用token获取信息进行校验Claims claims = JwtUtils.parseToken(token);//token不符合预期if(claims == null) {response.setStatus(401);return false;}return true;}
}

配置拦截器:

建议多使用List<String> excludePaths这样的结构先拦截所有路径  /**/*  然后进行排除路径

(这里工程少,为了方便测试使用了addPathPatterns("/user/**","/blog/**")排除部分路径)

/*** 注册拦截器*/
@Configuration
public class WebConfig implements WebMvcConfigurer {//注入拦截器@Autowiredprivate LoginInterceptor loginInterceptor;private final List<String> excludePaths = Arrays.asList("/user/login","/**/*.css","/**/*.html","/**/*.js","/**/*.jpg");@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(loginInterceptor).addPathPatterns("/user/**","/blog/**").excludePathPatterns(excludePaths);}
}

相关文章:

【SpringBoot】基于mybatisPlus的博客系统

1.实现用户登录 在之前的项目登录中&#xff0c;我使用的是Session传递用户信息实现校验登录 现在学习了Jwt令牌技术后我尝试用Jwt来完成校验工作 Jwt令牌 令牌一词在网络编程一节我就有所耳闻&#xff0c;现在又拾了起来。 这里讲应用&#xff1a;令牌也就用于身份标识&a…...

[Android]任务列表中有两个相机图标

现象&#xff1a; 修改AndroidManifest.xml <activityandroid:name"com.android.camera.PermissionsActivity"android:label"string/app_name"android:launchMode"singleTop"android:configChanges"orientation|screenSize|keyboardH…...

VINS-FUSION:配置参数说明与配置自己的参数

文章目录 📚简介📍配置文件说明📷相机配置参数🔧设备参数🎯配置自己的参数📷相机参数🔧设备参数📚简介 VINS-Fusion 是一个基于优化的多传感器状态估计器,实现了视觉惯性里程计(VIO)和视觉惯性全球导航卫星系统(VI-GNSS)融合。 📍配置文件说明 VINS-Fus…...

Polars: 新一代高性能数据处理库

<------最重要的是订阅“鲁班模锤”------> 在数据科学和数据分析领域&#xff0c;性能和效率一直是从业者关注的焦点。随着数据量的爆炸式增长&#xff0c;传统的数据处理工具如pandas在处理大规模数据时逐渐显露出其局限性。在这样的背景下&#xff0c;一个名为Polars…...

大屏/门户页面兼容各种分辨率或电脑缩放

需求要求: 需要支持缩放功能(缩放后 页面各元素模块正常展示)、 需要适配各种分辨率(初始加载不应出现横向滚动条) 选择的实现方案 利用 zoom 或者 transform 来缩放兼容页面样式&#xff0c;不动业务模块代码 const isMobile /iPhone|iPad|iPod|Android|Harmony/i.test(navi…...

自定义项目中导入文件import顺序

项目中import 顺序 分类顺序 可以根据模块或文件的功能、类型等进行分类&#xff0c;比如将所有的组件放在一起、工具函数放在一起等。这样的组织方式更有利于对项目结构和代码逻辑的理解&#xff0c;当需要查找某一类功能的代码时&#xff0c;可以快速定位到相应的 import 区…...

Git 本地提交撤销

引言 在 Git 版本控制系统中&#xff0c;偶尔会遇到需要撤销本地提交的情况。本文将详细介绍如何优雅地处理这种情况&#xff0c;帮助您在不慌乱的情况下恢复错误提交。 撤销本地提交的主要方法 当您意外提交了错误文件到 Git 仓库&#xff0c;但尚未推送到远程服务器时&…...

k8s术语之Replication Controller

Replication Controller 在kubernetes中简称RC,它其实是定义了一个期望的场景&#xff0c;即声明某种Pod的副本数量在任意时刻都符合某个预期值&#xff0c;包括一下几个值&#xff1a; 1.Pod期待的副本数&#xff08;replicas) 2.用于筛选目标Pod的Lable Selector 3.当…...

AI驱动视频批量智能混剪软件生产技术实践

一、引言&#xff1a;短视频工业化生产的技术革新 在电商带货、知识分享等领域&#xff0c;高效产出差异化视频内容成为核心竞争力。本文结合AI技术与工程实践&#xff0c;解析如何通过智能素材处理、参数化合成引擎、多维度质量控制构建全自动视频生产流水线&#xff0c;实现…...

SPL 量化 回测

回测是一种评估交易策略的通用方法。它通过计算策略在历史数据上的表现来评估交易策略的可行性。如果回测结果良好&#xff0c;交易者和分析师可能会有信心在未来继续使用该策略。 1. 回测脚本 首先要编写回测脚本&#xff0c;将回测脚本保存为 backtest.splx。 脚本代码如下…...

2025年“深圳杯”数学建模挑战赛A题-芯片热弹性物理参数估计

芯片热弹性物理参数估计 小驴数模 当今时代&#xff0c;芯片无疑是现代社会发展的 “核心引擎”。它深度嵌入智能手机&#xff0c;实现全球即时通讯&#xff1b;助力汽车智能驾驶&#xff0c;精准导航、自动操控&#xff1b;赋能工业自动化生产线&#xff0c;高效运转。但随着…...

前端笔记-Element-Plus

结束了vue的基础学习&#xff0c;现在进一步学习组件 Element-Plus部分学习目标&#xff1a; Element Plus1、查阅官方文档指南2、学习常用组件的使用方法3、Table、Pagination、Form4、Input、Input Number、Switch、Select、Date Picker、Button5、Message、MessageBox、N…...

vue3封装全局方法

场景&#xff1a;各个模块详情中存在附件列表数据&#xff0c;需要再每个中添加一个预览附件的方法&#xff0c;是后期提出的需求&#xff0c;所以要在每个模块中进行添加&#xff0c;就去将预览方法封装一下。 将公共方法封装在utils下 utils/filePreview.ts import router…...

Django 学习指南:从入门到精通(大体流程)

想要快速掌握 Django 开发技能吗&#xff1f;按照以下学习流程&#xff0c;带你从零基础成长为独立开发 Web 应用的高手。 一、准备工作&#xff1a;打下坚实基础 在开启 Django 之旅前&#xff0c;先确保你已掌握以下 Python 基础知识&#xff1a; 数据类型&#xff1a;熟悉数…...

Java对集合进行操作,赋值新字段

1、方法一&#xff1a;增强for循环 List<Refund> list refundService.selectRefundList(queryParam); for (Refund refund : list) {refund.setPayWay(refund.getPaymentMethod()); // 将支付方式赋值给付款方式 }在 Java 中&#xff0c;当你使用 for 循环遍历 List<…...

【网工第6版】第6章 网络安全③

目录 ■ 虚拟专用网VPN ◆虚拟专用网基础 ◆VPN分类 ▲根据应用场景不同分类 ▲根据VPN技术实现的网络层次分类 ◎ 二层隧道协议&#xff1a;L2TP和PPTP ◎ 网络层隧道协议&#xff1a;IPSec和GRE ※ IPSec IPSec基础 IPSec原理 IPSec两种封装模式 ※ GRE ■ 应用…...

20250430在ubuntu14.04.6系统上查看系统实时网速

rootrootubuntu:~$ sudo apt-get install iftop 【不需要root权限】 rootrootubuntu:~$ sudo apt-get install nload rootrootubuntu:~$ sudo apt-get install vnstat 【失败】 rootrootubuntu:~$ sudo apt-get install speedtest-cli rootrootubuntu:~$ sudo apt-get install …...

远程 Debugger 多用户环境下的用户隔离实践

远程 Debugger 多用户环境下的用户隔离实践 在现代分布式开发和云原生环境下&#xff0c;远程 Debugger 的应用愈发普遍。然而&#xff0c;随着多人协作和多租户场景的出现&#xff0c;**远程 Debugger 的“用户隔离”**变得至关重要。只有实现了良好的用户隔离&#xff0c;才…...

Neo4j多关系或多路径

目录 一、双向关系 1.创建2个节点间的双向关系 2.创建多个路径的节点&#xff0c;双向关系 3.查询带有方向性的关系 4.查询路径上的多个关系 5.查询出a到b的最短距离 6.查询特定长度的路径 二、将之前的关系清空下&#xff0c;如图所示&#xff0c;在操作一次 1.查询出…...

Locate 3D:Meta出品自监督学习3D定位方法

标题&#xff1a; Locate 3D: Real-World Object Localization via Self-Supervised Learning in 3D 摘要&#xff1a; 我们提出了 Locate 3D&#xff0c;这是一种可根据指代表达&#xff08;如“沙发和灯之间的小咖啡桌”&#xff09;在三维场景中定位物体的模型。Locate 3…...

Copilot for Excel 一键词云分析与情绪分析

在Excel中使用copilot对数据进行高级分析&#xff0c;我们已经领略过copilot的强悍能力&#xff1a; 零代码、超越DeepSeek&#xff1a;Excel高级数据分析&#xff0c;copilot加持、Python助力 Python in Excel高级分析&#xff1a;一键RFM分析 然而&#xff0c;很多时候我们…...

【Linux 网络】网络工具ifconfig和iproute/iproute2工具详解

【Linux 网络】网络工具ifconfig和iproute/iproute2工具详解 前言1、安装2、常用命令3、命令使用详解 前言 本篇文章主要介绍Linux下网络工具ifconfig/iproute(iproute2)的安装、使用示例和场景。操作系统Ubuntu 18.04。 1、安装 使用apt-get install 命令安装ifconfig和ipr…...

硬盘分区丢失≠末日!3步逻辑恢复法+物理修复全流程图解

引言&#xff1a;硬盘分区丢失——数据安全的“隐形杀手” 在数字化时代&#xff0c;硬盘作为数据存储的核心载体&#xff0c;承载着个人、企业乃至社会的关键信息。然而&#xff0c;硬盘分区丢失这一突发状况&#xff0c;往往让用户措手不及&#xff1a;文件系统突然报错、盘…...

数据接收全流程图(物理网卡 → 应用层)

以下是 DPDK VPP 在 Linux 系统中从网卡收包到应用层的完整数据流程图及分步解析&#xff0c;结合了内核旁路和用户态协议栈的协同工作&#xff1a; 数据接收全流程图&#xff08;物理网卡 → 应用层&#xff09; plaintext 复制 下载 ----------------------------------…...

【AI】DeepSeek 流程图 / 时序图制作,Word 排版错乱问题,文字转直观图形

一&#xff1a;动态流程图 / 时序图制作&#xff08;DeepSeek Draw.IO&#xff09; 工具准备 DeepSeek&#xff08;AI 生成代码&#xff09;&#xff1a;官网&#xff08;免费&#xff09;Draw.IO&#xff08;可视化渲染&#xff09;&#xff1a;官网&#xff08;免费&#…...

C++继承(上)

目录 一、继承的概念及定义 1. 继承的概念 2. 继承的定义 2.1 定义格式 2.2 继承关系和访问限定符 2.3 继承基类成员访问方式的变化 二、基类和派生类对象赋值转换 三、继承中的作用域 四、派生类的默认成员函数 一、继承的概念及定义 1. 继承的概念 继承是面向对象编…...

分布式-redisson

分布式锁redisson 加锁流程缓存相关问题 加锁流程 redisson底层通过lua脚本实现加锁的原子性lock动作包含&#xff1a;加锁、设置超时时间、锁续命未获取到锁的线程通过获取信号量许可等待&#xff0c;所释放后释放信号量通知等待线程 缓存相关问题 缓存失效&#xff08;击穿…...

Java学习手册:Spring MVC 架构与实现

一、Spring MVC 概述 Spring MVC 是 Spring 框架的一个模块&#xff0c;它提供了一套 Web 应用开发的解决方案&#xff0c;实现了 MVC&#xff08;Model-View-Controller&#xff09;设计模式。Spring MVC 提供了清晰的分离逻辑层、视图层和控制器层的结构&#xff0c;便于开发…...

第四部分:实用应用开发

本部分将涵盖以下关键主题&#xff1a; 视频处理基础 视频读取与保存视频帧处理实战&#xff1a;视频中运动目标追踪 条形码与二维码识别 条形码检测原理&#xff08;概念&#xff09;QR 码识别实战&#xff1a;制作二维码扫描器 文本识别入门 (OCR) 图像预处理使用 Tesseract…...

目标检测YOLO实战应用案例100讲-基于多级特征融合的小目标深度检测网络

目录 知识储备 基于多级特征融合的小目标深度检测网络实现 一、环境配置 二、核心代码实现 1. 多级特征融合模块(models/fpn.py ) 2. 主干网络(models/backbone.py ) 3. 检测头(models/detector.py ) 三、完整网络架构(models/net.py ) 四、训练代码(train.p…...

单片机-89C51部分:11、IIC 、传感器温湿度

飞书文档https://x509p6c8to.feishu.cn/wiki/Cczpw4oBeiyK71kFhKfcXkQmnad 一、简介 IIC协议&#xff0c;又称I2C协议&#xff0c;是由PHILP公司在80年代开发的两线式串行总线&#xff0c;用于连接微控制器及其外围设备&#xff0c;IIC属于半双工同步通信方式。 C IIC是一种同…...

Java从入门到精通 - Java入门

Java 入门 此笔记参考黑马教程&#xff0c;仅学习使用&#xff0c;如有侵权&#xff0c;联系必删 文章目录 Java 入门01 Java快速入门1. Java 是什么&#xff1f;能干什么&#xff1f;1.1 Java 背景知识1.2 Java 能做什么&#xff1f;1.3 Java 技术体系 2. 如何使用 Java&…...

SLAM中的状态估计理论:从基础到前沿的完整解析

SLAM中的状态估计理论&#xff1a;从基础到前沿的完整解析 一、SLAM状态估计基础与问题建模 1&#xff0e;状态估计问题的数学描述 在SLAM&#xff08;Simultaneous Localization and Mapping&#xff0c;同时定位与地图构建&#xff09;中&#xff0c;状态估计问题的核心在…...

Android 自带的分享功能分享到三方应用

1. 分享视频到三方应用 var shareIntent Intent(Intent.ACTION_SEND)shareIntent.setType("video/*")shareIntent.putExtra(Intent.EXTRA_STREAM, Uri.parse(path))startActivity(Intent.createChooser(shareIntent, "")) 2. 分享音频到三方应用 var sha…...

宇树科技开启“人形机器人格斗盛宴”

2025年5月至6月&#xff0c;一场备受瞩目的全球性科技盛事——全球首届“人形机器人格斗大赛”将由杭州宇树科技隆重开启。赛事将带来前所未有的机器人格斗视觉冲击&#xff0c;吸引全球目光聚焦。 为打造顶级参赛队伍&#xff0c;宇树科技的技术精英团队已连续多周开展密集的算…...

K8S - 命名空间实战 - 从资源隔离到多环境管理

引言 在传统的物理机或虚拟机环境中&#xff0c;不同业务应用共享资源&#xff0c;容易导致权限冲突、资源争用和管理混乱。Kubernetes 通过 命名空间&#xff08;Namespace&#xff09;实现资源逻辑隔离&#xff0c;将集群划分为多个虚拟子集群&#xff0c;从而解决以下问题&…...

【安全扫描器原理】基于协议的服务扫描器

【安全扫描器原理】基于协议的服务扫描器 1.概述2.服务扫描的基本原理3.WWW服务扫描4.FTP服务扫描5.Telnet服务扫描1.概述 一台计算机逻辑上可以提供多项服务,每安装一个服务,即打开了一个或多个端口。从这个角度上看,每个服务对应一个或几个指定端口,反之,如果能检测到某…...

第十六届蓝桥杯 2025 C/C++组 数列差分

目录 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 思路&#xff1a; 核心算法&#xff1a; 思路详解&#xff1a; 代码&#xff1a; 代码详解&#xff1a; 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; P12342 [蓝桥杯 2025 省 B/Py…...

模式识别的基本概念与理论体系

前面在讨论专家系统时曾经说过&#xff0c;为了使计算机具有自动获取知识的能力&#xff0c;除了应使它具有学习能力外&#xff0c;还应使它具有能识别诸如文字、图形、图象、声音等的能力&#xff0c;计算机的这种识别能力是模式识别研究的主要内容。当然&#xff0c;模式识别…...

机器学习,深度学习

定义&#xff08;非正式&#xff09;&#xff1a;不进行明确编程的情况下&#xff0c;提供大量数据让计算机进行自我学习分类&#xff1a;监督(supervised)学习&#xff0c;无监督(unsupervised)学习监督学习&#xff1a;提供的数据中包含了问题到正确答案(x到y)的映射&#xf…...

smolagents - Guided tour

https://colab.research.google.com/github/huggingface/notebooks/blob/main/smolagents_doc/en/pytorch/guided_tour.ipynbhttps://colab.research.google.com/github/huggingface/notebooks/blob/main/smolagents_doc/en/pytorch/guided_tour.ipynb...

【keil使用】无法打开keil工程,只有空白界面的解决方法

【keil使用】无法打开keil工程&#xff0c;只有空白界面的解决方法 一、最常见的原因 在我们新建keil工程或下载其他大佬的keil工程的时候可能会出现工程无法正常打开的情况&#xff0c;如图所示&#xff1a; 其中最常见的一个原因就是keil工程的目录路径太长了&#xff0c;W…...

openEuler 22.03 安装 Nginx,支持离线安装

目录 一、环境检查1.1 必要环境检查1.2 在线安装&#xff08;有网络&#xff09;1.3 离线安装&#xff08;无网络&#xff09; 二、下载Nginx2.1 在线下载2.2 离线下载 三、安装Nginx四、开机自启服务五、开放防火墙端口六、常用命令 一、环境检查 1.1 必要环境检查 # 查看 g…...

Excel 数组功能及应用示例

Excel表格中的数组&#xff08;Array&#xff09;是一个可以同时存储和操作多个数据的结构。数组可以是单行、单列&#xff08;一维数组&#xff09;或多行多列&#xff08;二维数组&#xff09;。在Excel中&#xff0c;数组公式或动态数组功能可以一次性处理多个值&#xff0c…...

C++后端服务器开发:侵入式与非侵入式程序结构解析

在C后端服务器开发中&#xff0c;架构设计是决定系统性能、可扩展性和可维护性的关键因素之一。尽管不同的业务需求会导致服务器架构的多样化&#xff0c;但网络通信模块作为所有服务的通用部分&#xff0c;为我们提供了一个抽象和讨论的基础。基于此&#xff0c;我们可以将服务…...

「Mac畅玩AIGC与多模态09」开发篇05 - 使用自定义天气查询插件开发智能体应用

一、概述 本篇介绍如何在 macOS 环境下,通过编写自定义 OpenAPI Schema,将天气查询服务接入 Dify 平台,并开发基于实时天气信息的智能体应用。本案例培养路径参数与查询参数结合的插件开发技巧,实现智能体和外部实时数据的动态联动。 二、环境准备 1. 确认本地开发环境 …...

Maven插件学习(五)—— 将项目构建生成的 OSGi Bundles(或 Features)发布到一个 P2 仓库

发布OSGi Bundles到一个 P2 仓库 读取项目中properties文件中的属性 <plugin><groupId>org.codehaus.mojo</groupId><artifactId>properties-maven-plugin</artifactId><version>1.0-alpha-2</version><executions><exec…...

欧拉计划 Project Euler61(循环的多边形数)题解

欧拉计划 Project Euler 61 题解 题干思路code 题干 思路 先生成所有四位数的多边形数集合分类保存&#xff0c;然后dfs找即可 code // 2512 1281 8128 2882 8256 5625 // 28684 #include <bits/stdc.h>using namespace std;using ll long long;typedef vector<i…...

C语言与Unix的传奇起源

C语言与Unix的传奇起源 背景&#xff1a;Multics项目的困境 这段历史要从20世纪60年代中叶的美国说起。当时&#xff0c;三大技术巨头——麻省理工学院&#xff08;MIT&#xff09;、AT&T贝尔实验室和通用电气&#xff08;GE&#xff09;——联手为GE-645大型机开发一个名…...

C#扩展方法与Lambda表达式基本用法

C# 扩展方法与 Lambda 表达式详解 一、扩展方法详解 1. 基本概念 ​​扩展方法​​允许为现有类型"添加"方法&#xff0c;而无需修改原始类型或创建派生类型。 ​​定义条件​​&#xff1a; 必须在静态类中定义方法本身必须是静态的第一个参数使用this修饰符指…...