V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
keelii
V2EX  ›  分享创造

又双叕写了一个 host 管理插件 https://github.com/keelii/awesome-host-manager

  •  1
     
  •   keelii ·
    keelii · 2017-11-07 13:55:15 +08:00 · 1390 次点击
    这是一个创建于 2613 天前的主题,其中的信息可能已经有所发展或是发生改变。

    切 host 对于平常开发来说再正常不过了,可是「切 host 难」的问题一直没解决,因为手动修改 host 文件会有很多(系统 dns、浏览器)缓存问题。经常听到 xx 说「我这是好的呀,你 host 有问题吧...」

    在 windows 下我一直使用 fiddler 来切换 host,很多人可能不知道这个功能。他的实现本质就是实用代理映射来实现 host 切换。这样的欢最大的优点就是 无延迟,秒切 host 这个体验就非常赞,而且是系统级别的,也就是说别的浏览器里面也适用(前提是浏览器代理设置为系统)

    然后由于最近切换到 mac 开发环境,发现 mac 下面的解决方案都不是很完美,或者说不适合我的要求。无外乎以下几种:

    物理修改 host 文件

    像 iHosts, Switchhosts 这类,但据我所知这种方法都有延迟

    抓包工具代理切 host

    比如 mac 下的 Wireshark、Charles,这些工具据说很强大,可是我自己用不惯,而且我是需求也很小,杀鸡焉用牛刀。fiddler for mac 虽然也能跑起来,但是体验太差了,界面卡的要死

    浏览器插件代理切 host

    像 Chrome 下的 Chrome-host-switch、Switch host plus 等,试用了下效果很理想。美中不足的是体验不好,只有标签没有分组,把标签当分组切的人很蛋疼

    简单看了下 switch host plus 的实现方式,再加上自己之前也写过 chrome 插件就决定自己造个轮子。Chrome 插件基于 html、css、javascript 自然很适合前端来做

    最近在看 react 相关的东西,刚好拿来练练手。技术选型基本上都是现成的框架拿来用就行了

    • react & redux 构建整体应用
    • bulma.css 简洁小巧的 CSS 框架
    • localStorage 数据直接写本地存储
    • create react app 构建打包应用

    应用截图

    ahm-640x440

    功能

    • 秒切 host 无延迟 😎
    • 基于 chrome 代理 ❤️
    • 兼容 socket 代理 🤔
    • 简洁好用,无多余功能 👏

    安装

    使用

    Host proxy

    和 host 文件规则一致

    192.168.100.1 your.domain.com your-anther.domain.com
    

    Socket proxy

    新建分组加入以下规则(按自己实际情况修改)

    SOCKS5 127.0.0.1:1080
    SOCKS 127.0.0.1:1080
    

    源代码

    Github(MIT)

    mtmzorro
        2
    mtmzorro  
       2017-11-07 14:06:08 +08:00
    沙发 先支持
    yangxin0
        3
    yangxin0  
       2017-11-07 14:15:23 +08:00
    贵东好闲, 写个脚本能搞定的东西还弄 UI
    ppwangs
        5
    ppwangs  
       2017-11-07 15:07:30 +08:00
    @yangxin0 脚本怎么写。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5864 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 02:01 · PVG 10:01 · LAX 18:01 · JFK 21:01
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.