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

使用Java实现Navicat密码的加密与解密

在日常开发过程中,我们有时需要处理各种软件保存的凭据信息,比如数据库连接密码等。这篇文章将介绍如何使用Java对Navicat保存的数据库密码进行加密和解密。

一、背景介绍

Navicat是一款强大的数据库管理工具,支持多种数据库系统。为了保护用户的数据库凭据,Navicat对用户输入的密码进行了加密处理。本文基于Navicat 12及以后版本使用的AES加密算法,以及Navicat 11及以前版本使用的Blowfish加密算法,展示如何通过Java代码实现这些密码的加密和解密。

二、环境准备

确保您的开发环境中已经配置好Java,并且引入了必要的安全库来支持加密操作。对于本教程,我们将直接使用JDK自带的javax.crypto包。

三、代码解析

加密逻辑

  • AES加密(适用于Navicat 12及以上版本):采用固定密钥和初始化向量(IV)。

  • Blowfish加密(适用于Navicat 11及以下版本):同样使用固定的密钥和IV,但加密过程包括了一步异或操作。

解密逻辑

解密逻辑相对应地分为AES解密和Blowfish解密两种情况,具体实现请参见上述代码片段中的decryptAESdecryptBlowfish方法。

四、核心代码展示

package com.aigc.admin.controller;import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.util.Arrays;/*** @author albert_luo@lizipro.cn* @version 1.0* @description: TODO* @date 04 Apr 2025 00:29*/
public class NavicatPasswordUtil {public static void main(String[] args) throws Exception {// 创建 NavicatPasswordUtil 实例NavicatPasswordUtil passwordUtil = new NavicatPasswordUtil();// 待解密的密码字符串String encryptedPassword = "30A228E829283FEA8540DA18D2B6A302";// 解密 Navicat 12 及以后的版本String decryptedPassword = passwordUtil.decryptPassword(encryptedPassword, NavicatVersion.VERSION_12);// 正则替换控制符(如响铃、退格等)decryptedPassword = decryptedPassword.replaceAll("\\p{Cntrl}", "");// 输出解密后的明文 结果为 shiguangSystem.out.println("解密后的密码: " + decryptedPassword);}// AES 加密密钥private static final String AES_KEY = "libcckeylibcckey";// AES 加密向量private static final String AES_IV = "libcciv libcciv ";// Blowfish 加密密钥private static final String BLOWFISH_KEY = "3DC5CA39";// Blowfish 加密向量private static final String BLOWFISH_IV = "d9c7c3c8870d64bd";/*** 加密密码** @param plaintextPassword 明文密码* @param navicatVersion    加密版本(NavicatVersion.VERSION_11 或 NavicatVersion.VERSION_12)* @return 加密后的密文密码* @throws Exception 加密过程中可能抛出的异常*/public String encryptPassword(String plaintextPassword, NavicatVersion navicatVersion) throws Exception {switch (navicatVersion) {case VERSION_11:return encryptBlowfish(plaintextPassword);case VERSION_12:return encryptAES(plaintextPassword);default:throw new IllegalArgumentException("不支持的 Navicat 版本");}}/*** 解密密码** @param encryptedPassword 密文密码* @param navicatVersion    解密版本(NavicatVersion.VERSION_11 或 NavicatVersion.VERSION_12)* @return 解密后的明文密码* @throws Exception 解密过程中可能抛出的异常*/public String decryptPassword(String encryptedPassword, NavicatVersion navicatVersion) throws Exception {switch (navicatVersion) {case VERSION_11:return decryptBlowfish(encryptedPassword);case VERSION_12:return decryptAES(encryptedPassword);default:throw new IllegalArgumentException("不支持的 Navicat 版本");}}/*** 使用 Blowfish 加密密码(适用于 Navicat 11 及以前的版本)** @param plaintextPassword 明文密码* @return 加密后的密文密码* @throws Exception 加密过程中可能抛出的异常*/private String encryptBlowfish(String plaintextPassword) throws Exception {byte[] iv = hexStringToByteArray(BLOWFISH_IV);byte[] key = hashToBytes(BLOWFISH_KEY);int round = plaintextPassword.length() / 8;int leftLength = plaintextPassword.length() % 8;StringBuilder encryptedResult = new StringBuilder();byte[] currentVector = iv.clone();Cipher cipher = Cipher.getInstance("Blowfish/ECB/NoPadding");SecretKeySpec secretKeySpec = new SecretKeySpec(key, "Blowfish");cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);for (int i = 0; i < round; i++) {byte[] block = xorBytes(plaintextPassword.substring(i * 8, (i + 1) * 8).getBytes(), currentVector);byte[] encryptedBlock = cipher.doFinal(block);currentVector = xorBytes(currentVector, encryptedBlock);encryptedResult.append(bytesToHex(encryptedBlock));}if (leftLength > 0) {currentVector = cipher.doFinal(currentVector);byte[] block = xorBytes(plaintextPassword.substring(round * 8).getBytes(), currentVector);encryptedResult.append(bytesToHex(block));}return encryptedResult.toString().toUpperCase();}/*** 使用 AES 加密密码(适用于 Navicat 12 及以后的版本)** @param plaintextPassword 明文密码* @return 加密后的密文密码* @throws Exception 加密过程中可能抛出的异常*/private String encryptAES(String plaintextPassword) throws Exception {byte[] iv = AES_IV.getBytes();byte[] key = AES_KEY.getBytes();Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] encryptedResult = cipher.doFinal(plaintextPassword.getBytes());return bytesToHex(encryptedResult).toUpperCase();}/*** 使用 Blowfish 解密密码(适用于 Navicat 11 及以前的版本)** @param encryptedPassword 密文密码* @return 解密后的明文密码* @throws Exception 解密过程中可能抛出的异常*/private String decryptBlowfish(String encryptedPassword) throws Exception {byte[] iv = hexStringToByteArray(BLOWFISH_IV);byte[] key = hashToBytes(BLOWFISH_KEY);byte[] encryptedBytes = hexStringToByteArray(encryptedPassword.toLowerCase());int round = encryptedBytes.length / 8;int leftLength = encryptedBytes.length % 8;StringBuilder decryptedResult = new StringBuilder();byte[] currentVector = iv.clone();Cipher cipher = Cipher.getInstance("Blowfish/ECB/NoPadding");SecretKeySpec secretKeySpec = new SecretKeySpec(key, "Blowfish");cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);for (int i = 0; i < round; i++) {byte[] encryptedBlock = Arrays.copyOfRange(encryptedBytes, i * 8, (i + 1) * 8);byte[] decryptedBlock = xorBytes(cipher.doFinal(encryptedBlock), currentVector);currentVector = xorBytes(currentVector, encryptedBlock);decryptedResult.append(new String(decryptedBlock));}if (leftLength > 0) {currentVector = cipher.doFinal(currentVector);byte[] block = Arrays.copyOfRange(encryptedBytes, round * 8, round * 8 + leftLength);decryptedResult.append(new String(xorBytes(block, currentVector), StandardCharsets.UTF_8));}return decryptedResult.toString();}/*** 使用 AES 解密密码(适用于 Navicat 12 及以后的版本)** @param encryptedPassword 密文密码* @return 解密后的明文密码* @throws Exception 解密过程中可能抛出的异常*/private String decryptAES(String encryptedPassword) throws Exception {byte[] iv = AES_IV.getBytes();byte[] key = AES_KEY.getBytes();byte[] encryptedBytes = hexStringToByteArray(encryptedPassword.toLowerCase());Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] decryptedResult = cipher.doFinal(encryptedBytes);return new String(decryptedResult);}/*** 对两个字节数组进行异或操作** @param bytes1 第一个字节数组* @param bytes2 第二个字节数组* @return 异或结果字节数组*/private static byte[] xorBytes(byte[] bytes1, byte[] bytes2) {byte[] result = new byte[bytes1.length];for (int i = 0; i < bytes1.length; i++) {result[i] = (byte) (bytes1[i] ^ bytes2[i]);}return result;}/*** 将十六进制字符串转换为字节数组** @param hexString 十六进制字符串* @return 字节数组*/private static byte[] hexStringToByteArray(String hexString) {int len = hexString.length();byte[] data = new byte[len / 2];for (int i = 0; i < len; i += 2) {data[i / 2] = (byte) ((Character.digit(hexString.charAt(i), 16) << 4) + Character.digit(hexString.charAt(i + 1), 16));}return data;}/*** 将字符串哈希为字节数组** @param inputString 输入字符串* @return 哈希后的字节数组* @throws Exception 哈希过程中可能抛出的异常*/private static byte[] hashToBytes(String inputString) throws Exception {return MessageDigest.getInstance("SHA-1").digest(inputString.getBytes());}/*** 将字节数组转换为十六进制字符串** @param byteArray 字节数组* @return 十六进制字符串*/private static String bytesToHex(byte[] byteArray) {StringBuilder result = new StringBuilder();for (byte b : byteArray) {result.append(String.format("%02X", b));}return result.toString();}
}/*** Navicat 版本枚举*/
enum NavicatVersion {VERSION_11,VERSION_12
}

五、总结

通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密码进行加密和解密。这不仅有助于加深对加密技术的理解,同时也为实际项目中处理类似需求提供了参考方案。需要注意的是,在真实的应用场景中,应当遵循最佳的安全实践,如定期更换密钥、避免硬编码敏感信息等。


希望这篇博客能帮助读者更好地理解和应用Java中的加密技术。如果想要深入了解,建议尝试修改并运行上述代码,观察不同参数设置下的输出结果。

相关文章:

使用Java实现Navicat密码的加密与解密

在日常开发过程中&#xff0c;我们有时需要处理各种软件保存的凭据信息&#xff0c;比如数据库连接密码等。这篇文章将介绍如何使用Java对Navicat保存的数据库密码进行加密和解密。 一、背景介绍 Navicat是一款强大的数据库管理工具&#xff0c;支持多种数据库系统。为了保护…...

怎么样进行定量分析

本文章将教会你如何对实验结果进行定量分析&#xff0c;其需要一定的论文基础&#xff0c;文末有论文撰写小技巧&#xff0c;不要看基础原理的人可以直接调到文章末尾。 一、什么是定量分析 定量分析是一种基于数据和数学模型的分析方法&#xff0c;它在众多领域中发挥着至关…...

python学习day2

今天主要学习了变量的数据类型&#xff0c;以及如何使用格式化符号进行输出。 一、认识数据类型 在python里为了应对不同的业务需求&#xff0c;也把数据分为不同的类型。 代码如下&#xff1a; """ 1、按类型将不同的变量存储在不同的类型数据 2、验证这些…...

FreeMarker

概述&#xff1a;FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据&#xff0c; 并用来生成输出文本(HTML网页&#xff0c;电子邮件&#xff0c;配置文件&#xff0c;源代码等)的通用工具。 它不是面向最终用户的&#xff0c;而是一个Java类库&#xff0c;是一款程序…...

JDK 21新特性详解

JDK 21新特性详解&#xff1a;现代Java开发的重大更新 Java开发工具包(JDK)21作为最新的长期支持(LTS)版本&#xff0c;于2023年9月发布&#xff0c;带来了许多令人兴奋的新特性。作为Java开发者&#xff0c;了解这些新功能对于保持技术竞争力至关重要。本文将详细介绍JDK 21中…...

使用MCP驱动IDA pro分析样本

最近国外的牛人开发了一个ida pro的mcp server&#xff0c;项目的地址为mrexodia/ida-pro-mcp: MCP Server for IDA Pro&#xff0c;实现了通过自然对话来分析样本。 今天我们试用一下。 MCP Server for IDA Pro项目简介 这个mcp server提供下面这些工具&#xff0c;基本涵盖…...

Web前端开发:@media(媒体查询)

什么是媒体查询&#xff1f; 媒体查询是CSS3的一个功能&#xff0c;允许你根据设备的特性&#xff08;如屏幕宽度、设备方向、分辨率等&#xff09;应用不同的CSS样式。简单来说&#xff0c;就是让网页在不同设备上&#xff08;手机、平板、电脑&#xff09;自动调整布局和样式…...

psotgresql18 源码编译安装

环境&#xff1a; 系统&#xff1a;centos7.9 数据库&#xff1a;postgresql18beta1 #PostgreSQL 18 已转向 DocBook XML 构建体系&#xff08;SGML 未来将被弃用&#xff09;。需要安装 XML 工具链&#xff0c;如下&#xff1a; yum install -y docbook5-style-xsl libxsl…...

如何在VSCode中更换默认浏览器:完整指南

引言 作为前端开发者&#xff0c;我们经常需要在VSCode中快速预览HTML文件。默认情况下&#xff0c;VSCode会使用系统默认浏览器打开文件&#xff0c;但有时我们可能需要切换到其他浏览器进行测试。本文将详细介绍如何在VSCode中更换默认浏览器。 方法一&#xff1a;使用VSCo…...

Python Day26 学习

继续NumPy的学习 数组的索引 一维数组的索引 创建及输出 arr1d np.arange(10) # 数组: [0 1 2 3 4 5 6 7 8 9] arr1d array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]) 取出数组的第一个元素&#xff0c;最后一个元素 代码实现 arr1d[0] arr1d[-1] 取出数组中索引为3&#x…...

2025年PMP 学习二十一 14章 项目立项管理

2025年PMP 学习二十一 14章 项目立项管理 项目立项管理 项目建议 (Project Proposal)项目可行性分析 (Project Feasibility Analysis)项目审批 (Project Approval)项目招投标 (Project Tendering)项目合同谈判和签订 (Project Contract Negotiation and Signing) 文章目录 20…...

Ubuntu开机自启服务

一、准备启动脚本 在你的项目文件夹&#xff08;例如 /home/ubuntu/Plant_Diease_Recongnization_Server_1&#xff09;中创建一个启动脚本 run_ui_main.sh&#xff1a; #!/usr/bin/env bash # run_ui_main.sh&#xff1a;激活 yolov8 环境并启动 ui_main.py# 设置 Anaconda/…...

使用Docker部署React应用与Nginx

这个教程将帮助您使用Docker部署一个带有React的Nginx容器&#xff0c;并通过卷(volumes)将本地代码绑定到Docker容器中。这种设置非常适合开发环境&#xff0c;因为它允许您在本地编辑代码&#xff0c;而容器中的应用会自动更新。 步骤概述 创建Nginx配置文件创建Dockerfile…...

基于SpringBoot的小型民营加油站管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

Triton介绍和各平台支持情况分析

文章目录 &#x1f49e;Triton介绍&#x1f9e0; Triton 是什么&#xff1f;&#x1f50d; Triton 的核心特点&#x1f680; Triton 在 PyTorch 中的作用&#x1f4e6; Triton 的典型使用场景&#x1f9ea; 示例&#xff1a;Triton 编写的向量加法&#xff08;GPU 并行&#xf…...

HTTPS核心机制拆解

目录 引言 HTTPS和HTTP的区别 常见加密方式 数据摘要 数字证书与数据签名 HTTPS请求过程 结语 引言 HTTPS是什么&#xff1f;是一个应用层协议&#xff0c;在HTTP协议的基础上引入了一层加密层。为什么需要HTTPS&#xff1f;答案是显而易见的&#xff0c;要加密&#xf…...

我的食物信使女友

第一章&#xff1a;初识那是一个普通的周三下午&#xff0c;阳光透过咖啡馆的玻璃窗洒在木质的桌子上&#xff0c;空气中弥漫着咖啡的香气和轻柔的爵士乐。我坐在角落的一个位置&#xff0c;手中捧着一本已经翻了几十页的小说&#xff0c;但心思却完全不在文字上。我的生活就像…...

【D1,2】 贪心算法刷题

文章目录 不同路径 II整数拆分 不同路径 II 初始化的时候不能整列初始化为1&#xff0c;因为如果有障碍物&#xff0c;后面的都不能到达 也不能整列初始化为0&#xff0c;因为状态转移的时候第一行第一列都没有检查&#xff0c;因此不能部分初始化 整数拆分 需要考虑几种情况…...

C++多态的详细讲解

【本节目标】 1. 多态的概念 2. 多态的定义及实现 3. 抽象类 4. 多态的原理 5. 单继承和多继承关系中的虚函数表 前言 需要声明的&#xff0c;本博客中的代码及解释都是在 vs2013 下的 x86 程序中&#xff0c;涉及的指针都是 4bytes 。 如果要其他平台下&#xff0c;部…...

UE5在Blueprint中判断不同平台

在Unreal Engine 5的蓝图中&#xff0c;可以通过以下方法判断当前运行的平台&#xff08;如Android、Windows、iOS等&#xff09;&#xff0c;并根据平台执行不同的逻辑&#xff1a; 方法1&#xff1a;使用 Get Platform Name 节点 步骤&#xff1a; 在蓝图图表中右键点击&am…...

多卡跑ollama run deepseek-r1

# 设置环境变量并启动模型 export CUDA_VISIBLE_DEVICES0,1,2,3 export OLLAMA_SCHED_SPREAD1 # 启用多卡负载均衡 ollama run deepseek-r1:32b 若 deepseek-r1:32b 的显存需求未超过单卡容量&#xff08;如单卡 24GB&#xff09;&#xff0c;Ollama 不会自动启用多卡 在run…...

MAC电脑中右键后复制和拷贝的区别

在Mac电脑中&#xff0c;右键菜单中的“复制”和“拷贝”操作在功能上有所不同&#xff1a; 复制 功能&#xff1a;在选定的位置创建一个与原始文件相同的副本。快捷键&#xff1a;CommandD用于在当前位置快速复制文件&#xff0c;CommandC用于将内容复制到剪贴板。效果&…...

打卡第二十二天

知识点回顾&#xff1a; LDA线性判别PCA主成分分析t-SNE降维 还有一些其他的降维方式&#xff0c;也就是最重要的词向量的加工&#xff0c;我们未来再说。 作业&#xff1a; 自由作业&#xff1a;探索下什么时候用到降维&#xff1f;降维的主要应用&#xff1f;或者让AI给你出…...

【Unity 2023 新版InputSystem系统】新版InputSystem 如何进行人物移动(包括配置、代码详细实现过程)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、InputSystem配置二、GameInput 游戏输入脚本1.实现思路2.完整代码三、Player 游戏人物移动脚本1.实现思路2.完整代码四、场景脚本设置1.组件设置五、问题解决1.人物一直下落2.人物跳跃时,…...

Python实现的在线词典学习工具

Python实现的在线词典学习工具 源码最初来自网络&#xff0c;根据实际情况进行了修改。 主要功能&#xff1a; 单词查询 通过Bing词典在线获取单词释义&#xff08;正则提取网页meta描述&#xff09;&#xff0c;支持回车键快速查询 内置网络请求重试和异常处理机制 在线网页…...

软考 系统架构设计师系列知识点之杂项集萃(63)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之杂项集萃&#xff08;62&#xff09; 第102题 以下关于系统性能评估方法的描述&#xff0c;错误的是&#xff08;&#xff09;。 A. 指令执行速度法常用每秒百万次指令运算&#xff08;MIPS&#xff09;评估系统性能…...

python重庆旅游系统-旅游攻略

目录 技术栈介绍具体实现截图系统设计研究方法&#xff1a;设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理&#xff0c;难度适中&#xf…...

如何使用GIT管理项目代码

介绍 ​ Git是目前世界上最流行甚至最好的开源分布式版本控制系统&#xff0c;不论是很小的项目还是很大的项目&#xff0c;它都能有效并且高效的处理项目版本管理&#xff0c;初衷是为了帮助管理linux内核代码而开发的一个开放源码的版本控制软件。 GIT常用分支名称 分支分…...

Android 11.0 动画缩放默认值改为0.5的功能实现

1.前言 在11.0的系统rom定制化开发中,在关于设置动画的时候,系统有相关参数要求,设置默认的 动画缩放默认值等功能,来实现相关功能,接下来分析下相关的动画默认缩放值的设置功能实现 2.动画缩放默认值改为0.5的功能实现的核心类 frameworks/base/packages/SettingsProv…...

第35周Zookkeeper+Dubbo 面试题精讲

面试题精讲 一、算法面试答题思路 理解思路的重要性:算法面试比基础面试更复杂,需先想清楚思路,与面试官沟通确认题目条件(如数据范围、是否包含负数/零等),这有助于理清解题思路并展示技术实力。变量命名清晰:算法中变量命名要明确含义和范围,避免使用模糊的变量名,…...

Mergekit——任务向量合并算法Ties解析

Mergekit——高频合并算法 TIES解析 Ties背景Ties 核心思想具体流程总结 mergekit项目地址 Mergekit提供模型合并方法可以概况为三大类&#xff1a;基本线性加权、基于球面插值、基于任务向量&#xff0c;今天我们来刷下基于任务向量的ties合并方法&#xff0c;熟悉原理和代码。…...

初识 Redis

什么是 Redis&#xff1f; 在 Redis 官网中有介绍&#xff0c; Redis 就是一个存储空间&#xff0c;只不过这个存储空间是在内存上的&#xff0c;这也就代表存储在 Redis 中的数据访问起来会非常快&#xff0c;但也会有一个弊端&#xff0c;也就是内存资源是非常少的&#xff…...

python打卡训练营打卡记录day30

一、导入官方库 我们复盘下学习python的逻辑&#xff0c;所谓学习python就是学习python常见的基础语法学习你所处理任务需要用到的第三方库。 1.1标准导入&#xff1a;导入整个库 这是最基本也是最常见的导入方式&#xff0c;直接使用import语句。 # 方式1&#xff1a;导入整…...

FART 主动调用组件设计和源码分析

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ 现有脱壳方法存在的问题 脱壳粒度集中在 DexFile 整体&#xff0c;当前对 apk 保护的粒度在函数粒度&#xff0c;这就导致了脱壳与加固的不对等&#xff0c;无…...

windows使用ollama部署deepseek及qwen

ollama 参考文档 ollama 官方文档 GitHub仓库 基础环境&#xff1a; NVIDIA 1660TI 6G 下载 ollma是一款开源工具&#xff0c;支持在本地计算机&#xff08;无需联网&#xff09;快速部署和运行大型语言模型&#xff08;LLM&#xff09;&#xff0c;如 LLaMA、Mistral、G…...

【11408学习记录】考研英语辞职信写作三步法:真题精讲+妙句活用+范文模板

应聘信 英语写作2005年考研英语真题小作文写作思路第一段第二段妙句7 9妙句11补充3补充4 第三段 妙句成文 每日一句词汇第一步&#xff1a;找谓语第二步&#xff1a;断句第三步&#xff1a;简化主句原因状语从句 英语 写作 2005年考研英语真题小作文 Directions:​​ Two m…...

湖北理元理律师事务所:债务优化如何实现“减负不降质”?

债务压力下&#xff0c;如何在保障基本生活品质的同时科学规划还款&#xff0c;是许多债务人面临的现实难题。湖北理元理律师事务所通过多年实务经验&#xff0c;总结出一套“法律财务心理”的复合型解决方案。本文基于公开案例与法律框架&#xff0c;解析其服务逻辑中的可借鉴…...

python fastapi + react, 写一个图片 app

1. 起因&#xff0c; 目的: 上厕所的时候&#xff0c;想用手机查看电脑上的图片&#xff0c;但是又不想点击下载。此app 应运而生。 2. 先看效果 单击图片&#xff0c;能放大图片 3. 过程: 过程很枯燥。有时候&#xff0c; 有一堆新的想法。 但是做起来太麻烦&#xff0c;…...

Golang的Web应用架构设计

# Golang的Web应用架构设计 介绍 是一种快速、高效、可靠的编程语言&#xff0c;它在Web应用开发中越来越受欢迎。Golang的Web应用架构设计通常包括前端、后端和数据库三个部分。在本篇文章中&#xff0c;我们将详细介绍Golang的Web应用架构设计及其组成部分。 前端 在Golang的…...

软件设计师“UML”真题考点分析——求三连

一、考点分值占比与趋势分析 综合知识题分值统计表 年份考题数量分值分值占比考察重点2018222.67%类图关系、序列图消息流2019334.00%对象图特征、部署图辨析2020222.67%组件图特性、泛化关系2021334.00%聚合/组合区别、交互图应用2022222.67%用例图参与者、状态图转换202344…...

Nginx端口telnet不通排查指南

nginx已经配置server及端口20002&#xff0c;telnet不通&#xff1a;telnet 127.0.0.1 20002 Trying 127.0.0.1... telnet: connect to address 127.0.0.1: Connection refused 一、检查 systemctl status nginx.service nginx: [emerg] bind() to 0.0.0.0:20002 failed (13…...

C++ 函数对象、仿函数与 Lambda 表达式详解

C 函数对象、仿函数与 Lambda 表达式详解 在 C 中&#xff0c;函数对象&#xff08;Function Object&#xff09;、仿函数&#xff08;Functor&#xff09; 和 Lambda 表达式 是三种实现可调用行为的技术&#xff0c;它们在功能上类似&#xff0c;但语法和适用场景有所不同。 …...

More Effective C++:改善编程与设计(下)

目录 条款19:了解临时对象的来源 条款20:协助完成“返回值优化” 条款21:利用重载技术避免隐式类型转换 条款22:考虑以操作符复合形式&#xff08;op&#xff09;取代其独身形式&#xff08;op&#xff09; 条款23:考虑使用其他程序库 条款24:了解virtual functions、mul…...

C++:判断闰年

【描述】 判断某年是否是闰年。 【输入】 输入只有一行&#xff0c;包含一个整数a(0 < a < 3000) 【输出】 一行&#xff0c;如果公元a年是闰年输出Y&#xff0c;否则输出N 【样例输入】 2006 【样例输出】 N 【提示】 公历纪年法中&#xff0c;能被4整除的大多是闰年&am…...

C+++STL(一)

/ 文章目录 模版C作为静态类型语言宏可以摆脱数据类型的限制利用宏构建通用函数框架 函数模版函数模版的定义函数模版的使用函数模版的分析实例化函数模版的条件 函数模版扩展二次编译隐式推断类型实参函数模版的重载 bilibili 学习网址&#xff1a;https://www.bilibili.com/…...

C 语言学习笔记(函数2)

内容提要 函数 函数的调用函数的声明函数的嵌套关系函数的递归调用数组做函数参数 函数 函数的调用 调用方式 ①函数语句&#xff1a; test (); //对于无返回值的函数&#xff0c;直接调用 int res max(2,4); //对于有返回值的函数&#xff0c;一般需要在主调函…...

Spring的后置处理器是干什么用的?扩展点又是什么?

Spring 的后置处理器和扩展点是其框架设计的核心机制&#xff0c;它们为开发者提供了灵活的扩展能力&#xff0c;允许在 Bean 的生命周期和容器初始化过程中注入自定义逻辑。 1. 后置处理器&#xff08;Post Processors&#xff09; 后置处理器是 Spring 中用于干预 Bean 生命…...

Java大数据机器学习模型在金融衍生品风险建模中的创新实践

摘要 本文深入探讨Java技术栈在大数据与机器学习领域的独特优势&#xff0c;及其在金融衍生品风险建模中的突破性应用。通过分析分布式计算框架与机器学习库的整合方案&#xff0c;揭示Java在构建复杂金融风险模型时的技术可行性。结合信用违约互换&#xff08;CDS&#xff09…...

leetcode3403. 从盒子中找出字典序最大的字符串 I-medium

1 题目&#xff1a;从盒子中找出字典序最大的字符串 I 官方标定难度&#xff1a; 给你一个字符串 word 和一个整数 numFriends。 Alice 正在为她的 numFriends 位朋友组织一个游戏。游戏分为多个回合&#xff0c;在每一回合中&#xff1a; word 被分割成 numFriends 个 非空…...

Effective C++阅读笔记(item 1-4)

文章目录 理解模板类型推导理解auto类型推导理解decltype学会查看类型推导结果 理解模板类型推导 c的auto特性是建立在模板类型推到的基础上。坏消息是当模板类型推导规则应用于auto环境时&#xff0c;有时不如应用于template时那么直观。我们可能很自然的期望T和传递进函数的…...