Gemini cli 源码分析之工具篇-WebFetch工具

Gemini cli 源码分析之工具篇-WebFetch工具

查看完整的Gemini cli 源码分析系列课程 Gemini CLI源码启示录:AI工程师必须掌握的终端开发范式

WebFetch工具深度分析

概述

WebFetch工具 (packages/core/src/tools/web-fetch.ts) 是Gemini CLI项目中的一个核心工具,用于从URL获取和处理网页内容。该工具结合了AI能力和传统网页抓取技术,提供了智能的内容获取和处理功能。

核心架构

主要组件

WebFetchTool(主工具类) ├── WebFetchToolInvocation(工具调用实现) ├── parsePrompt(URL解析函数) └── GroundingMetadata(引用和元数据接口)

继承关系

  • WebFetchTool 继承自 BaseDeclarativeTool<WebFetchToolParams, ToolResult>
  • WebFetchToolInvocation 继承自 BaseToolInvocation<WebFetchToolParams, ToolResult>

核心功能分析

1. URL解析和验证 (parsePrompt)

位置: lines 41-74

exportfunctionparsePrompt(text:string):{ validUrls:string[]; errors:string[];}

功能特点:

  • 从输入文本中提取包含 :// 的tokens
  • 使用 new URL() 验证URL格式
  • 协议白名单:仅支持 http:https:
  • 返回有效URL列表和错误信息

安全考虑:

  • 拒绝非标准协议(如 file:, ftp: 等)
  • 严格的URL格式验证

2. 双重执行策略

主执行路径 (execute)

位置: lines 240-380

执行流程:

  1. 解析输入prompt中的URLs
  2. 检查私有IP地址
  3. 调用Gemini AI的 urlContext 工具
  4. 处理grounding metadata和citations
  5. 格式化输出结果

核心代码:

const response =await geminiClient.generateContent([{ role:'user', parts:[{ text: userPrompt }]}],{ tools:[{ urlContext:{}}]}, signal,DEFAULT_GEMINI_FLASH_MODEL,);
Fallback执行路径 (executeFallback)

位置: lines 121-196

触发条件:

  • 检测到私有IP地址
  • 主执行路径失败
  • URL检索状态异常

功能特点:

  • 直接HTTP请求获取内容
  • GitHub URL特殊处理(blob → raw转换)
  • HTML到文本的智能转换
  • 内容长度限制 (MAX_CONTENT_LENGTH = 100000)

3. GitHub URL处理

特殊转换逻辑:

if(url.includes('github.com')&& url.includes('/blob/')){ url = url .replace('github.com','raw.githubusercontent.com').replace('/blob/','/');}

应用场景:

  • GitHub文件查看页面 → 原始文件内容
  • 便于获取可读的源代码内容

4. 内容处理机制

HTML到文本转换

使用 html-to-text 库:

textContent =convert(rawContent,{ wordwrap:false, selectors:[{ selector:'a', options:{ ignoreHref:true}},{ selector:'img', format:'skip'},],});
内容类型判断
  • text/html: 进行HTML到文本转换
  • 其他类型: 保持原始文本格式

Grounding和Citation系统

Grounding Metadata结构

接口定义 (lines 76-95):

interfaceGroundingChunkWeb{ uri?:string; title?:string;}interfaceGroundingSupportSegment{ startIndex:number; endIndex:number; text?:string;}

Citation插入算法

位置: lines 325-344

算法步骤:

  1. 收集所有grounding支持信息
  2. 生成citation标记 [1], [2]
  3. 按位置倒序插入(避免位置偏移)
  4. 在响应文本末尾添加sources列表

示例输出:

