JWT深度解析:现代Web身份验证的通行证-优雅草卓伊凡
# JWT深度解析:现代Web身份验证的通行证
## 一、JWT的本质与构成
### 1.1 JWT的定义解析
JWT(JSON Web Token)是一种**开放标准(RFC 7519)**,用于在各方之间安全地传输信息作为JSON对象。这种信息可以被验证和信任,因为它是经过**数字签名**的。JWT可以使用密钥(HMAC算法)或使用RSA或ECDSA的公钥/私钥对进行签名。
**核心特征**:
- 紧凑的URL安全字符串表示
- 包含声明(claims)的独立验证机制
- 可选择加密保障隐私(JWE)
- 跨语言支持(所有主流语言均有实现)
### 1.2 JWT的结构解剖
一个典型的JWT由三部分组成,用点(.)分隔:
```
Header.Payload.Signature
```
**示例JWT**:
```
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.
eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.
SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
```
#### (1) Header(头部)
```json
{
"alg": "HS256", // 签名算法
"typ": "JWT" // 令牌类型
}
```
*经过Base64Url编码形成第一部分*
#### (2) Payload(负载)
包含**声明(claims)**,即关于实体(通常是用户)和其他数据的声明。有三种类型的声明:
- **注册声明**(预定义):iss(签发者)、exp(过期时间)、sub(主题)等
- **公共声明**:可以自定义,但建议在IANA JSON Web Token Registry中定义
- **私有声明**:自定义声明,用于在同意使用它们的各方之间共享信息
```json
{
"sub": "1234567890",
"name": "John Doe",
"admin": true,
"iat": 1516239022
}
```
#### (3) Signature(签名)
通过将编码后的header、编码后的payload、一个密钥(secret)和header中指定的算法生成签名。例如HMAC SHA256算法:
```
HMACSHA256(
base64UrlEncode(header) + "." +
base64UrlEncode(payload),
secret)
```
## 二、JWT与RESTful架构的共生关系
### 2.1 RESTful的身份验证挑战
REST(Representational State Transfer)架构风格的核心原则之一是**无状态性**,这意味着服务器不应在请求之间保留客户端的状态。这与传统的**会话(Session)认证**方式存在根本矛盾:
1. **会话机制的问题**:
- 服务器需要维护会话存储
- 水平扩展困难(需要会话复制或粘性会话)
- CSRF攻击风险
2. **JWT的解决方案**:
```mermaid
sequenceDiagram
客户端->>+服务器: 登录请求(用户名/密码)
服务器-->>-客户端: 返回JWT
客户端->>+服务器: 携带JWT的API请求
服务器-->>-客户端: 返回数据
```
*完全无状态的交互流程*
### 2.2 JWT赋能RESTful设计
1. **真正的无状态实现**:
- 每个请求包含完整认证信息
- 服务器无需维护会话状态
2. **跨域资源共享(CORS)友好**:
- 不需要cookie
- 适合前后端分离架构
3. **微服务场景优势**:
- 服务间无需共享会话存储
- 令牌可携带用户上下文
## 三、JWT与传统方式的革命性对比
### 3.1 会话(Session)认证流程
```mermaid
graph TD
A[客户端登录] --> B[服务器创建Session]
B --> C[存储SessionID到Cookie]
C --> D[后续请求携带Cookie]
D --> E[服务器查询Session存储]
E --> F[验证身份]
```
### 3.2 JWT认证流程
```mermaid
graph TD
A[客户端登录] --> B[服务器生成JWT]
B --> C[返回JWT给客户端]
C --> D[客户端存储JWT]
D --> E[请求携带JWT]
E --> F[服务器验证签名]
F --> G[处理请求]
```
### 3.3 关键差异矩阵
| 维度 | 传统Session | JWT |
|--------------------|---------------------------|---------------------------|
| **存储位置** | 服务器内存/数据库 | 客户端存储 |
| **扩展性** | 需要会话复制 | 天然支持分布式 |
| **CSRF防护** | 需要额外措施 | 天生免疫 |
| **移动端友好度** | 差(依赖Cookie) | 优秀(多种存储方式) |
| **性能开销** | 每次查询会话存储 | 仅签名验证 |
| **有效期控制** | 服务端强制过期 | 依赖令牌中的exp声明 |
## 四、JWT的三大核心优势比喻
### 4.1 比喻一:自助通关的电子护照
**类比说明**:
- **传统方式**:像旧式海关,需要反复查验证件并登记(服务器查会话)
- **JWT方式**:如现代电子护照,内含可验证的加密芯片(签名),海关只需扫描即可获取全部信息并验证真伪
**技术映射**:
- 生物特征数据 → JWT Payload中的用户声明
- 防伪芯片技术 → 数字签名算法
- 护照有效期 → exp声明
**优势体现**:
- 减少服务器查询(海关无需联系发证机关)
- 加快通关速度(减少网络往返)
- 支持多国通行(跨域认证)
### 4.2 比喻二:自带票根的演唱会手环
**场景描述**:
- **传统票务**:入场时兑换纸质票,离场后失效,再次入场需重新验票(类似会话)
- **手环系统**:佩戴防水手环,内含RFID芯片记录购票信息(JWT),可多次进出
**技术对应**:
| 手环特性 | JWT实现 |
|----------------|------------------------|
| 防水材质 | Base64URL安全编码 |
| RFID信息 | Payload中的用户声明 |
| 扫描枪验证 | 签名验证 |
| 当日有效 | exp过期时间 |
**核心价值**:
- 用户体验流畅(无重复认证)
- 主办方节省人力(无需维持验票状态)
- 防止假票(签名防篡改)
### 4.3 比喻三:多功能智能门禁卡
**传统门禁**:
- 中央控制室需持续供电维护门禁状态
- 每个门禁点需要实时联网验证
- 权限变更延迟大
**JWT式智能卡**:
- 卡内芯片存储加密的权限信息(JWT Payload)
- 门禁终端本地验证数字签名
- 可包含细粒度权限(不同区域访问权)
- 可设置失效时间(临时访客卡)
**技术优势**:
- 断电仍可工作(离线验证)
- 权限实时更新(重发令牌即可)
- 最小化中央系统压力
## 五、JWT的现代应用场景
### 5.1 单点登录(SSO)系统
**实现流程**:
1. 用户登录认证服务器获取JWT
2. 访问其他系统时携带该JWT
3. 各系统独立验证令牌有效性
**优势**:
- 避免密码重复输入
- 无需集中式会话存储
- 安全域间信任建立简单
### 5.2 微服务架构认证
```mermaid
graph LR
A[客户端] --> B[API网关]
B --> C[微服务A]
B --> D[微服务B]
style A fill:#f9f,stroke:#333
style B fill:#bbf,stroke:#333
style C fill:#f96,stroke:#333
style D fill:#f96,stroke:#333
%% JWT传递
A -. 携带JWT .-> B
B -. 转发JWT .-> C
B -. 转发JWT .-> D
```
**价值体现**:
- 服务间无需认证中心
- 用户上下文完整传递
- 细粒度权限控制(每个服务可解析JWT中的角色)
### 5.3 移动应用认证
**最佳实践**:
- 客户端持久化存储JWT(SecureStorage)
- 刷新令牌机制保障长期可用性
- 生物识别二次验证敏感操作
**安全模式**:
```swift
// iOS钥匙链存储示例
let token = "eyJhbGciOiJIUz..."
let query: [String: Any] = [
kSecClass as String: kSecClassGenericPassword,
kSecAttrAccount as String: "com.app.jwt",
kSecValueData as String: token.data(using: .utf8)!
]
SecItemAdd(query as CFDictionary, nil)
```
## 六、JWT实施的关键考量
### 6.1 安全最佳实践
1. **算法选择**:
- 优先使用RS256(非对称)而非HS256(对称)
- 禁用none算法
2. **有效期控制**:
- 设置合理的exp(通常2小时)
- 使用refresh_token延长会话
3. **敏感数据**:
- Payload不存储密码等机密信息
- 敏感声明可考虑JWE加密
### 6.2 性能优化策略
1. **令牌压缩**:
- 精简必要声明
- 避免过度使用公共声明
2. **验证缓存**:
```python
# Python伪代码示例
from datetime import timedelta
from django.core.cache import cache
def verify_jwt(token):
# 检查缓存
if cache.get(f"valid_token:{token}"):
return True
# 正常验证流程
if jwt_verify(token):
# 有效期内缓存验证结果
cache.set(f"valid_token:{token}", True, timeout=timedelta(minutes=30))
return True
return False
```
3. **分布式黑名单**:
- 登出令牌加入短期黑名单
- Redis存储失效令牌(需权衡无状态性)
## 七、未来演进方向
### 7.1 JWT与新兴技术结合
1. **区块链身份**:
- 将DID(去中心化身份)嵌入JWT
- 智能合约验证令牌有效性
2. **量子安全**:
- 抗量子计算签名算法(如CRYSTALS-Dilithium)
- 后量子加密Payload
3. **零信任架构**:
- 超短有效期JWT(如5分钟)
- 持续重新认证
### 7.2 标准扩展演进
1. **JWT瘦身**:
- IETF草案draft-ietf-oauth-jwt-encoded-claims
- 外部引用声明减少令牌体积
2. **交互式证明**:
- 结合zk-SNARKs实现选择性披露
- 保护用户隐私同时满足验证需求
## 结语:身份验证的新范式
JWT技术代表着身份验证从**中心化管控**到**去中心化验证**的范式转变。正如卓伊凡在多个大型分布式系统架构中验证的,JWT不仅解决了RESTful架构的无状态难题,更为现代应用提供了:
1. **横向扩展能力**:无需会话复制即可实现分布式认证
2. **协议中立性**:适用于HTTP/2、gRPC甚至MQTT等各类协议
3. **全栈一致性**:Web、移动端、IoT设备统一认证机制
尽管JWT需要开发者改变传统的会话思维模式,但其带来的架构简洁性和系统弹性,使其成为云原生时代不可逆转的技术趋势。正如护照的电子化改革一样,JWT正在成为数字世界的**通用身份通行证**,为万物互联的未来奠定安全基石。
相关文章:
JWT深度解析:现代Web身份验证的通行证-优雅草卓伊凡
# JWT深度解析:现代Web身份验证的通行证 ## 一、JWT的本质与构成 ### 1.1 JWT的定义解析 JWT(JSON Web Token)是一种**开放标准(RFC 7519)**,用于在各方之间安全地传输信息作为JSON对象。这种信息可以被…...
VTK|.obj文件数据处理+Jet/Viridis/CoolToWarm/Grayscale/Rainbow/风格颜色渲染
文章目录 处理OBJ文件Jet渲染风格Viridis渲染风格CoolToWarm渲染风格Grayscale渲染风格Rainbow渲染风格切换风格按钮槽函数(可优化)相关代码github链接 将 .obj 数据进行 Elevation 着色并可视化渲染的完整流程 和.ply文件处理方式一样 处理OBJ文件 vo…...
如何通过服务主体获取 Azure 凭据
本文详细讲解如何通过 Azure 服务主体生成凭据,使应用程序能够安全访问 Azure 资源(如部署 Container Apps)。以下步骤基于 Azure Portal 操作,适用于自动化部署、CI/CD 等场景。 步骤 1:登录 Azure Portal 访问 Azure 门户。使用 Azure 账户(需具备订阅管理员权限)登录…...
Kubernetes探针生产环境实战指南
一、探针的本质:应用健康的智能体检系统 想象你的应用是一个高空走钢丝的演员,Kubernetes探针就像三位安全员: 启动探针:检查演员是否站稳(应用是否完成初始化)就绪探针:确认演员准备好表演&a…...
node.js 实战——express图片保存到本地或服务器(七牛云、腾讯云、阿里云)
本地 ✅ 使用formidable 读取表单内容 npm i formidable ✅ 使用mime-types 获取图片后缀 npm install mime-types✅ js 中提交form表单 document.getElementById(uploadForm).addEventListener(submit, function(e){e.preventDefault();const blob preview._blob;if(!blob)…...
线代第二章矩阵第五、六、七节矩阵的转置、方阵的行列式、方阵的伴随矩阵
文章目录 矩阵的转置转置性质对称矩阵与反对称矩阵 方阵的行列式方阵的伴随矩阵(重要) 矩阵的转置 转置性质 (1) (2) (3) (4)注意这个: 扩展&a…...
经验:从CAN到以太网为主的车载网络架构升级
引言 新能源汽车智能化与网联化的进程中,传统CAN总线已难以满足高带宽、低延迟的通信需求,车载以太网逐步成为新一代电子架构的核心骨干。本文基于工程实践,系统性解析车载以太网的核心技术、协议栈、拓扑设计及工具链升级策略,助…...
基于FPGA婴儿安全监护系统(蓝牙小程序监测)
基于FPGA婴儿安全监护系统 前言一、芯片手册阅读二、代码分析1.温湿度驱动2.转速等级设置模块3.电机转速控制模块 总结视频演示 前言 实时监测车内温湿度数据(DTH11温湿度模块)----实时控制风扇驱动速度(结合温湿度进行控制)----…...
嵌入式 C 语言控制语句
目录 1. 控制语句 2. 分支语句 2.1 if else 2.2 switch 3. 循环语句 3.1 goto 3.2 while 循环 3.3 do while 循环 3.4 for 循环 3.5 例题 3.6 循环控制语句 3.6.1 break 3.6.2 continue 1. 控制语句 控制语句分为:顺序语句,分支语句࿰…...
leaflet-velocity风场粒子效果及数据处理
一,后台给到的数据 {"msg": "success","code": 200,"data": {"startLat": 39.3,"endlat": 41.2,"latdel": 0.099999994,"startLon": 115.3,"endLon": 117.50001,"…...
React 实现 JWT 登录验证的最小可运行示例
下面是一个用 React 实现 JWT 登录验证的最小可运行示例,包含: React 前端:登录、保存 Token、获取用户数据。模拟后端:用 mock API(你也可以接真后端)。 🧱 技术栈 React(使用 Vi…...
MySQL报错解决过程
我在调试datagrip的时候,显示拒绝连接,开始的时候,我以为只是服务没有开启,结果到后来在网上搜索各种解决办法无果后,就选择卸载,卸载之后安装新的MySQL 以下就是我的解决过程。 如果只是在使用外置软件&…...
更多 QVariant 使用案例
以下是 QVariant 的其他典型应用场景及代码示例,涵盖更多实际开发需求: 6. 数据库查询结果处理 处理数据库字段的异构数据类型(如整数、字符串、日期等): QSqlQuery query; query.exec("SELECT name, age, crea…...
WPF中解决数据绑定不匹配的问题
在 WPF 开发中,IValueConverter 和 IMultiValueConverter 接口是非常实用的工具,它们允许你在数据绑定过程中对数据进行转换。 IValueConverter 接口示例 IValueConverter 接口用于单值转换,它包含 Convert 和 ConvertBack 两个方法。Conve…...
学习Cesium Entities
🌐 Cesium中的Entities系统趣味学习 📊 Entities系统架构流程图 #mermaid-svg-Lkue5O3gYOkEVSbD {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Lkue5O3gYOkEVSbD .error-icon{fill:#552222;}#mermaid-svg-Lku…...
Spark处理过程-案例数据清洗
(一)需求说明 准备十条符合包含用户信息的文本文件,每行格式为 姓名,年龄,性别,需要清洗掉年龄为空或者非数字的行。 例如: 张三,25,男 李四,,女 王五,30,男 赵六,a,女 孙七,35,男 周八,40,女 吴九,abc,男 郑十,45,女…...
【AI提示词】马斯洛需求分析专家
提示说明 专业的心理学需求分析专家,熟悉马斯洛需求层次理论及其在不同文化背景下的适用性。 提示词 # Role: 马斯洛需求分析专家## Profile - language: 中文 - description: 专业的心理学需求分析专家,熟悉马斯洛需求层次理论及其在不同文化背景下的…...
【WebRTC-13】是在哪,什么时候,创建编解码器?
Android-RTC系列软重启,改变以往细读源代码的方式 改为 带上实际问题分析代码。增加实用性,方便形成肌肉记忆。同时不分种类、不分难易程度,在线征集问题切入点。 问题:编解码器的关键实体类是什么?在哪里&什么时候…...
Kuikly 安装环境篇
1、安装版本号为2024.1.1 的Android studio(如使用高版本的Android studio需要更改JDK版本号为17) 2、JDK版本使用17(如需要修改JDK:Android Studio -> Settings -> Build,Execution,Deployment -> Build Tools -> Gr…...
npm create vite@latest my-vue-app 解读
背景发荧光的样式。 filter属性的学习:filter - CSS:层叠样式表 | MDN 复习一下em 组件的调用: 是msg让“ViteVue”显示出来的!! a标签的targte属性: 组件之间怎么传值的: ,没看懂code标签怎么…...
【本地搭建npm私服】使用Verdaccio
使用Verdaccio搭建本地NPM私服及私有包管理指南 一、Verdaccio安装与基础配置 1. 安装Verdaccio # 全局安装Verdaccio npm install -g verdaccio# 检查版本 verdaccio --version2. 启动服务 verdaccio启动后默认监听4873端口,访问 http://localhost:4873 3. 配…...
Chroma:一个开源的8.9B文生图模型
Chroma 模型讲解 一、模型概述 Chroma 是一个基于 FLUX.1-schnell 的 8.9B 参数模型。它采用了 Apache 2.0 许可证,完全开源,允许任何人使用、修改和在其基础上进行开发,不存在企业限制。该模型目前正在训练中,训练数据集从 20M…...
量子通信技术及其在信息安全中的应用:开启无条件安全通信的新时代
前言 在数字化时代,信息安全是全球关注的焦点。随着传统加密技术面临量子计算等新兴技术的挑战,量子通信作为一种基于量子力学原理的新型通信技术,因其无条件安全的特性而备受关注。量子通信不仅能够有效抵御量子计算的威胁,还能为…...
【杂谈】Godot 2D游戏窗口设置
如切如磋,如琢如磨。 目录 一、引言二、设置(一)基本尺寸(二)拉伸(三)手持设备朝向(四)窗口模式 一、引言 在开发2D游戏时,窗口尺寸的设定是游戏…...
MySQL 8.0 OCP认证考试题库持续更新
MySQL是属于甲骨文Oracle公司的一个世界知名的免费数据库产品,使用的范围广、企业多、人员也多,所以对MySQL认证关注的人也不少,MySQL的证书与Oracle的证书使用的是同一个模板,只是在内部的介绍上稍有不同,MySQL认证考…...
C++GO语言微服务基础技术②
目录 01 protobuf语法回顾 02 protobuf的编译、和其他序列化比较 03 查看protoc编译文件对比自定义封装 04 grpc安装简介 05 grpc服务远程调用作业布置 06 作业-grpc-server端 07 作业-grpc-client端 01 protobuf语法回顾 ## 编译 protobuf> 回顾:C 编译 …...
【使用switch结构输出季节】2021-11-23
缘由用switch语句设计程序一年有12个月-编程语言-CSDN问答 void 使用switch结构输出季节(int y) {//缘由https://ask.csdn.net/questions/7577096?spm1005.2025.3001.5141std::cout << y << "\t";switch (y){case 3: case 4: case 5:std::cout <<…...
【Bootstrap V4系列】学习入门教程之 组件-下拉菜单(Dropdowns)
Bootstrap V4系列 学习入门教程之 组件-下拉菜单(Dropdowns) 下拉菜单(Dropdowns)一、Overview 概述二、Accessibility 可访问性三、Examples3.1 Single button 单按钮3.2 Split button 分割按钮 四、Sizing 尺寸 下拉菜单&#x…...
基础编程题目集 6-8 简单阶乘计算
本题要求实现一个计算非负整数阶乘的简单函数。 函数接口定义: int Factorial( const int N ); 其中N是用户传入的参数,其值不超过12。如果N是非负整数,则该函数必须返回N的阶乘,否则返回0。 裁判测试程序样例: #in…...
解决word里插入公式后打不开的问题
小铃铛最近在写毕业论文了,需要在文档里插入公式,然鹅一插入就卡死了,直接关闭文档后就再也打不开了,报错什么确定磁盘有空间(?总之就是文档损坏的意思) 这个时候不要慌,先把word后缀…...
android studio开发:设置屏幕朝向为竖屏,强制应用的包体始终以竖屏(纵向)展示
在 Android 中,要强制应用的包体始终以竖屏(纵向)展示,可以通过以下几种方式来实现: ✅ 方式一: 在 AndroidManifest.xml 中设置 Activity 的方向,这是最常用的方法。对所有需要强制竖屏的 Ac…...
中国自动驾驶研发解决方案,第一!
4月28日,IDC《中国汽车云市场(2024下半年)跟踪》报告发布,2024下半年中国汽车云市场整体规模达到65.1亿元人民币,同比增长27.4%。IDC认为,自动驾驶技术深化与生成式AI的发展将为汽车云打开新的成长天花板,推动云计算在…...
OpenCv实战笔记(3)基于opencv实现调用摄像头并实时显示画面
一、实现效果 二、实现原理 使用 OpenCV 打开摄像头,持续捕获视频帧,并在一个窗口中实时显示这些帧,直到用户按下 ESC 键退出。整体流程:打开摄像头(cv::VideoCapture)>创建图像显示窗口(cv…...
SpringBoot3 + Druid + DynamicDataSource + PgSQL 连接池优化方案
问题描述 使用 SpringBoot Druid DynamicDataSource PgSQL 时遇到的连接过多未释放问题,一方面是升级DB Core对DB做Tuning,另一方面是优化Druid数据库连接池方案。 关键优化方向 连接泄漏检测与回收 连接有效性验证 合理的连接池大小配置 闲置连接…...
C++ 深入解析 数据结构中的 AVL树的插入 涉及的旋转规则
欢迎来到干货小仓库 "普通程序员Google 超级程序员" 1、AVL 树的概念 二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。 例如在这种情况下&…...
c++中的引用
1,引用的基本使用: 作用:给变量起别名 语法:数据类型 &别名 原名 #include<iostream> using namespace std; int main() {int a10;int &ba;cout<<"a "<<a<<endl;cout<<&quo…...
零拷贝的简单复习
PageCache PageCache是内核缓冲区 DMA 没有DMA前的IO:整个数据的传输过程,都需要 CPU 亲自参与搬运数据的过程,而且这个过程中CPU 是不能做其他事情的 CPU发起IO 磁盘将数据放到磁盘缓冲区 CPU将磁盘缓冲区数据放到内核缓冲区 CPU将内核缓…...
CCF编程能力等级认证 一级 第一次课
介绍 CCF 编程能力等级认证(GESP)为青少年计算机和编程学习者提供学业能力验证的规则和平台,由中国计算机学会发起并主办。 每年考试分四次,时间是每年的3月、6月、9月、12月,以当年每期公布的时间为准。 GESP适用年…...
芯片测试之Open-Short Test全解析:从原理到实战
大家好,我是硅言。最近在开发NORD的AC、DC测试程序,准备和大家聊聊NOR Flash一套完整的AC、DC测试,要测哪些参数,如何测试等等。OS测试(Open-Short Test,开短路测试)作为芯片测试"…...
文件包含 任意文件读取
文件处理漏洞--文件包含 - wizard骑士 - 博客园 1,什么是文件包含 程序开发人员一般会吧重复使用的函数写道单个文件中,需要使用某个函数时直接调用此文件,无需再次编写,文件调用的过程就是文件包含,所以将包含的文件…...
string[字符串中第一个的唯一字符][蓝桥杯]
使用哈希表解决 class Solution { public:int firstUniqChar(string s) {int arr[26];for(int i0;i<s.size();i){arr[s[i]-a];}for(int i0;i<s.size();i){if(arr[s[i]-a]1)return i;}return -1;} };...
sql server限制用户只能访问特定表
一个老系统的sqlserver 数据库需要新建一个用户,并限制这个新用户只能访问指定的几个数据表。 1.夺权 创建用户简单,但是登录用户没有管理权,windows管理员登录用户也没有管理权限,这就需要夺权,在单用户模式下&…...
中级网络工程师知识点2
1.netstat -r:显示路由表信息 netstat -a:显示所有活动的TCP连接数以及计算机正在监听的TCP和UDP端口 netstat -e:显示以太网统计信息 netstat -n:以数字形式显示网络地址和端口号 2.display multicast forwarding-table 命令的作用是查看组播转发表信息。 display multic…...
SQL常用操作大全:复制表、跨库查询、删除重复数据
大家好,欢迎来到程序视点!我是你们的老朋友.小二! SQL常用操作精华总结 表结构与数据操作 复制表结构: SELECT * INTO b FROM a WHERE 1<>1 (SQL Server专用) SELECT TOP 0 * INTO b FROM a (更通用) 拷贝表数据&#…...
辰鳗科技朱越洋:紧扣时代契机,全力投身能源转型战略赛道
国家能源局于4月28日出台的《关于促进能源领域民营经济发展若干举措的通知》(以下简称《通知》),是继2月民营企业座谈会后深化能源领域市场化改革的关键政策,标志着民营经济在“双碳”目标引领下正式进入能源转型的核心赛道。 自…...
java 破解aspose.words 18.6 使用
资源包:https://download.csdn.net/download/qq_36598111/90787167 jar包是破解过的,直接可以使用。 引入jar,要引入本地的,不要直接引入仓库的 <dependency><groupId>com.aspose</groupId><artifactId>…...
基于鸢尾花(Iris)数据集的分类模型
本文适合初学者入门,涵盖了数据加载、预处理、建模、训练和评估的全过程。 🎯 项目目标 使用机器学习算法(如K近邻KNN)对鸢尾花的品种进行分类。 🧰 所需工具 Python 3.x 安装的库: pip install scikit…...
电容知识小结
1.同样是电容,1uf的陶瓷电容和1uf的铝电解电容是不一样的; 2.实际的电容等效为ESR C ESL;ESR等效电阻和ESL等效电感; 3.铝电解电容,瓷片电容和钽电容。 4.电容是容纳和释放电荷的电子器件; 5.电容的工作:…...
基于springboot+vue的校园部门资料管理系统
开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7数据库工具:Navicat12开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9 系统展示 系统登录 学生组…...
LeetCode 热题 100 131. 分割回文串
LeetCode 热题 100 | 131. 分割回文串 大家好,今天我们来解决一道经典的回溯算法问题——分割回文串。这道题在 LeetCode 上被标记为中等难度,要求将一个字符串 s 分割成若干个子串,使得每个子串都是回文串,并返回所有可能的分割…...