Skip to content

Latest commit

 

History

History
174 lines (121 loc) · 6.74 KB

README_ZH.md

File metadata and controls

174 lines (121 loc) · 6.74 KB

🧰 IP 工具箱

VMIP.xyz Banner

PWA Windows-image MacOS-image Linux-image

Website

🇺🇸 English | 🇨🇳 简体中文 | 🇫🇷 Français

👉 在这里体验:https://VMIP.xyz

备注:你可以直接用我已经搭建好的服务,也可以自行搭建。

Deploy with Vercel Deploy with Docker

这是我第一次用 Vue.js 练手的项目。我……只是一个普通的产品经理。

👀 主要功能

  • 🖥️ 看自己的 IP:从多个 IPv4 和 IPv6 来源检测显示本机的 IP
  • 🕵️ 看 IP 信息:显示所有 IP 的相关信息,包括国家、地区、ASN、地理位置等
  • 🚦 可用性检测:检测一些网站的可用性:Google, Github, Youtube, 网易, 百度等
  • 🚥 WebRTC 检测:查看使用 WebRTC 连接时使用的 IP
  • 🛑 DNS 泄露检测:查看 DNS 出口信息,以便查看在 VPN/代理的情况下,是否存在 DNS 泄露隐私的风险
  • 🚀 网速测试:利用边缘网络进行网速测试
  • 🚏 代理规则测试:配合代理软件的规则设置,测试规则设置是否正常
  • 🌐 全球延迟测试:从分布在全球的多个服务器进行延迟测试,了解你与全球网络的连接速度
  • 📡 MTR 测试:从分布在全球的多个服务器进行 MTR 测试,了解你与全球的连接路径
  • 🔦 DNS 解析器:从多个渠道对域名进行 DNS 解析,获取实时的解析结果,可用于污染判断
  • 🌗 暗黑模式:根据系统设置自动切换暗黑/白天模式,也可以手动切换
  • 📱 简约模式:为移动版提供的专门模式,缩短页面长度,快速查看最重要的信息
  • 🔍 查任意 IP 信息:可以通过小工具查询任意 IP 的信息
  • 📲 支持 PWA:可以添加为手机应用以及电脑里的桌面应用,方便使用
  • ⌨️ 支持快捷键:可以随时输入 ? 查看快捷键菜单
  • 🌍 根据可用性检测结果,返回目前是否可以访问全世界网络的提示
  • 🇺🇸 🇨🇳 🇫🇷 支持中文、英文、法文

📕 如何使用

3 种部署方式:

在 Node 环境部署

确保你系统里已经有 Node.js 环境。

克隆代码:

git clone https://github.com/qr4d/MyIP.git

安装:

npm install

编译:

npm run build

运行:

npm start

程序会运行在 18966 端口。

使用 Vercel

点击顶部的部署到 Vercel 按钮,即可完成部署。

使用 Docker

点击顶部的部署到 Docker 按钮,即可完成部署,又或者,直接输入下面的命令:

docker run -d -p 18966:18966 --name myip --restart always qr4d/myip:latest

📚 环境变量

你可以不添加环境变量直接使用,但是如果你想使用一些高级功能,可以添加下面的环境变量:

变量名 是否必须 默认值 说明
PORT 18966 程序运行的端口
BING_MAP_API_KEY "" Bing 地图的 API Key,用于展示 IP 所在地的地图
ALLOWED_DOMAINS "" 允许访问的域名,用逗号分隔,用于防止后端 API 被滥用
IPCHECKING_API_KEY "" VMIP.xyz 的 API Key,用于获取精准的 IP 归属地信息
IPINFO_API_TOKEN "" IPInfo.io 的 API Token,用于通过 IPInfo.io 获取 IP 归属地信息
KEYCDN_USER_AGENT "" 使用 KeyCDN 时的域名,需包含 https 前缀。用于通过 KeyCDN 获取 IP 归属地信息
CLOUDFLARE_API "" Cloudflare 的 API Key,用于通过 Cloudflare 获取 AS 系统的信息
VITE_RECAPTCHA_SITE_KEY "" Google reCAPTCHA 的 Site Key,用于在前端显示 reCAPTCHA 验证
RECAPTCHA_SECRET_KEY "" Google reCAPTCHA 的 Secret Key,用于在后端验证 reCAPTCHA 验证

在 Node 环境里使用环境变量

创建环境变量:

cp .env.example .env

修改 .env 里的内容,比如:

PORT=18966
BING_MAP_API_KEY="YOUR_KEY_HERE"
ALLOWED_DOMAINS="example.com"
IPCHECKING_API="YOUR_KEY_HERE"

然后重新启动后端服务。

在 Vercel 里使用环境变量

请参考 .env.example 里的内容,添加到 Vercel 的环境变量里。

在 Docker 里使用环境变量

你可以在运行 Docker 的时候,添加环境变量,比如:

docker run -d -p 18966:18966 \
  -e BING_MAP_API_KEY="YOUR_KEY_HERE" \
  -e ALLOWED_DOMAINS="example.com" \
  -e IPCHECKING_API="YOUR_TOKEN_HERE" \
  --name myip \
  qr4d/myip:latest

👩🏻‍💻 高级用法

如果你在通过代理上网,可以考虑在你的代理配置里,增加下面的规则(请根据你使用的客户端进行修改),这样就可以实现同时查询真实 IP 和代理后的 IP:

# IP Testing
IP-CIDR,1.0.0.1/32,DIRECT,no-resolve
IP-CIDR6,2606:4700:4700::1111/128,DIRECT,no-resolve
DOMAIN-SUFFIX,ipify.org,Proxy
# Rule Testing
DOMAIN,ptest-1.VMIP.xyz,Proxy1
DOMAIN,ptest-2.VMIP.xyz,Proxy2
DOMAIN,ptest-3.VMIP.xyz,Proxy3
DOMAIN,ptest-4.VMIP.xyz,Proxy4
DOMAIN,ptest-5.VMIP.xyz,Proxy5
DOMAIN,ptest-6.VMIP.xyz,Proxy6
DOMAIN,ptest-7.VMIP.xyz,Proxy7
DOMAIN,ptest-8.VMIP.xyz,Proxy8

😶‍🌫️ 额外说明

在 V2.0 发布的时候,我曾经说:这个程序的 70% 的代码不是我写的,是通过 ChatGPT 写的。大概来回 90 个回合,外加一些细微的手动修改,完成了全部代码。

当然,程序的架构和 UI 还是需要自己进行设计。

随着 V3.0 及后续的代码发布,ChatGPT 帮助我写代码的比例逐渐下降,估计现在在 40% - 50% 之间。相反,在这个过程中,我从完全不会 JavaScript 和 Vue ,与 AI 结对编程后,我现在已经能看懂大部分的 JS 代码了,并且也已经能手撸一些。

感谢 AI ,给了我这样一个失业产品经理快速学习编程的机会。

🌟 Star History

Star History Chart