响应内容... [1][2] Sources: [1] 页面标题 (https://example.com) [2] 另一页面 (https://another.com) 

安全机制

1. 私有IP检测

功能: 使用 isPrivateIp() 检查URL是否指向私有网络
处理: 检测到私有IP时自动切换到fallback模式

2. 协议白名单

限制: 仅允许 http:https: 协议
防护: 防止 file://, javascript: 等潜在危险协议

3. 内容大小限制

限制: MAX_CONTENT_LENGTH = 100000 字符
目的: 防止内存溢出和处理超大文件

4. 超时控制

设置: URL_FETCH_TIMEOUT_MS = 10000 (10秒)
应用: 防止长时间阻塞请求

错误处理机制

错误类型定义

enum ToolErrorType {WEB_FETCH_FALLBACK_FAILED,WEB_FETCH_PROCESSING_ERROR,}

错误处理策略

  1. URL解析错误: 返回具体的格式错误信息
  2. 网络请求失败: 提供HTTP状态码和错误描述
  3. 内容处理错误: 捕获并格式化异常信息
  4. Fallback失败: 记录遥测数据并返回错误

遥测集成

Fallback尝试记录:

logWebFetchFallbackAttempt(this.config,newWebFetchFallbackAttemptEvent('private_ip'));

事件类型:

  • 'private_ip': 私有IP触发fallback
  • 'primary_failed': 主执行路径失败

工具配置和验证

参数验证 (validateToolParamValues)

位置: lines 418-436

验证规则:

  1. prompt参数不能为空
  2. 至少包含一个有效URL
  3. 所有URL必须格式正确
  4. 协议必须是http或https

工具描述

用户可见描述:

"Processes content from URL(s), including local and private network addresses (e.g., localhost), embedded in a prompt. Include up to 20 URLs and instructions (e.g., summarize, extract specific data) directly in the 'prompt' parameter." 

支持特性:

  • 最多20个URL
  • 本地和私有网络地址支持
  • 嵌入式指令处理

使用示例

基本用法

{ prompt:"Summarize https://example.com/article and extract key points"}

多URL处理

{ prompt:"Compare the content from https://site1.com and https://site2.com, focusing on their main features"}

GitHub代码分析

{ prompt:"Explain the code in https://github.com/user/repo/blob/main/src/file.js"}

性能优化

1. 内容截断

  • 限制处理内容长度,避免超大文档影响性能
  • 保持响应时间在可接受范围内

2. 智能Fallback

  • 仅在必要时使用fallback机制
  • 减少不必要的双重请求

3. 并行处理能力

  • 支持在单个prompt中处理多个URL
  • Gemini AI模型并行处理能力

技术债务和改进建议

当前限制

  1. 单URL Fallback: Fallback模式目前只处理第一个URL
  2. 内容类型支持: 主要针对HTML和文本,对其他格式支持有限
  3. 缓存机制: 缺少内容缓存,重复请求相同URL会重新获取

建议改进

  1. 多URL Fallback支持:
// 建议改进:支持多URL的fallback处理for(const url of urls){// 处理每个URL}
  1. 内容缓存:
// 建议添加缓存层const cached =await cache.get(url);if(cached)return cached;
  1. 更丰富的内容类型支持:
  • PDF文档处理
  • 结构化数据(JSON、XML)解析
  • 媒体文件元数据提取

总结

WebFetch工具是Gemini CLI中一个设计精良的组件,它成功地将AI能力与传统网页抓取技术结合,提供了:

优势

  • 智能内容处理: 结合Gemini AI的理解能力
  • 健壮的错误处理: 多层次的fallback机制
  • 安全防护: 全面的安全检查和限制
  • 用户友好: 简洁的接口和清晰的错误信息

技术亮点

  • Grounding和Citation系统提供可追溯的信息来源
  • GitHub URL特殊处理增强了开发者体验
  • 私有网络支持扩展了使用场景
  • 灵活的内容处理适应不同数据格式

该工具展现了现代AI工具设计的最佳实践,平衡了功能性、安全性和易用性,为用户提供了可靠的网页内容获取和处理能力。

Read more

什么是Agentic AI?Agentic AI 与传统 AIGC 有什么区别?

什么是Agentic AI?Agentic AI 与传统 AIGC 有什么区别?

什么是 Agentic AI?Agentic AI 与传统 AIGC 有什么区别? 1. 引言 近年来,人工智能(AI)技术飞速发展,其中以生成式 AI(AIGC,Artificial Intelligence Generated Content)和 Agentic AI(智能代理 AI)最为热门。AIGC 通过深度学习模型生成文本、图像、视频等内容,而 Agentic AI 则更进一步,能够自主感知、决策并执行任务。那么,Agentic AI 究竟是什么?它与传统的 AIGC 有何不同?在本文中,我们将深入探讨 Agentic AI 的概念、技术原理、

【优质开源项目】AIGC开源推荐-全球情报监控平台worldmonitor

【优质开源项目】AIGC开源推荐-全球情报监控平台worldmonitor

1.概述 World Monitor 是一个开源的实时情报/监测仪表盘,聚合多类数据源(新闻、地理/卫星、航运/空中、财经、威胁情报等),提供交互式地理视图、AI 摘要、事件聚合与报警,支持 Web / PWA / Tauri 桌面三种运行方式,并可通过变体(WORLD / TECH / FINANCE)切换功能集。 2. 总体技术架构(分层视角) 客户端层(Browser / PWA / Tauri desktop) * • React + TypeScript + Vite 构建。 * • 地图/可视化:deck.gl(WebGL 3D globe)、MapLibre GL、D3

GLM-OCR效果展示:会议纪要手写笔记→结构化待办事项+时间线

GLM-OCR效果展示:会议纪要手写笔记→结构化待办事项+时间线 重要提示:本文所有展示效果基于真实测试,GLM-OCR模型在处理手写文档方面表现出色,但实际效果可能因书写质量、图片清晰度等因素有所差异。 1. 项目概述与核心价值 GLM-OCR 是一个基于先进多模态架构的智能文档识别模型,专门针对复杂文档理解场景设计。与传统OCR只能简单识别文字不同,GLM-OCR能够理解文档的语义结构,将杂乱的手写内容转化为结构化的信息。 为什么这个能力如此重要? 想象一下这样的场景:会议结束后,你的笔记本上满是潦草的手写笔记——待办事项散落在各处,时间点标记混乱,重要事项被随意标注。传统OCR只能给你一堆杂乱无章的文本,而GLM-OCR却能智能地: * 识别并提取所有待办事项 * 自动整理时间线和截止日期 * 区分不同优先级和责任人 * 生成可直接使用的结构化数据 这种从"杂乱手写"到"清晰结构化"的转换能力,正是GLM-OCR的核心价值所在。 2. 效果展示:真实案例对比 2.1 原始手写会议纪要 我们先来看一个真实的会议纪要手写案例。这是一张典型的会议笔记照片

Nano BananaPro生图使用指南:让AI绘画触手可及

Nano BananaPro生图使用指南:让AI绘画触手可及

最近在折腾AI生图的时候,偶然发现了一个让我眼前一亮的工具——Nano BananaPro。说实话,刚开始我也没抱太大期望,毕竟市面上的AI生图工具已经够多了。但用了几天之后,我发现这玩意儿确实有点东西,特别是配合Gemini使用的时候,那种"所想即所得"的感觉真的很爽。 今天就来聊聊这个工具到底怎么用,以及它能帮我们解决哪些实际问题。 一、Nano BananaPro是什么? 简单来说,Nano BananaPro是Google Gemini推出的一个高级图像生成模式。它不是一个独立的应用,而是集成在Gemini生态中的一个功能增强。你可以把它理解为Gemini的"专业绘图模式"——当你需要生成更复杂、更精细的图像时,就该它上场了。 不过,直接在Gemini里手敲提示词其实挺麻烦的,特别是那些需要精确描述的场景。这时候就需要一些辅助工具了,比如Banana Prompt Quicker这个浏览器扩展。它本质上是一个提示词快速插入工具,内置了大量针对Nano BananaPro优化过的提示词模板,覆盖工作、学习、生活等各种场景。 二、如何使用Nano BananaPro生