CTFd平台集成MCP协议:AI助手赋能CTF赛事智能运维实践

news2026/5/13 23:06:48
1. 项目概述CTFd与MCP的融合实践最近在安全圈和CTFCapture The Flag夺旗赛赛事运维圈子里一个名为AaryaBhusal/ctfd-mcp的项目引起了我的注意。乍一看这像是一个针对CTFd平台的插件或扩展但“MCP”这个缩写背后所代表的意义才是真正让这个项目变得有趣和强大的关键。简单来说这是一个为CTFd平台设计的MCPModel Context Protocol服务器实现。如果你是一位CTF赛事组织者、安全研究爱好者或者对如何用更智能的方式管理、交互和扩展你的CTF平台感兴趣那么这个项目值得你花时间深入了解。CTFd本身是一个功能强大、应用广泛的开源CTF平台用于举办网络安全竞赛。它提供了题目管理、队伍管理、积分榜、动态记分牌等一系列核心功能。然而随着赛事规模的扩大和题目形式的复杂化平台的管理、题目的批量操作、数据的深度分析以及与外部工具的集成往往需要依赖手动操作或编写大量脚本效率上存在瓶颈。而MCP作为一种新兴的、旨在标准化大型语言模型LLM与外部工具和数据源交互的协议为解决这类问题提供了全新的思路。ctfd-mcp项目的核心价值就是为CTFd平台“注入”MCP能力使其能够通过自然语言指令被AI助手如Claude Desktop、Cursor等支持MCP的客户端直接操作和查询。想象一下你不再需要记忆复杂的CTFd后台API路径或者编写繁琐的curl命令。你只需要对你的AI助手说“帮我列出所有未解出的Web类题目”、“给‘Team Alpha’队伍加500分”、“导出一份当前所有队伍的得分明细CSV文件”这些指令就能被自动、准确地执行。这不仅仅是自动化更是将平台管理能力“语义化”和“自然语言化”极大地降低了操作门槛提升了响应速度。接下来我将从设计思路、核心功能实现、实操部署到进阶应用为你完整拆解这个项目。2. 核心架构与设计思路拆解2.1 为什么是MCP协议选型的深层考量在深入代码之前我们必须先理解为什么选择MCP作为集成协议而不是传统的REST API封装、CLI工具或者Webhook。这背后是项目设计者对未来人机交互范式的一种预判和实践。首先MCP的核心优势在于“标准化”和“声明式”。它定义了一套统一的规范用于描述工具Tools、资源Resources和提示词Prompts。对于CTFd这样一个拥有固定数据模型用户、队伍、题目、提交、分数和操作集合增删改查的平台其能力可以非常完美地映射为MCP的“工具”。MCP服务器即ctfd-mcp的作用就是向MCP客户端你的AI助手宣告“我这里提供了以下工具list_challenges列出题目、get_team_score获取队伍分数……”并且清晰地描述每个工具需要什么参数、会返回什么结果。客户端在连接后就能动态地发现并理解这些工具无需为CTFd专门编写插件。其次MCP实现了“一次集成多处使用”。一旦ctfd-mcp服务器运行起来任何兼容MCP的客户端都能连接并使用其功能。无论是Claude Desktop、Cursor还是未来可能出现的其他AI工作台你都不需要为每个客户端单独适配。这解决了工具碎片化的问题将能力集中在服务器端维护。再者从安全运维的角度看MCP提供了一种可控的AI赋能方式。服务器可以精细控制暴露哪些工具比如只暴露查询类工具不暴露修改分数这类高危操作并且所有操作都通过标准的、可审计的协议进行比直接让AI模型生成并执行任意代码或API调用要安全得多。注意MCP协议本身不处理身份认证和授权这部分依赖于底层的传输层如SSH、Stdio over SSH或由CTFd自身的API Token来保障。在设计ctfd-mcp时必须将CTFd Admin API Token的安全管理作为重中之重。2.2 项目整体架构解析ctfd-mcp项目通常采用客户端-服务器架构但这里的“客户端”特指MCP客户端你的AI应用而“服务器”则是本项目。MCP服务器层这是项目的核心通常是一个长期运行的守护进程。它使用Python的mcpSDK或类似实现来创建一个MCP服务器实例。该服务器的生命周期包括初始化读取配置如CTFd实例的URL、Admin API Token。工具注册将CTFd的各种操作封装成一个个MCP Tool并注册到服务器中。例如一个create_challengeTool其输入参数可能包括name,category,description,value,flag等对应CTFd创建题目的API字段。资源声明声明一些只读的“资源”例如challenges://list可以代表当前所有题目的列表视图。AI客户端可以直接“读取”这个资源来获取信息而无需调用工具。协议通信通过Stdio标准输入输出或SSH等MCP支持的传输方式与MCP客户端建立连接并按照MCP协议规范交换JSON-RPC消息。CTFd API适配层这一层负责与真实的CTFd实例进行通信。它封装了CTFd的RESTful API处理HTTP请求的发送、响应解析、错误处理。为了提高健壮性这一层需要实现重试机制、速率限制适配以及详细的错误日志。项目可能会使用requests库并围绕CTFd官方API文档构建一个轻量级的客户端类。配置与安全层如何安全地管理CTFd的访问凭证是关键。理想的做法是通过环境变量或配置文件来传递CTFD_URL和CTFD_API_TOKEN。Token应具有管理员权限但仅限于必要的操作范围。在服务器启动时应验证Token的有效性以及网络连通性。客户端集成示例项目文档通常会提供如何与Claude Desktop等客户端集成的示例。例如在Claude Desktop的配置文件中添加一个指向本地ctfd-mcp服务器进程的配置项。这步操作是将能力“注入”到你日常使用的AI环境中的临门一脚。这个架构的精妙之处在于解耦MCP协议负责通用的、标准化的AI交互CTFd API负责具体的平台操作而ctfd-mcp作为粘合剂将后者“翻译”成前者能理解的语言。3. 核心功能实现与工具拆解一个实用的ctfd-mcp服务器应该实现哪些工具这直接决定了它的能力边界。我们可以从CTFd运维的核心工作流来推导。3.1 题目管理工具集题目是CTF的核心。相关的MCP工具会围绕题目的生命周期展开。list_challenges获取题目列表。这应该是一个最基础、最常用的工具。实现时它会调用CTFd的/api/v1/challenges端点。设计难点在于参数设计是否支持按分类category过滤是否支持按当前登录用户或指定队伍的解题状态已解/未解过滤一个良好的设计应该提供这些过滤参数让AI能执行如“列出所有未解出的Crypto题目”这样的复杂查询。返回结果应结构化便于AI阅读和总结。get_challenge_details获取特定题目的详细信息。输入参数为题目ID或名称。除了返回题目描述、分值、分类外对于管理员可能还需要返回关联的文件File、提示Hints信息甚至是被解出的次数Solves。这个工具是深度分析题目的基础。create_challenge创建新题目。这是管理员的核心操作。参数会非常多且复杂name,category,description,value初始分值,type标准、动态分值,connection_info如需state隐藏/可见以及最重要的flag答案。实现时必须对输入进行严格的验证并处理好CTFd API对字段的特定要求如描述字段的HTML格式。一个高级功能是支持通过上传文件URI或内容自动创建题目附件。update_challenge与delete_challenge更新和删除题目。更新工具需要能够部分更新PATCH语义例如只修改分值或描述。删除工具必须谨慎最好能设计一个确认机制或者仅在MCP服务器配置为“高危模式”时才暴露此工具。calculate_dynamic_score如果赛事使用了动态分值题目此工具可以模拟或计算当前题目的实时分值。它需要调用CTFd的相关接口或根据解出人数本地计算。3.2 队伍与用户管理工具集管理参赛者是另一项繁重任务。list_teams/list_users列出所有队伍或用户。支持按名称搜索、按分数排序、按所属分组如果有过滤。get_team_score/get_user_score获取特定队伍或用户的详细得分情况包括各题目得分、排名、解题时间线。这需要聚合多次API调用。award_score手动为队伍加分或扣分。这是一个高风险操作必须记录详细的操作日志并在工具描述中明确警告。输入应包括队伍标识、分数值、原因备注。ban_user/ban_team禁用用户或队伍。用于处理违规行为。3.3 赛事监控与数据分析工具集这类工具将MCP的分析能力发挥到极致。get_scoreboard获取实时积分榜。可以支持获取前N名或某个分组内的积分榜。get_submission_feed获取最近的提交动态流。用于监控赛事活跃度快速发现可能的异常提交如短时间内大量错误尝试。export_data数据导出工具。这是一个“瑞士军刀”式的工具可以导出题目列表、队伍列表、完整积分榜、提交记录等到CSV或JSON格式。实现时可能需要组合多个API调用并在服务器端进行格式转换和拼接。AI可以执行如“导出一份所有队伍在Web类题目的得分明细”这样的复杂请求。get_statistics获取赛事统计概览如总参赛人数、题目总数、总提交数、解题率最高的题目等。这能为组织者提供一个快速的数据仪表盘。3.4 资源Resources声明示例除了工具MCP的资源Resources提供了一种更直接的“读取”数据的方式。例如可以声明以下资源challenges://summary一个只读资源其内容可以是当前题目分类和数量的简要文本总结。scoreboard://top10一个只读资源直接返回积分榜前十名的HTML或Markdown片段。AI客户端可以直接“读取”Read这些资源的URI来获取信息而无需知道背后调用的是哪个具体工具。这简化了某些常见查询的交互。实操心得在设计和实现工具时工具描述的清晰度至关重要。MCP工具的描述description和参数模式inputSchema是AI理解如何调用它的唯一依据。描述应使用自然、明确的语句说明工具的功能、适用场景和副作用。参数模式应使用JSON Schema精确定义每个参数的类型、是否必需、枚举值如category的可选值、描述和示例。一个模糊的描述会导致AI误用或不敢使用该工具。4. 从零开始部署与配置实战理论讲完我们进入实战环节。假设你已有一个正在运行的CTFd实例例如https://ctfd.example.com并拥有管理员权限和API Token。4.1 环境准备与依赖安装ctfd-mcp项目通常是Python项目。首先需要准备Python环境建议3.8以上。# 1. 克隆项目代码此处以假设的项目仓库为例 git clone https://github.com/AaryaBhusal/ctfd-mcp.git cd ctfd-mcp # 2. 创建并激活虚拟环境推荐 python -m venv venv source venv/bin/activate # Linux/macOS # venv\Scripts\activate # Windows # 3. 安装项目依赖 pip install -r requirements.txt # 典型的依赖可能包括mcp, requests, pydantic, python-dotenv等关键依赖解析mcp这是MCP协议的Python SDK由Anthropic等公司维护是构建服务器的基石。requests用于与CTFd的HTTP API通信。pydantic用于数据验证和设置管理确保从配置文件和工具参数传入的数据格式正确。python-dotenv用于从.env文件加载环境变量安全地管理敏感配置。4.2 配置文件的编写与安全考量项目通常会提供一个配置文件模板如config.example.yaml或.env.example。我们需要创建自己的配置文件。# 复制示例配置文件 cp .env.example .env编辑.env文件填入你的CTFd实例信息# .env 文件内容示例 CTFD_URLhttps://your-ctfd-instance.com CTFD_API_TOKENyour_super_secret_admin_api_token_here # 可选MCP服务器监听的传输方式默认为stdio # MCP_TRANSPORTstdio # 可选日志级别 LOG_LEVELINFO安全警告CTFD_API_TOKEN这是最高权限的钥匙。务必在CTFd后台生成一个仅用于此项目的Token并定期轮换。绝对不要将此Token提交到任何版本控制系统如Git。.env文件必须被添加到.gitignore中。CTFD_URL确保你的CTFd实例配置了HTTPS以保证通信过程中的令牌不被窃听。文件权限确保.env文件的读写权限仅限于当前用户。4.3 启动MCP服务器并进行连接测试配置完成后可以启动MCP服务器。启动方式取决于项目的设计通常是一个Python脚本。# 方式一直接运行主脚本 python src/server.py # 方式二通过安装后的入口点如果项目支持 ctfd-mcp-server如果一切正常服务器会启动并等待在标准输入输出stdio上连接。它不会主动退出而是保持运行状态。接下来我们需要配置一个MCP客户端来连接它。以Claude Desktop为例找到Claude Desktop的配置文件夹。macOS:~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:%APPDATA%\Claude\claude_desktop_config.json编辑claude_desktop_config.json文件在mcpServers部分添加一个新的服务器配置。{ mcpServers: { ctfd: { command: /path/to/your/ctfd-mcp/venv/bin/python, args: [ /path/to/your/ctfd-mcp/src/server.py ], env: { CTFD_URL: https://your-ctfd-instance.com, CTFD_API_TOKEN: your_token_here } } } }配置详解command指定Python解释器的路径强烈建议使用虚拟环境中的Python以确保依赖正确。args指定要运行的服务器脚本路径。env这里可以直接覆盖环境变量。注意将Token明文写在配置文件中仍有风险但比写在代码中好。更安全的方式是让服务器脚本从加密的凭据存储中读取但这增加了复杂度。对于个人或受信环境此方式可接受。保存配置文件并重启Claude Desktop。重启后在Claude的聊天界面你应该能看到新的工具可用。可以尝试输入“请使用ctfd工具列出当前所有的题目分类。”4.4 验证与初步使用如果配置成功Claude会识别出ctfd-mcp提供的工具并能够调用它们。你可以进行一些简单的只读操作来验证“当前积分榜前三名是哪些队伍”“我们有多少道Web类题目”“帮我看看‘Team01’队伍的解题情况。”如果AI能够正确理解并返回从CTFd获取的数据说明部署成功。如果失败请检查Claude Desktop的日志通常可在其设置中找到或通过命令行启动查看。ctfd-mcp服务器的输出日志确保启动时设置了LOG_LEVELDEBUG以获得更详细的信息。网络连通性确保运行Claude Desktop和ctfd-mcp的机器能够访问CTFD_URL。API Token权限确认Token在CTFd后台具有足够的权限通常是管理员权限。5. 高级应用场景与效能提升基础功能跑通后我们可以探索一些更高级的应用场景这些场景能真正体现“AI运维”的威力。5.1 场景一智能赛事监控与告警你可以创建一个组合式的工作流而不仅仅是单次查询。例如结合AI的推理能力和MCP工具实现智能监控。构想让AI助手定期或通过事件触发执行以下任务序列调用get_submission_feed获取最新提交。分析提交记录识别异常模式例如同一IP对同一题目在1分钟内错误提交超过20次可能是在暴力破解。如果发现异常调用get_user_details获取该用户信息。综合判断后建议或直接执行ban_user操作并通过其他渠道如调用发送消息的MCP工具通知管理员。实现提示这需要AI客户端如Claude具备一定的“智能体”Agent能力即能够根据目标自主规划并调用一系列工具。目前这可以通过编写详细的提示词Prompt或使用Claude的“项目”Projects功能来初步实现。ctfd-mcp提供了工具而如何编排这些工具形成智能工作流则取决于上层的AI应用。5.2 场景二动态题目难度与分值调整在CTF中动态调整题目分值以平衡赛事体验是一种高级技巧。你可以利用MCP工具实现半自动化的调整。操作流程管理员发出指令“分析一下当前所有题目的解题情况找出那些解出人数少于3但已开放超过6小时的题目。”AI调用list_challenges和get_challenge_details或一个更强大的get_challenges_with_stats工具获取数据。AI分析数据列出符合条件低解出、长时间的题目。管理员审核列表然后指令“给‘Hard Crypto Puzzle’这道题增加50分基础分并发布一条公告提示题目已降低难度。”AI依次调用update_challenge修改分值和CTFd的公告发布工具如果实现了的话。这个过程将数据分析和决策执行无缝衔接管理员只需做出关键决策繁琐的数据收集和操作由AI代劳。5.3 场景三赛后复盘与报告生成赛事结束后生成一份详尽的复盘报告是组织者的重要工作。ctfd-mcp可以成为数据收集的强大助手。报告生成流程数据收集指令“为本次‘XX杯CTF’生成一份赛事数据报告”。AI会调用一系列工具export_data导出所有队伍、题目、提交的完整数据。get_statistics获取整体统计数据。get_scoreboard获取最终排名。数据分析AI利用其强大的自然语言处理和数据分析能力对导出的数据进行分析。它可以计算各分类题目的平均解题时间、解出率。队伍的实力分布是否有断层。题目的难度曲线是否合理。赛事期间的活跃度变化趋势。报告撰写AI根据分析结果自动生成一份结构化的Markdown或HTML报告包含数据摘要、图表描述虽然MCP工具不直接生成图表但可以描述数据趋势、亮点与不足总结。这极大地简化了赛后工作让组织者能将精力集中在从数据中提炼洞察而非手动整理数据上。5.4 性能优化与稳定性保障当工具被频繁调用时性能成为关键。缓存策略对于get_scoreboard、list_challenges这类读多写少、实时性要求稍低的数据可以在ctfd-mcp服务器端实现简单的内存缓存如使用functools.lru_cache并设置一个合理的过期时间如30秒。这能显著减少对CTFd API的直接调用提升响应速度并减轻CTFd服务器压力。异步处理如果工具涉及复杂的、耗时的操作如导出大量数据并格式转换应考虑使用异步IOasyncio来实现避免阻塞服务器处理其他请求。MCP的Python SDK可能对异步有良好支持。错误处理与重试网络请求可能失败。在CTFd API适配层必须实现健壮的错误处理和指数退避重试机制。同时要将友好的错误信息通过MCP协议返回给客户端让AI能理解发生了什么如“CTFd服务器暂时无法访问”而非晦涩的HTTP错误码。速率限制尊重CTFd API的速率限制。在服务器内部实现一个简单的限流器防止因AI助手的快速连续请求导致CTFd端触发限流。6. 常见问题排查与实战技巧在实际部署和使用中你肯定会遇到各种问题。以下是我在实践中总结的一些常见坑点及其解决方案。6.1 连接与配置问题问题现象可能原因排查步骤与解决方案Claude Desktop无法识别ctfd工具1. MCP服务器配置错误。2. Claude Desktop未正确重启。3. 服务器启动失败。1. 检查claude_desktop_config.json格式特别是路径和参数是否正确。使用绝对路径更可靠。2. 彻底关闭Claude Desktop进程并重启。3. 在终端手动运行服务器命令查看是否有错误输出如Python依赖缺失、导入错误。确保虚拟环境已激活。工具调用后返回“连接错误”或“超时”1.CTFD_URL不可达。2.CTFD_API_TOKEN无效或过期。3. 网络防火墙或代理阻止。1. 在服务器机器上用curl -v CTFD_URL/api/v1/challenges测试连通性。2. 在CTFd后台重新生成API Token并更新配置。3. 检查服务器环境的网络代理设置确保requests库能正确通过代理访问外网如果存在。服务器启动立即退出1. 缺少关键环境变量。2. Python依赖版本冲突。3. 代码存在语法错误。1. 检查.env文件或命令行环境变量是否已正确设置且被读取。在代码开头打印配置进行调试。2. 检查requirements.txt尝试在全新的虚拟环境中安装。3. 运行python -m py_compile src/server.py检查语法。6.2 工具使用与行为异常问题现象可能原因排查步骤与解决方案AI无法正确理解工具参数工具的描述description或输入模式inputSchema定义不清晰。这是开发阶段最常见的问题。仔细检查每个MCP工具函数的文档字符串和用tool装饰器定义的schema。确保参数名称、类型、描述、是否必需、枚举值等都准确无误。可以先用简单的工具测试。调用工具成功但返回结果AI无法解析工具返回的数据结构过于复杂或非结构化。MCP工具应返回结构化的数据如字典、列表最好是简单的JSON序列化对象。避免返回冗长的、未经处理的HTML或包含大量无关文本的字符串。可以在工具内部对CTFd API返回的数据进行清洗、过滤和格式化只提取AI需要的关键信息。执行高危操作如删题没有确认工具设计缺少安全护栏。对于delete_challenge,ban_user等危险操作强烈建议在工具实现中加入二次确认逻辑或者根本不暴露这些工具。一种折中方案是工具返回一个需要管理员手动执行的命令或操作步骤而不是直接执行。安全永远是第一位的。工具执行速度慢1. CTFd API响应慢。2. 工具逻辑复杂或多次调用API。3. 网络延迟高。1. 优化CTFd服务器性能或数据库查询。2. 在工具实现中考虑是否可以通过一次API调用获取更多数据减少请求次数。引入缓存见5.4节。3. 将ctfd-mcp服务器部署在离CTFd实例网络更近的位置。6.3 安全加固建议最小权限原则为ctfd-mcp使用的API Token创建独立的、具有最小必要权限的账号。如果CTFd支持创建一个只有“题目查看”和“积分榜查看”权限的Token用于只读类工具与需要修改权限的Token分开。访问控制如果ctfd-mcp服务器需要暴露在网络上例如通过SSH传输必须配置严格的防火墙规则只允许受信的MCP客户端IP地址访问。审计日志在ctfd-mcp服务器中实现详细的日志记录记录每一个被调用的工具、参数、调用者如果MCP协议能传递身份信息、时间戳和结果。这对于事后追溯和问题排查至关重要。定期更新关注ctfd-mcp项目本身的更新以及其依赖库特别是mcpSDK的更新及时修复可能的安全漏洞。6.4 我的独家实操心得从只读工具开始初次部署时建议先只实现和暴露list_challenges,get_scoreboard,get_submission_feed等只读工具。这样即使配置有误或AI误解指令也不会对生产环境造成破坏。待稳定运行一段时间后再逐步添加写操作工具。善用“资源”Resources对于AI只需要“看”而不需要“操作”的数据优先定义为Resource。这比调用Tool更符合直觉AI可能会更倾向于直接读取一个scoreboard://current资源而不是调用一个get_scoreboard工具。为工具提供丰富的示例在工具的description中可以加入一两个自然语言调用示例。例如在award_score的工具描述里写上“例如‘给队伍“BlueTeam”奖励50分原因是他们在比赛中报告了一个关键漏洞。’” 这能极大地提升AI理解和使用工具的准确性。组合使用创造工作流不要局限于单次工具调用。尝试引导AI将多个工具组合起来完成复杂任务。例如你可以直接对AI说“分析一下本次比赛哪道题目最难解出人数最少并给我这道题目的详细描述和第一个解出它的队伍信息。” AI应该能自动规划出调用list_challenges- 分析数据 - 调用get_challenge_details- 调用get_submission_feed或相关工具找出第一次正确提交的流程。AaryaBhusal/ctfd-mcp这个项目打开了一扇门它展示了如何将成熟的、功能固定的传统软件CTFd与快速发展的、灵活智能的AI能力通过MCP相结合。这种模式不仅适用于CTFd理论上可以适配任何拥有API的Web应用或服务。它的价值在于降低了专业工具的使用门槛将复杂的操作转化为自然的对话让组织者能更专注于策略和创意而非重复的点击和命令输入。如果你正在运营CTF赛事我强烈建议你尝试部署和使用它亲自体验这种“用说话来管理平台”的高效与便捷。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2603786.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

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…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…