3.6 KiB
3.6 KiB
| title | created | updated | type | tags | sources | ||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Geo 账号与代理模块 | 2026-05-07 | 2026-05-07 | entity |
|
|
Geo 账号与代理模块
Geo 模块是 2026-05-07 新增的账号、代理 IP 与浏览器 profile 绑定基础设施,服务养号、电商自动化和后续 Agent 操作账号矩阵。它和 netabrowser-runtime 协作:Geo 负责账号/IP/登录态数据,浏览器 daemon 负责真正打开带指纹、代理和持久 profile 的 Chromium。
目录结构
packages/backend/src/modules/geo/
├── config.ts
├── controller/admin/account.ts
├── controller/admin/proxy_ip.ts
├── entity/account.ts
├── entity/proxy_ip.ts
├── provider/proxy/
│ ├── interface.ts
│ ├── local.ts
│ └── tianqi.ts
└── service/
├── account.ts
├── encrypt.ts
└── proxy_ip.ts
前端入口在 packages/frontend/src/modules/geo/,包含 accounts.vue、proxies.vue 和 dashboard.vue。
数据模型
| 表 | Entity | 职责 |
|---|---|---|
geo_account |
entity/account.ts |
平台账号、登录态、sessionName、fingerprintSeed、cookie、绑定 Agent 和绑定 IP |
geo_proxy_ip |
entity/proxy_ip.ts |
本地/第三方代理、协议、区域、城市、出口 IP、套餐、健康状态和账号 1:1 绑定 |
关键约束:
geo_account.sessionName唯一,对应 netabrowser-runtime 的浏览器 profile。geo_account.fingerprintSeed让同一账号每次启动保持稳定指纹,不同账号表现为不同物理设备。geo_proxy_ip.bindAccountId和geo_account.proxyId形成强 1:1 绑定。- 切换 IP 或重置账号会生成新的
sessionName和fingerprintSeed,清空 cookie,并尝试删除旧 profile。
账号流程
GeoAccountService 的主路径:
add()
-> 创建账号
-> 生成 sessionName / fingerprintSeed
-> 可选绑定 proxy
launch()
-> 根据账号和 IP 构造 daemon open 参数
-> 调用 /admin/browser-daemon/open
-> 如果同名 session 已存在则 goto 复用
-> fresh profile 时可注入数据库 cookie
captureCookies()
-> 调用 browser-daemon cookie-list
-> 写入 cookies/cookieCapturedAt/cookieExpiresAt/loginStatus
-> 尝试从 cookie 或 DOM 提取 loginAccount
这些流程说明 Geo 不是简单 CRUD,而是账号状态机、IP 绑定和浏览器 profile 生命周期的协调层。
代理 Provider
provider/proxy/ 当前提供:
local:本地直连模式。tianqi:第三方代理 Provider 骨架。interface.ts:统一 Provider 接口。
GeoProxyIpService 负责把数据库记录转换为浏览器 daemon 可消费的 proxy 信息;SOCKS5 用户名密码的 Chromium 兼容问题由 netabrowser-runtime 的本地 HTTP 桥处理。
前端入口
Geo 前端在 packages/frontend/src/modules/geo/config.ts 注册独立模块入口,当前页面分为:
- 账号页:新增账号、选择平台、绑定 Agent/IP、启动浏览器、抓取 cookie、重置会话、切换 IP。
- 代理页:管理本地/第三方代理、查看状态、绑定关系和健康信息。
- Dashboard:当前为轻量入口,后续可承接账号矩阵概览。