<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
    <channel>
        <title>指南 on LiaoKE</title>
        <link>https://blog.liao-ke.com/tags/%E6%8C%87%E5%8D%97/</link>
        <description>Recent content in 指南 on LiaoKE</description>
        <generator>Hugo -- gohugo.io</generator>
        <language>zh</language>
        <lastBuildDate>Fri, 27 Mar 2026 23:41:23 +0800</lastBuildDate><atom:link href="https://blog.liao-ke.com/tags/%E6%8C%87%E5%8D%97/index.xml" rel="self" type="application/rss+xml" /><item>
            <title>最简单的绕过校园网多设备热点检测方案</title>
            <link>https://blog.liao-ke.com/p/bypass-campus-wifi/</link>
            <pubDate>Mon, 09 Mar 2026 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/bypass-campus-wifi/</guid>
            <description>&lt;h2 id=&#34;前言&#34;&gt;前言&#xA;&lt;/h2&gt;&lt;p&gt;弄到了一个白嫖的校园网账号,但是触发设备连接上限了(电脑只要开热点，wifi就无法访问互联网),我手机电脑无法同时连接,于是便有了接下来这篇教程&lt;/p&gt;&#xA;&lt;h2 id=&#34;原因解析&#34;&gt;原因解析&#xA;&lt;/h2&gt;&lt;ol&gt;&#xA;&lt;li&gt;当电脑连接WIFI的时候,网络适配器中的wlan网卡便是已连接的状态&lt;/li&gt;&#xA;&lt;li&gt;此时我们打开热点,在网络适配器中会自动创建一个新的本地连接的网卡&lt;/li&gt;&#xA;&lt;li&gt;在默认情况下,热点的网卡会自动寻找可以访问互联网的网卡，作为上级网卡.&lt;/li&gt;&#xA;&lt;li&gt;但是由于校园网有检测,当热点网卡的流量转发到wlan时,校园网就会检测到有多个设备，从而断开访问&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;596px&#34; data-flex-grow=&#34;248&#34; height=&#34;1021&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/1.png&#34; srcset=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/1_hu_f6ddd3897d7c4762.png 800w, https://blog.liao-ke.com/p/bypass-campus-wifi/1_hu_7766e7470a6c5736.png 1600w, https://blog.liao-ke.com/p/bypass-campus-wifi/1_hu_c9c8b2088f654b12.png 2400w, https://blog.liao-ke.com/p/bypass-campus-wifi/1.png 2536w&#34; width=&#34;2536&#34;&gt;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h2 id=&#34;解决方法&#34;&gt;解决方法&#xA;&lt;/h2&gt;&lt;ol&gt;&#xA;&lt;li&gt;通过手动设置热点网卡的上级网卡到其他的网卡,然后其他网卡的流量(经过这个网卡，对流量进行处理)再流入wlan,这样便不会被校园网检测.&lt;/li&gt;&#xA;&lt;li&gt;于是我们便要用到clash/singbox这样的代理工具的tun模式创造另外一个网卡(其实也可以用wintun驱动手动创建,不过得手动配置一些东西，比较麻烦)&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;398px&#34; data-flex-grow=&#34;165&#34; height=&#34;1522&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/4.png&#34; srcset=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/4_hu_9c14e63979693ea3.png 800w, https://blog.liao-ke.com/p/bypass-campus-wifi/4_hu_cf267a449f2e693b.png 1600w, https://blog.liao-ke.com/p/bypass-campus-wifi/4_hu_4735dd398f200177.png 2400w, https://blog.liao-ke.com/p/bypass-campus-wifi/4.png 2524w&#34; width=&#34;2524&#34;&gt;&lt;/li&gt;&#xA;&lt;li&gt;不一定需要添加clash的代理配置文件,只要打开tun模式即可.&lt;/li&gt;&#xA;&lt;li&gt;此时网络适配器中将会多出一张其他的网络设备&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;475px&#34; data-flex-grow=&#34;198&#34; height=&#34;1279&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/2.png&#34; srcset=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/2_hu_e7e0e595dbb775f3.png 800w, https://blog.liao-ke.com/p/bypass-campus-wifi/2_hu_b84d6fffccdec549.png 1600w, https://blog.liao-ke.com/p/bypass-campus-wifi/2_hu_24c108a4e474ac75.png 2400w, https://blog.liao-ke.com/p/bypass-campus-wifi/2.png 2536w&#34; width=&#34;2536&#34;&gt;&lt;/li&gt;&#xA;&lt;li&gt;此时右击该网卡属性点击共享，然后设置共享的网络为本地连接(相当手动指定热点的上级网络),便可以实现绕过校园网检测&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;420px&#34; data-flex-grow=&#34;175&#34; height=&#34;1455&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/3.png&#34; srcset=&#34;https://blog.liao-ke.com/p/bypass-campus-wifi/3_hu_a56ff396293e3540.png 800w, https://blog.liao-ke.com/p/bypass-campus-wifi/3_hu_bc91273d69530b0b.png 1600w, https://blog.liao-ke.com/p/bypass-campus-wifi/3_hu_4928c0912892392d.png 2400w, https://blog.liao-ke.com/p/bypass-campus-wifi/3.png 2548w&#34; width=&#34;2548&#34;&gt;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;</description>
        </item><item>
            <title>openwrt25.10设置vlan实现单线复用</title>
            <link>https://blog.liao-ke.com/p/openwrt-vlan/</link>
            <pubDate>Wed, 25 Feb 2026 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/openwrt-vlan/</guid>
            <description>&lt;h2 id=&#34;原理解析&#34;&gt;原理解析&#xA;&lt;/h2&gt;&lt;p&gt;(特别注意:有一些路由器的系统是不支持设置vlanid的,所以建议所有路由器都为openwrt软路由，方便操作.)&lt;/p&gt;&#xA;&lt;p&gt;在传统方案中,当光猫设置&lt;strong&gt;桥接模式&lt;/strong&gt;,软路由负责拨号,此时光猫的其他网口在正常情况下是无法工作的,因为光猫此时只做光电转换，不做路由ip下发.&lt;/p&gt;&#xA;&lt;p&gt;此时我们便需要用到一项技术实现光猫在桥接模式下光猫的其他网口也能正常工作.这便是&lt;strong&gt;vlanid&lt;/strong&gt;.vlanid并不只有&lt;strong&gt;单线复用&lt;/strong&gt;这一个功能,它也可以用来划分局域网,从本质上来讲，它的作用就是给流量打上标记.&lt;/p&gt;&#xA;&lt;p&gt;当光猫桥接主路由拨号时,其他房间网口的流量是流向光猫的网口,在流量没有打&lt;strong&gt;vlanid&lt;/strong&gt;标识的情况下，光猫也不知道要把这些流量弄到哪里去,所以光猫其他网口便无法正常通讯.&lt;/p&gt;&#xA;&lt;p&gt;所以这个时候我们便用&lt;strong&gt;vlanid&lt;/strong&gt;来实现&lt;strong&gt;单线复用&lt;/strong&gt;(&lt;strong&gt;即一条网线，负责实现两个功能,也就是说我们主路由与光猫连接的那根网线既负责主路由的拨号，又负责主路由dhcp服务器下发ip到光猫的其他网口&lt;/strong&gt;),我们在其他网口的房间里的路由器里面设置&lt;strong&gt;vlanid&lt;/strong&gt;,然后在光猫的管理员后台里也设置的&lt;strong&gt;vlanid&lt;/strong&gt;,最后在主路由里面设置一样的&lt;strong&gt;vlanid&lt;/strong&gt;.就这样在三台设备中都设置了&lt;strong&gt;vlanid&lt;/strong&gt;,设备就知道这些流量该如何传输.&lt;/p&gt;&#xA;&lt;h2 id=&#34;具体操作&#34;&gt;具体操作&#xA;&lt;/h2&gt;&lt;ol&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;在房间的子路由中把&lt;strong&gt;wan接口删除&lt;/strong&gt;,只留lan口,然后在设备中添加连接网线的网口的vlan设备,然后把这个设备添加到&lt;strong&gt;br-lan&lt;/strong&gt;的网桥设备集合之中&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;577px&#34; data-flex-grow=&#34;240&#34; height=&#34;991&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/1.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/1_hu_bed4ace6e307d14.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/1_hu_af2ca4f3c1b49335.jpg 1600w, https://blog.liao-ke.com/p/openwrt-vlan/1.jpg 2383w&#34; width=&#34;2383&#34;&gt;&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;442px&#34; data-flex-grow=&#34;184&#34; height=&#34;1236&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/2.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/2_hu_e1ca0916ec0c1173.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/2_hu_54e74809fd24f41e.jpg 1600w, https://blog.liao-ke.com/p/openwrt-vlan/2.jpg 2281w&#34; width=&#34;2281&#34;&gt;&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;在光猫的管理员后台(&lt;strong&gt;不同的型号的光猫进入管理员后台的方法不同，有一些甚至进不去管理员后台，这里就不细讲了&lt;/strong&gt;),把对应连接方式的lan口绑定全部取消,然后设置对应网口的&lt;strong&gt;vlanid和vlan绑定&lt;/strong&gt;&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;299px&#34; data-flex-grow=&#34;124&#34; height=&#34;985&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/3.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/3_hu_94ffdac528760fa7.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/3.jpg 1228w&#34; width=&#34;1228&#34;&gt;&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;293px&#34; data-flex-grow=&#34;122&#34; height=&#34;998&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/4.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/4_hu_9c75919e4e3c7f72.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/4.jpg 1219w&#34; width=&#34;1219&#34;&gt;&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;244px&#34; data-flex-grow=&#34;101&#34; height=&#34;1180&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/5.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/5_hu_f4d7f32e6e3872e3.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/5.jpg 1200w&#34; width=&#34;1200&#34;&gt;&#xA;以上这张图中，网络连接二是用于主路由和光猫拨号的，而网络连接五则是用于设置vlanid来实现单线复用的。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;在主路由进行和子路由中一样的操作,只是这一次不用把wan口删除了,把wan口对应的连接端口设置&lt;strong&gt;vlanid&lt;/strong&gt;,然后也一并添加到&lt;strong&gt;br-lan&lt;/strong&gt;中即可完成配置&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;464px&#34; data-flex-grow=&#34;193&#34; height=&#34;1320&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/6.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/6_hu_8fb1fb10e4e9a234.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/6_hu_4cea7f81684e07f7.jpg 1600w, https://blog.liao-ke.com/p/openwrt-vlan/6_hu_db16147587da4ba1.jpg 2400w, https://blog.liao-ke.com/p/openwrt-vlan/6.jpg 2553w&#34; width=&#34;2553&#34;&gt;&#xA;&lt;img class=&#34;gallery-image&#34; data-flex-basis=&#34;453px&#34; data-flex-grow=&#34;188&#34; height=&#34;1351&#34; loading=&#34;lazy&#34; sizes=&#34;(max-width: 767px) calc(100vw - 30px), (max-width: 1023px) 700px, (max-width: 1279px) 950px, 1232px&#34; src=&#34;https://blog.liao-ke.com/p/openwrt-vlan/7.jpg&#34; srcset=&#34;https://blog.liao-ke.com/p/openwrt-vlan/7_hu_c3f838f7acdbb915.jpg 800w, https://blog.liao-ke.com/p/openwrt-vlan/7_hu_81134c7cf31261b1.jpg 1600w, https://blog.liao-ke.com/p/openwrt-vlan/7_hu_8a45356256eca507.jpg 2400w, https://blog.liao-ke.com/p/openwrt-vlan/7.jpg 2553w&#34; width=&#34;2553&#34;&gt;&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;p&gt;完成了以上三个步骤,就可以实现光猫在&lt;strong&gt;桥接模式&lt;/strong&gt;下，房间的子路由仍然可以接收到主路由下发的ip了&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>2026年软路由系统分析和推荐</title>
            <link>https://blog.liao-ke.com/p/routeros-choose/</link>
            <pubDate>Wed, 18 Feb 2026 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/routeros-choose/</guid>
            <description>&lt;h1 id=&#34;2026年软路由系统分析和推荐&#34;&gt;2026年软路由系统分析和推荐&#xA;&lt;/h1&gt;&lt;p&gt;截止到目前为止,还在持续维护更新的软路由系统有&lt;code&gt;openwrt&lt;/code&gt;系,&lt;code&gt;ikuai&lt;/code&gt;,&lt;code&gt;RouterOS&lt;/code&gt;.&lt;/p&gt;&#xA;&lt;h2 id=&#34;三大系统简述&#34;&gt;三大系统简述&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;ikuai系统&lt;/strong&gt;不开源,可玩性和软件生态上比openwrt和RouterOS差,但是稳定,适用于对稳定性和兼容性要求比较高的工作环境，比如说企业.&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;Routeros系统&lt;/strong&gt;是开源的,基于linux,但是软件生态和可玩性也不如openwrt,Linux内核版本也较低,主打的也是偏稳定向的.&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;openwrt系统&lt;/strong&gt;是开源的,相当于阉割魔改版之后的linux（linux可以干的,openwrt通过补全环境和其他方法，基本都可以干,如docker,php,python等）,且积极更新Linux内核和对应s组件依赖,社区力量和软件包是远远大于另外两个软路由系统的,由于openwrt系统非常轻量，所以适配的硬件特别广.而另外两个软路由系统对硬件的要求多相对较高,而openwrt各种嵌入式设备也可以刷入,很多厂商的硬路由openwrt也会适配.所以对于个人玩家来说,强烈推荐openwrt系.&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;openwrt系分支&#34;&gt;openwrt系分支&#xA;&lt;/h2&gt;&lt;p&gt;而openwrt系又主要分&lt;code&gt;openwrt官方系统&lt;/code&gt;,&lt;code&gt;immortalwrt&lt;/code&gt;,&lt;code&gt;kwrt&lt;/code&gt;,&lt;code&gt;lead&lt;/code&gt;,&lt;code&gt;x-wrt&lt;/code&gt;,&lt;code&gt;istoreos&lt;/code&gt;&lt;/p&gt;&#xA;&lt;h3 id=&#34;openwrt官方系统&#34;&gt;openwrt官方系统:&#xA;&lt;/h3&gt;&lt;p&gt;是所有其他分支的源头，更新速度最快,但是软件包源服务器是在国外，国内用户无法直接更新里面的软件包,而且官方服务器里面的软件包数量很少.&lt;/p&gt;&#xA;&lt;h3 id=&#34;immortalwrt&#34;&gt;immortalwrt:&#xA;&lt;/h3&gt;&lt;p&gt;基于openwrt源代码轻量改动,可以看成openwrt中国特供版,而且极大的丰富了软件包数量,有很多github上面的第三方的软件包，以及把软件包服务器改成了在国内,还有一些其他的优化以及添加了更多的硬件支持,但是每当openwrt新的版本出来,immortalwrt需要过一小段时间才能适配完&lt;/p&gt;&#xA;&lt;h3 id=&#34;kwrt&#34;&gt;kwrt:&#xA;&lt;/h3&gt;&lt;p&gt;基于openwrt,可以看成在openwrt源代码的基础上，自己写了一套代码流程来自定义一些东西,有自己自建的软件仓库,里面软件的数量是openwrt系里面最多的,构建系统镜像的时候还可以提前自定义后台IP地址，宽带账号之类的东西,但是魔改的比较多，特别容易出bug（比如我的r2s固件直接开不了机）,而且这个系统作者的名声在圈内不太好,合并上游系统速度还算及时(immortal需要一点时间)&lt;/p&gt;&#xA;&lt;h3 id=&#34;lede&#34;&gt;lede:&#xA;&lt;/h3&gt;&lt;p&gt;准确来说是lean的lede,最原始的lede是openwrt里面分出来，后面又重新与openwrt合并,而github上面的lede是lean(作者)基于最后的lede源代码的个人维护版本,也就是说基于的openwrt主线版本已经十分老旧了,这个系统的优点是有一些闭源驱动，性能非常强大,但由于已经和新版的openwrt代码相差很大，所以很多软件包已经不兼容了.&lt;/p&gt;&#xA;&lt;h3 id=&#34;x-wrt&#34;&gt;x-wrt:&#xA;&lt;/h3&gt;&lt;p&gt;基于openwrt的主线分支(不是release分支),所以代码更新速度很快,有自己的软件仓库，国内用户可以直连,相对于官方的系统，已经内置集成的一些功能&lt;/p&gt;&#xA;&lt;h3 id=&#34;istoreos&#34;&gt;istoreos:&#xA;&lt;/h3&gt;&lt;p&gt;基于openwrt以前的分支,一般不会基于最新的主线分支，一般会隔一两个大版本,有自己的软件源，国内用户可直接连,主要就是ui和功能改动,openwrt官方系统或其他分支系统也可以安装istoreos的软件包来实现成istoreos的ui和功能.主打的是将路由器和nas结合，里面内置了很多跟nas有关的功能。&lt;/p&gt;&#xA;&lt;h2 id=&#34;结论&#34;&gt;结论&#xA;&lt;/h2&gt;&lt;p&gt;综上所述目前软路由系统，我个人推荐openwrt系,openwrt系里面结合更新速度和软件包数量以及稳定性,lede基于的主线版本太老,istoreos更新上游的速度较慢,kwrt魔改openwrt有点多(不是基于源代码魔改),稳定性较差.x-wrt特色不是很强,所以我个人综合起来更推荐immortalwrt&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>我对几种LLM扩展工具的区别与使用心得</title>
            <link>https://blog.liao-ke.com/p/llm-tool-calls/</link>
            <pubDate>Mon, 02 Feb 2026 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/llm-tool-calls/</guid>
            <description>&lt;h1 id=&#34;关于llm的几种工具扩展方法的区别和见解&#34;&gt;关于LLM的几种工具扩展方法的区别和见解&#xA;&lt;/h1&gt;&lt;p&gt;LLM本身只能当做&lt;strong&gt;聊天对话机器&lt;/strong&gt;,他只可以接收对话，然后返回回答,本身是&lt;strong&gt;不能干任何额外的事情&lt;/strong&gt;.&lt;/p&gt;&#xA;&lt;p&gt;我们使用ai的一些扩展功能，比如联网搜索和其他的工具本质上是让&lt;strong&gt;AI返回指定参数&lt;/strong&gt;,&lt;strong&gt;交由外部工具去完成&lt;/strong&gt;,然后在拿&lt;strong&gt;外部工具执行到的信息作为上下文&lt;/strong&gt;,再返回给AI,&lt;strong&gt;llm只是决策者而并非执行者&lt;/strong&gt;,&lt;strong&gt;工具真正的逻辑执行部分和判断部分需要人为的完成&lt;/strong&gt;.&lt;/p&gt;&#xA;&lt;p&gt;而市面上主流的LLM主要有以下几种方法扩展工具&lt;/p&gt;&#xA;&lt;h2 id=&#34;1tool-calls很少使用&#34;&gt;1.Tool Calls(很少使用)&#xA;&lt;/h2&gt;&lt;p&gt;这个是一些大语言模型本身自带的功能,可以让用户&lt;strong&gt;自定义一段工具介绍&lt;/strong&gt;，然后让LLM在适当的时候&lt;strong&gt;返回工具调用的结构体&lt;/strong&gt;,然后由用户&lt;strong&gt;解析结构体执行程序&lt;/strong&gt;之后，再返回获取到的结果来完善上下文&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点:&lt;/strong&gt;&#xA;LLM和工具的衔接部分&lt;strong&gt;需要自己人为书写&lt;/strong&gt;,比如需要&lt;strong&gt;判断LLM有没有返回工具调用信息&lt;/strong&gt;,如果返回了，要根据返回的信息进行选择调用,&lt;strong&gt;写的工具越复杂&lt;/strong&gt;，衔接部分需要花费的时间就越大,并且不同的模型的Tool Calls返回的信息可能还有所不同，&lt;strong&gt;不同模型的Tool Calls标准不一样，同一个工具需要对不同的模型单独做适配&lt;/strong&gt;,所以并不流行(不过算是最早的给llm扩展工具的方法)&lt;/p&gt;&#xA;&lt;h2 id=&#34;2mcp流行&#34;&gt;2.Mcp(流行)&#xA;&lt;/h2&gt;&lt;p&gt;这是一套&lt;strong&gt;严格的标准&lt;/strong&gt;,不会像Tool Calls一样可能因为模型的问题，返回的结构体有所差异,有&lt;strong&gt;mcp客户端&lt;/strong&gt;,还有&lt;strong&gt;mcp服务器&lt;/strong&gt;,工具的连接方式有&lt;strong&gt;远程&lt;/strong&gt;，也有&lt;strong&gt;本地调用&lt;/strong&gt;,是一套很完善的规则.&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点:&lt;/strong&gt;&#xA;因为&lt;strong&gt;调用流程过于严谨和繁琐&lt;/strong&gt;,所以很容易引起&lt;strong&gt;llm上下文直接爆炸&lt;/strong&gt;,让llm抓不到重点,对话越到后面效果越差。&lt;strong&gt;部署和开发也相对麻烦&lt;/strong&gt;,因为有服务端，客户端，还有一些七七八八.而Tool Calls,可以直接在一个片段代码里面完成开发.&lt;/p&gt;&#xA;&lt;h2 id=&#34;3skills流行&#34;&gt;3.Skills(流行)&#xA;&lt;/h2&gt;&lt;p&gt;这个是最近claude推出,我对他的理解是&lt;strong&gt;最高级别的prompt&lt;/strong&gt;,这个严格来说&lt;strong&gt;并不是一个标准,而是共识&lt;/strong&gt;,更偏向于一个技术理念,&lt;strong&gt;需要IDE自己去实现这个理念（&lt;a class=&#34;link&#34; href=&#34;https://github.com/anthropics/skills&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Claude开源了他们官方skills的实现&lt;/a&gt;）&lt;/strong&gt;,不像mcp和Tool Calls是有一定的标准的,要严格按照官方的标准来。&lt;/p&gt;&#xA;&lt;p&gt;Skills某种程度上来说和Tool Calls有点类似,但是&lt;strong&gt;他不需要写LLM和工具之间的桥接代码&lt;/strong&gt;,并且还可以完成一些prompt才可以做的事，比如说&lt;strong&gt;自定义一下语气和注意事项&lt;/strong&gt;.&lt;/p&gt;&#xA;&lt;p&gt;Tool Calls每写一个工具，我需要自己再写程序去判断LLM返回的工具调用信息，然后再去执行运算(并且还可能因为不同的模型返回的信息有差异而导致兼容性问题),&lt;strong&gt;而放到Skills&lt;/strong&gt;,我只需要&lt;strong&gt;自定义一段话&lt;/strong&gt;,&lt;strong&gt;不需要写具体的代码&lt;/strong&gt;(工具本身是要写代码的，只是&lt;strong&gt;调用不需要写代码&lt;/strong&gt;),比如在特定的时候执行某个文件目录下面的某个代码片段传入某些参数,相当于把&lt;strong&gt;桥接部分交由了程序本身&lt;/strong&gt;(如Vscode和windsurf)去执行,所以说需要程序去适配Skills,&lt;strong&gt;它是共识和理念，而不是一套标准&lt;/strong&gt;.(不过当流行起来的时候，共识理念最终也会成为大家默认的标准)&lt;/p&gt;&#xA;&lt;h2 id=&#34;总结&#34;&gt;总结&#xA;&lt;/h2&gt;&lt;p&gt;总结:以上三种给LLM扩展工具的方式,我个人对未来最看好的是&lt;strong&gt;Skills&lt;/strong&gt;,我认为把这套逻辑和共识再进行优化加强是完全可以比过Tool Calls和mcp。Tool Calls桥接部分比较麻烦,&lt;strong&gt;一切运转都要依靠代码&lt;/strong&gt;,还有&lt;strong&gt;兼容性问题&lt;/strong&gt;;mcp&lt;strong&gt;开发部署繁琐,且容易引起上下文爆炸&lt;/strong&gt;,LLM运行缓慢.Skills&lt;strong&gt;恰好能解决这两者的缺点&lt;/strong&gt;&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>Hugo自动修正文章最后修改时间的最佳方案</title>
            <link>https://blog.liao-ke.com/p/hugo-add-lastmod-to-posts/</link>
            <pubDate>Sun, 25 Jan 2026 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/hugo-add-lastmod-to-posts/</guid>
            <description>&lt;h1 id=&#34;hugo-全自动修正文章修改时间的最佳实践serverless-场景&#34;&gt;Hugo 全自动修正文章修改时间的最佳实践（Serverless 场景）&#xA;&lt;/h1&gt;&lt;p&gt;在使用 Hugo 构建静态博客时，&lt;strong&gt;文章的修改时间（Last Modified Time）&lt;/strong&gt; 是一个非常重要但又容易踩坑的问题，尤其是在 &lt;strong&gt;Serverless / CI 自动部署&lt;/strong&gt; 场景下。&lt;/p&gt;&#xA;&lt;p&gt;Hugo 官方目前提供了多种用于确定文章修改时间的方式：&lt;/p&gt;&#xA;&lt;h2 id=&#34;hugo-支持的修改时间来源&#34;&gt;Hugo 支持的修改时间来源&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;code&gt;:filemodtime&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;&#xA;使用文件本身的最后修改时间作为文章的修改时间。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;code&gt;lastmod&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;&#xA;需要在文章 Front Matter 中手动维护 &lt;code&gt;lastmod&lt;/code&gt; 字段。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;code&gt;:git&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;&#xA;使用 Git 中该文件的&lt;strong&gt;最后一次提交时间&lt;/strong&gt;作为修改时间（依赖 &lt;code&gt;gitinfo&lt;/code&gt;）。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;code&gt;date&lt;/code&gt;&lt;/strong&gt;&lt;br&gt;&#xA;使用文章的发布时间作为修改时间。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;各方案的自动化可行性分析&#34;&gt;各方案的自动化可行性分析&#xA;&lt;/h2&gt;&lt;p&gt;在上述方案中：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;✅ &lt;strong&gt;可自动化&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;code&gt;:filemodtime&lt;/code&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;:git&lt;/code&gt;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;❌ &lt;strong&gt;不适合全自动&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;code&gt;lastmod&lt;/code&gt;（需要人工维护）&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;date&lt;/code&gt;（语义不符）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;filemodtime-在-serverless-场景下的问题&#34;&gt;:filemodtime 在 Serverless 场景下的问题&#xA;&lt;/h2&gt;&lt;p&gt;使用 Hugo 的一个重要原因，正是为了 &lt;strong&gt;方便地将网站部署到 Serverless 平台&lt;/strong&gt;（如 Cloudflare Pages、Vercel、Netlify 等）。&lt;/p&gt;&#xA;&lt;p&gt;然而在 Serverless / CI 场景中：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;每次部署都会重新 &lt;code&gt;git clone&lt;/code&gt; 仓库&lt;/li&gt;&#xA;&lt;li&gt;所有文件的 &lt;strong&gt;文件系统修改时间&lt;/strong&gt; 都会变成「拉取时间」&lt;/li&gt;&#xA;&lt;li&gt;这会导致：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;所有文章的修改时间被错误地更新为“本次部署时间”&lt;/li&gt;&#xA;&lt;li&gt;完全失去文章真实修改时间的意义&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;因此，&lt;strong&gt;&lt;code&gt;:filemodtime&lt;/code&gt; 在默认情况下并不适合 Serverless 场景&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;git-方案的现实问题&#34;&gt;:git 方案的现实问题&#xA;&lt;/h2&gt;&lt;p&gt;理论上，&lt;code&gt;:git&lt;/code&gt; 是最理想的方案：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;修改时间与 Git 提交严格一致&lt;/li&gt;&#xA;&lt;li&gt;完全自动化&lt;/li&gt;&#xA;&lt;li&gt;不依赖文件系统时间戳&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;但在实际使用中：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;即使开启了 &lt;code&gt;enableGitInfo = true&lt;/code&gt;&lt;/li&gt;&#xA;&lt;li&gt;某些情况下 &lt;code&gt;:git&lt;/code&gt; &lt;strong&gt;无法正确生效&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;在 CI / Serverless 环境中尤为明显&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;不确定这是环境限制、Git shallow clone、还是 Hugo 本身的 Bug，但结果是：&lt;strong&gt;该方案在实践中不够稳定&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;最终解决方案修改文件时间戳为git-提交时间--filemodtime&#34;&gt;最终解决方案：修改文件时间戳为Git 提交时间 + :filemodtime&#xA;&lt;/h2&gt;&lt;p&gt;综合以上问题，我最终总结出了一套&lt;strong&gt;最适合 Serverless 管理的全自动方案&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;h3 id=&#34;核心思路&#34;&gt;核心思路&#xA;&lt;/h3&gt;&#xA;    &lt;blockquote&gt;&#xA;        &lt;p&gt;&lt;strong&gt;在 Hugo 构建之前，将文件的修改时间戳“伪装”为 Git 最后提交时间。&lt;/strong&gt;&lt;/p&gt;&#xA;&#xA;    &lt;/blockquote&gt;&#xA;&lt;p&gt;具体流程如下：&lt;/p&gt;&#xA;&lt;ol&gt;&#xA;&lt;li&gt;Hugo 中使用 &lt;code&gt;:filemodtime&lt;/code&gt; 作为文章修改时间来源&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-fallback&#34; data-lang=&#34;fallback&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;[frontmatter]&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;lastmod = [&amp;#39;:fileModTime&amp;#39;]&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;ol start=&#34;2&#34;&gt;&#xA;&lt;li&gt;将脚本放在文件夹根目录&lt;/li&gt;&#xA;&lt;li&gt;将自动执行脚本的命令和正式部署命令合二为一(&lt;strong&gt;这里需要注意的是一般的serverless平台拉取项目只是浅层克隆不会把文件的最后提交信息给拉取过来，所以我们要在最前面要执行完整的拉取命令。&lt;/strong&gt;)&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-fallback&#34; data-lang=&#34;fallback&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;git fetch --unshallow &amp;amp;&amp;amp; chmod +x 1.sh &amp;amp;&amp;amp; ./1.sh &amp;amp;&amp;amp; hugo&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;p&gt;这样就可以做到：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;✅ 修改时间与 Git 提交时间一致&lt;/li&gt;&#xA;&lt;li&gt;✅ 完全自动化&lt;/li&gt;&#xA;&lt;li&gt;✅ 与 Serverless / CI 环境完美兼容&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;自动同步-git-提交时间到文件修改时间的脚本&#34;&gt;自动同步 Git 提交时间到文件修改时间的脚本&#xA;&lt;/h2&gt;&lt;p&gt;下面的脚本用于：&lt;/p&gt;&#xA;&#xA;    &lt;blockquote&gt;&#xA;        &lt;p&gt;&lt;strong&gt;将当前目录下所有文件的最后修改时间，统一修改为对应的 Git 最后提交时间&lt;/strong&gt;&lt;/p&gt;&#xA;&#xA;    &lt;/blockquote&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt; 1&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 2&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 3&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 4&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 5&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 6&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 7&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 8&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 9&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;10&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;11&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;12&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;13&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;14&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;15&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;16&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;17&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;18&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;19&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;20&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;21&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;22&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;23&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;24&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;25&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;26&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;27&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;# （此处放置你的脚本内容）&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;#!/bin/bash&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;# git-set-filetime.sh&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;# 功能：将 git 仓库中所有被追踪文件的修改时间改为最后一次提交时间&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;# 确保当前目录是 git 仓库&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;[&lt;/span&gt; ! -d &lt;span class=&#34;s2&#34;&gt;&amp;#34;.git&amp;#34;&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;]&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;then&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;nb&#34;&gt;echo&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;Error: 当前目录不是 git 仓库根目录&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;nb&#34;&gt;exit&lt;/span&gt; &lt;span class=&#34;m&#34;&gt;1&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;fi&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;c1&#34;&gt;# 获取所有被追踪文件（包含特殊字符/空格/中文）&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;git ls-files -z &lt;span class=&#34;p&#34;&gt;|&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;while&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;IFS&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nb&#34;&gt;read&lt;/span&gt; -r -d &lt;span class=&#34;s1&#34;&gt;&amp;#39;&amp;#39;&lt;/span&gt; file&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;do&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;c1&#34;&gt;# 获取最后一次提交的 Unix 时间戳&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;nv&#34;&gt;timestamp&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;$(&lt;/span&gt;git log -1 --format&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;%ct&amp;#34;&lt;/span&gt; -- &lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$file&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;[&lt;/span&gt; -n &lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$timestamp&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;]&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;then&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;c1&#34;&gt;# 使用 touch 修改文件修改时间&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;c1&#34;&gt;# -d &amp;#34;@$timestamp&amp;#34; 表示从 Unix 时间戳设置时间&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        touch -d &lt;span class=&#34;s2&#34;&gt;&amp;#34;@&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$timestamp&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$file&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nb&#34;&gt;echo&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;Updated: &lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$file&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt; -&amp;gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;$(&lt;/span&gt;date -d &lt;span class=&#34;s2&#34;&gt;&amp;#34;@&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$timestamp&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt; &lt;span class=&#34;s1&#34;&gt;&amp;#39;+%Y-%m-%d %H:%M:%S&amp;#39;&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;)&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;k&#34;&gt;else&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nb&#34;&gt;echo&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;Skipped (not tracked): &lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$file&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;k&#34;&gt;fi&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;done&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;echo&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;All tracked files&amp;#39; modification times updated.&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;</description>
        </item><item>
            <title>Android Root 的演进与抉择</title>
            <link>https://blog.liao-ke.com/p/android-root/</link>
            <pubDate>Tue, 09 Dec 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/android-root/</guid>
            <description>&lt;h1 id=&#34;android-root-发展历程和方案分析&#34;&gt;Android Root 发展历程和方案分析&#xA;&lt;/h1&gt;&lt;p&gt;Android Root 顾名思义即给安卓系统获取根权限，让用户拥有系统级权限，极大提升系统可玩性。&lt;br&gt;&#xA;一般来说，Root 需要先解锁 bootloader（BL），解锁的目的，是让用户有权限刷写各个分区，从而能：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;更换系统（system / vendor / product 等）&lt;/li&gt;&#xA;&lt;li&gt;更换内核（boot ）&lt;/li&gt;&#xA;&lt;li&gt;注入 Root / 模块方案&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;注意：解锁 BL ≠ 必然 Root&lt;/strong&gt;，也可以只刷机不 Root。&lt;br&gt;&#xA;主流 Root 方案按时间大致可以排成这样：&lt;/p&gt;&#xA;&#xA;    &lt;blockquote&gt;&#xA;        &lt;p&gt;&lt;strong&gt;KingRoot → SuperSU → Magisk → SKRoot（小众） → KernelSU → APatch&lt;/strong&gt;&lt;/p&gt;&#xA;&#xA;    &lt;/blockquote&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;一root-实现思路按技术路线分类&#34;&gt;一、Root 实现思路：按技术路线分类&#xA;&lt;/h2&gt;&lt;h3 id=&#34;用户态-rootuser-space-root&#34;&gt;用户态 Root（User-space Root）&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;不直接修改内核代码&lt;/li&gt;&#xA;&lt;li&gt;修改 &lt;strong&gt;boot.img → ramdisk → init 脚本&lt;/strong&gt;，在早期启动阶段插入自己的用户态 root 程序&lt;/li&gt;&#xA;&lt;li&gt;通过 &lt;strong&gt;用户态守护进程&lt;/strong&gt; 管理权限（例如 &lt;code&gt;magiskd&lt;/code&gt;）&lt;/li&gt;&#xA;&lt;li&gt;一般依赖一个 &lt;strong&gt;管理 App&lt;/strong&gt; 配合使用（授权弹窗、模块管理等）&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;代表方案：Magisk&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;优点&lt;/strong&gt;：对内核无强依赖，兼容面最广&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;缺点&lt;/strong&gt;：本质不在内核，某些内核安全策略/厂商定制下会有局限&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;内核态-rootkernel-space-root&#34;&gt;内核态 Root（Kernel-space Root）&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;直接在内核中 &lt;strong&gt;Hook 权限相关函数 / LSM / syscall&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;在内核层修改 &lt;code&gt;cred&lt;/code&gt;、&lt;code&gt;capabilities&lt;/code&gt; 等结构，获得最高权限&lt;/li&gt;&#xA;&lt;li&gt;部分方案需要内核源码（早期 KernelSU），部分不需要（APatch、SKRoot）&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;代表方案：KernelSU、APatch、SKRoot&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;优点&lt;/strong&gt;：权限层级最高，可做更“隐蔽”和细粒度的控制&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;缺点&lt;/strong&gt;：与内核版本/厂商定制强相关，适配成本较高&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;漏洞-rootexploit-based-root&#34;&gt;漏洞 Root（Exploit-based Root）&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;利用系统或内核漏洞临时/半永久获取 Root&lt;/li&gt;&#xA;&lt;li&gt;通常依赖特定 Android / 内核版本，系统一更新就失效&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;代表方案：KingRoot 等一键 Root 工具&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;优点&lt;/strong&gt;：用户体验简单，历史上对锁 BL 的机器也有机会&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;缺点&lt;/strong&gt;：完全吃漏洞红利，维护性差，安全风险高&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;二按时间线看典型方案&#34;&gt;二、按时间线看典型方案&#xA;&lt;/h2&gt;&lt;h3 id=&#34;kingroot漏洞驱动的早期-root&#34;&gt;KingRoot：漏洞驱动的早期 Root&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;主要活跃在 &lt;strong&gt;Android 4.4 ~ 6.0&lt;/strong&gt; 时代&lt;/li&gt;&#xA;&lt;li&gt;通过 &lt;strong&gt;内核 / 系统漏洞&lt;/strong&gt;（如提权漏洞）获得 Root&lt;/li&gt;&#xA;&lt;li&gt;多为 &lt;strong&gt;临时或半永久 Root&lt;/strong&gt;，重启或 OTA 后经常失效&lt;/li&gt;&#xA;&lt;li&gt;随着漏洞不断被修复，这类方案很快被淘汰&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;定位&lt;/strong&gt;：&lt;br&gt;&#xA;完全基于漏洞的时代产物，如今更多是历史意义。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;supersusystem-分区注入-su-的经典方案&#34;&gt;SuperSU：system 分区注入 su 的经典方案&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;思路：直接修改 &lt;code&gt;system.img&lt;/code&gt;，在 &lt;code&gt;/system/bin&lt;/code&gt; 或 &lt;code&gt;/system/xbin&lt;/code&gt; 注入 &lt;code&gt;su&lt;/code&gt; 二进制&lt;/li&gt;&#xA;&lt;li&gt;通过 &lt;code&gt;su&lt;/code&gt; 的 setuid 机制实现提权&lt;/li&gt;&#xA;&lt;li&gt;典型适用 &lt;strong&gt;Android 4.x ~ 6.x&lt;/strong&gt;，system 还比较“好改”的时代&lt;/li&gt;&#xA;&lt;li&gt;随着：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;system 分区逐渐只读 / 受更严格完整性保护&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;Magisk 引入 systemless Root&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;SuperSU 很快失去优势。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;定位&lt;/strong&gt;：&lt;br&gt;&#xA;传统“改 system.img 注入 su”的代表&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;magisk用户态-systemless-root-的时代&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/topjohnwu/Magisk&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Magisk&lt;/a&gt;：用户态 systemless Root 的时代&#xA;&lt;/h3&gt;&lt;p&gt;Magisk 把 Root 方式拉到了一个新高度。&lt;/p&gt;&#xA;&lt;h4 id=&#34;核心实现&#34;&gt;核心实现&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;修改 &lt;strong&gt;boot.img → ramdisk → init&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;用 &lt;code&gt;magiskinit&lt;/code&gt; 接管早期启动，作为“第一个用户态进程”&lt;/li&gt;&#xA;&lt;li&gt;启动 root 守护进程 &lt;code&gt;magiskd&lt;/code&gt;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;/system/bin/su&lt;/code&gt; 在 Magisk 中 &lt;strong&gt;只是前端/中转&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;解析参数 → 连接 &lt;code&gt;magiskd&lt;/code&gt; → 由 &lt;code&gt;magiskd&lt;/code&gt; 以 root fork/exec 真正的命令&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;提权的决策和执行&lt;/strong&gt;在 &lt;code&gt;magiskd&lt;/code&gt; 中完成，而不是在 &lt;code&gt;su&lt;/code&gt; 本身&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;不在 system 分区直接写入文件，做到 &lt;strong&gt;systemless&lt;/strong&gt;&lt;br&gt;&#xA;（实际上是用挂载/覆盖的方式“虚拟出”修改过的系统视图）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;关键特点&#34;&gt;关键特点&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;首创 magic mount 模块系统&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;在不实际修改系统文件的情况下，实现对 &lt;code&gt;/system&lt;/code&gt;、&lt;code&gt;/vendor&lt;/code&gt; 等目录的文件覆盖&lt;/li&gt;&#xA;&lt;li&gt;极大提升“玩机模块生态”&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;强兼容性&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;只要能改 boot.img中的init脚本，大多数内核版本都能使用&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;依赖管理 App&lt;/strong&gt;（Magisk App）：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;管理模块、处理 su 授权弹窗、升级/卸载&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;局限&#34;&gt;局限&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;纯用户态方案，需要搭配app&lt;/li&gt;&#xA;&lt;li&gt;模块生态与内核态模块（如 APatch 的 KPM ）相比，在&lt;strong&gt;内核能力利用上&lt;/strong&gt;略逊一筹&lt;/li&gt;&#xA;&lt;li&gt;不支持kernelsu后来的模块webui功能,需要额外安装app解决&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;skroot早期内核-root--su-环境注入的探索者&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/abcz316/SKRoot-linuxKernelRoot&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;SKRoot&lt;/a&gt;：早期“内核 Root + su 环境注入”的探索者&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;时间上早于目前主流内核 Root（KernelSU / APatch）&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;无需内核源码&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;离线分析目标内核镜像（ELF/镜像格式）&lt;/li&gt;&#xA;&lt;li&gt;找到如 &lt;code&gt;do_execve&lt;/code&gt; 等关键函数与 &lt;code&gt;task_struct/cred/seccomp&lt;/code&gt; 的偏移&lt;/li&gt;&#xA;&lt;li&gt;插入自定义 shellcode 实现内核级提权&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;号称“&lt;strong&gt;隐藏性很强&lt;/strong&gt;”：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;没有模块系统&lt;/li&gt;&#xA;&lt;li&gt;常见用法是：针对&lt;strong&gt;单个或少数进程&lt;/strong&gt;注入 su 环境&lt;/li&gt;&#xA;&lt;li&gt;通过 PATH / so 寄生等方式，让特定 APP 获得 su，而不是全局暴露&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;适配范围：&lt;strong&gt;大致 3.10 ~ 6.6 内核&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;优点&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;不依赖内核源码，适配范围相对广&lt;/li&gt;&#xA;&lt;li&gt;su 环境可以“定向注入”，对其他进程很隐蔽&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;没有完整的模块系统，操作较繁琐&lt;/li&gt;&#xA;&lt;li&gt;生态小众，文档和社区支持相对较弱&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;kernelsu主流内核态-root--overlayfs-模块&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/tiann/KernelSU&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;KernelSU&lt;/a&gt;：主流内核态 Root + overlayfs 模块&#xA;&lt;/h3&gt;&lt;h4 id=&#34;基本定位&#34;&gt;基本定位&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;代表性的 &lt;strong&gt;内核态 Root&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;在内核中安装 hook（LSM / cred 修改等）&lt;/li&gt;&#xA;&lt;li&gt;在执行 &lt;code&gt;/system/bin/su&lt;/code&gt; 时，内核直接修改进程 cred 实现提权&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;code&gt;/system/bin/su&lt;/code&gt; 在 KernelSU 中是真正的 &lt;strong&gt;提权入口&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;它触发内核 hook&lt;/li&gt;&#xA;&lt;li&gt;提权是在内核里完成的，而不是转发给某个守护进程（区别于 Magisk）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;技术路径演进&#34;&gt;技术路径演进&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;早期：通过 &lt;strong&gt;谷歌GKI 内核（已被官方淘汰） / 内核源码集成（已被官方淘汰）&lt;/strong&gt; 集成 KernelSU&lt;/li&gt;&#xA;&lt;li&gt;现在主流：&lt;strong&gt;LKM（ko 模块）方式&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;把修改封装成内核模块加载进 GKI 内核&lt;/li&gt;&#xA;&lt;li&gt;同一大版本Gki内核编译出来的ko模块具有一定通用性,所以安装体验上不需要内核源代码&lt;/li&gt;&#xA;&lt;li&gt;但 &lt;strong&gt;ko 的编译仍依赖内核的源码&lt;/strong&gt;，只是这部分由项目方/维护者完成&lt;/li&gt;&#xA;&lt;li&gt;对用户体验来说“不需要自己改源码”&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;模块系统元模块支持overlyfsmagic-mount或者自定义挂载方式&#34;&gt;模块系统：元模块（支持overlyfs/magic mount或者自定义挂载方式）&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;默认使用 &lt;strong&gt;overlayfs&lt;/strong&gt; 实现模块系统(首创)：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;支持对 &lt;code&gt;/system&lt;/code&gt; 等只读分区做“上层覆盖”(模块安装后通常需要 &lt;strong&gt;重启才能生效对/system的修改&lt;/strong&gt;)&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;对比 Magisk 的 magic mount：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;overlayfs 是内核特性，语义更标准&lt;/li&gt;&#xA;&lt;li&gt;但实时性稍差，多数变更需要重启&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;特点与限制&#34;&gt;特点与限制&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ol&gt;&#xA;&lt;li&gt;内核态 su：安全模型清晰，可做细粒度 App profile（按 UID/GID 控制权限大小）&lt;/li&gt;&#xA;&lt;li&gt;官方overlayfs 模块系统：结构正规，可与 GKI 思路统一&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;限制&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;对低版本 / 非 GKI 内核兼容性差&lt;/li&gt;&#xA;&lt;li&gt;一些魔改了内核且不开源的gki设备对谷歌官方gki内核支持差,刷了可能开不了机&lt;/li&gt;&#xA;&lt;li&gt;官方更推荐搭配 &lt;strong&gt;5.10以上的 GKI 内核搭配ko模块使用&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h3 id=&#34;apatch无需源码的-kpimg-内核-root--kpm-模块&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/bmax121/APatch&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;APatch&lt;/a&gt;：无需源码的 kpimg 内核 Root + KPM 模块&#xA;&lt;/h3&gt;&lt;p&gt;在内核 Root 方案中，APatch 的技术路线是目前&lt;strong&gt;最“工程化 + 通用”的一类&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;h4 id=&#34;核心实现方式&#34;&gt;核心实现方式&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;仍然是 &lt;strong&gt;内核态 Root&lt;/strong&gt;，但：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;不需要内核源码&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;使用 KernelPatch 工具链解析并 patch 目标内核镜像&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;通过在内核镜像中注入 &lt;strong&gt;&lt;code&gt;kpimg&lt;/code&gt;&lt;/strong&gt;：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;修改内核启动入口 / early init 流程&lt;/li&gt;&#xA;&lt;li&gt;把自定义 hook 注入到内核的启动过程&lt;/li&gt;&#xA;&lt;li&gt;重启后，&lt;code&gt;kpimg&lt;/code&gt; 会在早期阶段接管部分逻辑，实现：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;Root 提权&lt;/li&gt;&#xA;&lt;li&gt;内核 hook（supercall / inline hook）&lt;/li&gt;&#xA;&lt;li&gt;启动用户态守护/事件（&lt;a class=&#34;link&#34; href=&#34;cci:7://file:///c:/Users/Administrator/Documents/github/APatch/apd:0:0-0:0&#34; &gt;apd&lt;/a&gt; 等）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;兼容性&#34;&gt;兼容性&#xA;&lt;/h4&gt;&lt;ul&gt;&#xA;&lt;li&gt;内核版本范围广：&lt;strong&gt;3.18 ~ 6.12&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;不依赖 GKI，不要求厂商公开内核源码&lt;/li&gt;&#xA;&lt;li&gt;对各家定制内核更友好（因为是直接对内核二进制镜像做符号分析与 patch）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h4 id=&#34;特点&#34;&gt;特点&#xA;&lt;/h4&gt;&lt;ol&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;KPM 内核模块&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;在已经被 kpimg 接管的内核里，动态加载 KPM 模块&lt;/li&gt;&#xA;&lt;li&gt;支持对内核函数进行 hook，部分 hook 即时生效&lt;/li&gt;&#xA;&lt;li&gt;无&lt;code&gt;/system/bin/su&lt;/code&gt;文件，通过监听拦截&lt;code&gt;/system/bin/su&lt;/code&gt;或&lt;code&gt;su&lt;/code&gt;指令来实现提权&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;模块系统 + Lua 脚本&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;用户态 &lt;a class=&#34;link&#34; href=&#34;cci:7://file:///c:/Users/Administrator/Documents/github/APatch/apd:0:0-0:0&#34; &gt;apd&lt;/a&gt; 管理模块目录、事件（post-fs-data / boot-completed 等）&lt;/li&gt;&#xA;&lt;li&gt;最新版本中可以用 &lt;strong&gt;Lua&lt;/strong&gt; 替代传统 shell 脚本，增强复杂逻辑可维护性&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;不依赖内核源码的工程化链路&lt;/strong&gt;：&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;用 &lt;a class=&#34;link&#34; href=&#34;cci:7://file:///c:/Users/Administrator/Documents/github/APatch/1/KernelPatch/tools/kallsym.c:0:0-0:0&#34; &gt;tools/kallsym.c&lt;/a&gt;、&lt;a class=&#34;link&#34; href=&#34;cci:7://file:///c:/Users/Administrator/Documents/github/APatch/1/KernelPatch/tools/patch.c:0:0-0:0&#34; &gt;tools/patch.c&lt;/a&gt; 等做符号解析、patch&lt;/li&gt;&#xA;&lt;li&gt;用 &lt;a class=&#34;link&#34; href=&#34;cci:7://file:///c:/Users/Administrator/Documents/github/APatch/1/KernelPatch/kernel/patch/android/user_init.sh:0:0-0:0&#34; &gt;kernel/patch/android/user_init.sh&lt;/a&gt; 等把 apd 接到系统启动阶段&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;支持kernelsu的元模块挂载方案(2026.1.12补)&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;三综合对比与结论&#34;&gt;三、综合对比与结论&#xA;&lt;/h2&gt;&lt;h3 id=&#34;技术路线对比简表&#34;&gt;技术路线对比（简表）&#xA;&lt;/h3&gt;&lt;table&gt;&#xA;&#x9;&lt;thead&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;方案&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;类型&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;是否改内核代码&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;是否需源码&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;是否依赖 App&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;su 角色&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;th&gt;模块系统&lt;/th&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&lt;/thead&gt;&#xA;&#x9;&lt;tbody&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;KingRoot&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;漏洞 Root&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;需要&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;各家自定义&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;无 / 简单补丁&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;SuperSU&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;system 注入 su&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;可选&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;传统 setuid su&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;无&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;Magisk&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;用户态 Root&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;间接（不改内核）&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;强依赖&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;&lt;code&gt;/system/bin/su&lt;/code&gt;中转到 &lt;code&gt;magiskd&lt;/code&gt;&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;magic mount&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;SKRoot&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;内核 Root&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;是（patch 镜像）&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;有工具/库&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;隐藏 su + 进程定向注入&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;无完整模块系统&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;KernelSU&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;内核 Root&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;是（源码/GKI/LKM）&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;技术层面上需要&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;App 非必须&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;&lt;code&gt;/system/bin/su&lt;/code&gt; 触发内核提权&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;元模块&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&#x9;&#x9;&lt;tr&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;APatch&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;内核 Root&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;是（kpimg patch）&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;否&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;App 非必须&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;内核 hook su/execve 等&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&#x9;&#x9;&lt;td&gt;APM/KPM + Lua&lt;/td&gt;&#xA;&#x9;&#x9;&#x9;&lt;/tr&gt;&#xA;&#x9;&lt;/tbody&gt;&#xA;&lt;/table&gt;&#xA;&lt;h3 id=&#34;目前最主流的三款root方案分析&#34;&gt;目前最主流的三款root方案分析&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;Magisk&lt;/strong&gt;：&lt;br&gt;&#xA;适合追求 &lt;strong&gt;广泛兼容 + 成熟模块生态&lt;/strong&gt; 的用户，一般设备能解锁 boot.img 就能用。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;KernelSU&lt;/strong&gt;：&lt;br&gt;&#xA;适合有 &lt;strong&gt;GKI 内核&lt;/strong&gt;，且希望在内核层面细控 Root 权限（App profile）的人，&lt;br&gt;&#xA;更偏“官方化”的内核模块方案，但对旧机型支持有限&#xA;可以自定义挂载&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;APatch&lt;/strong&gt;：&lt;br&gt;&#xA;从技术理念上最“硬核”，不依赖源码、支持广泛内核版本，&lt;br&gt;&#xA;内核模块 hook + Lua 模块系统，对研究者 / 高级玩家非常友好。&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;</description>
        </item><item>
            <title>如何选择最适合你的 AI IDE 与扩展插件</title>
            <link>https://blog.liao-ke.com/p/ai-ide/</link>
            <pubDate>Mon, 08 Dec 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/ai-ide/</guid>
            <description>&lt;h1 id=&#34;ai-ide-工具推荐&#34;&gt;AI IDE 工具推荐&#xA;&lt;/h1&gt;&lt;h2 id=&#34;为什么使用-ai-ide&#34;&gt;为什么使用 AI IDE？&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;传统 AI 聊天无法：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;实时读取本地文件&lt;/li&gt;&#xA;&lt;li&gt;兼顾项目的宏观框架管理&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;偏商业化的 AI IDE：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;一般不允许自定义第三方服务商接口&lt;/li&gt;&#xA;&lt;li&gt;强制使用平台模型收取订阅费&lt;/li&gt;&#xA;&lt;li&gt;实时读取本地文件&lt;/li&gt;&#xA;&lt;li&gt;适配开发的执行流程与逻辑&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;因此，为了高效开发和项目管理，需要使用 AI IDE。&lt;/p&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;ai-ide-的能力评价指标&#34;&gt;AI IDE 的能力评价指标&#xA;&lt;/h2&gt;&lt;ol&gt;&#xA;&lt;li&gt;&lt;strong&gt;硬实力：自带模型能力&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;软实力：上下文补全与逻辑能力&lt;/strong&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;通过插件、执行策略、隐藏的上下文prompt 等实现&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;两者缺一不可&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;ai-编程工具分类&#34;&gt;AI 编程工具分类&#xA;&lt;/h2&gt;&lt;h3 id=&#34;1-cli-命令行ai开发工具&#34;&gt;1. CLI 命令行AI开发工具&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;开发效率比 IDE 差&#xA;&lt;ul&gt;&#xA;&lt;li&gt;文件引用需手动输入&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;不适合宏观项目管理&lt;/li&gt;&#xA;&lt;li&gt;适合单一功能的改进&lt;/li&gt;&#xA;&lt;li&gt;代表工具：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://openai.com/blog/openai-codex&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;OpenAI Codex★★★&lt;/a&gt;(也有vscode 插件版本,但开发效率不如集成式ai ide,仍然是片段式更改)&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://claude.com/product/claude-code&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Claude Code★★★&lt;/a&gt;(也有vscode 插件版本,但开发效率不如集成式ai ide,仍然是片段式更改)&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/sst/opencode&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;OpenCode（开源）&lt;/a&gt;（可自定义服务商接口，但上下文能力较弱）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;2-ide-ai-开发工具&#34;&gt;2. IDE AI 开发工具&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;直接从文件管理器拖入文件即可&lt;/li&gt;&#xA;&lt;li&gt;支持项目级宏观管理&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;国内-ai-ide&#34;&gt;国内 AI IDE&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://www.trae.ai/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Trae&lt;/a&gt;&lt;/strong&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;特有 Solo 模式（和普通模式感觉主要是 UI 差别，在功能上感觉差的不是很大，可能隐藏 prompt 有所优化）&lt;/li&gt;&#xA;&lt;li&gt;可使用规定的国内其他服务商接口&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://qoder.ai/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Qoder&lt;/a&gt;&lt;/strong&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;无特色&lt;/li&gt;&#xA;&lt;li&gt;上下文消耗快&lt;/li&gt;&#xA;&lt;li&gt;无法使用国外模型或其他接口&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://lingma.aliyun.com/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;通义灵码&lt;/a&gt;&lt;/strong&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;无特色&lt;/li&gt;&#xA;&lt;li&gt;无法使用国外模型或其他接口&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;国内-ide-的共性&#34;&gt;国内 IDE 的共性&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;喜欢构建工作区文件全量索引，每次提问前先查索引文件，消耗大量上下文 token，有时查找的文件过多反而忽略关键问题&lt;/li&gt;&#xA;&lt;li&gt;国内模型编码能力较弱，且不允许使用国外更强的模型&lt;/li&gt;&#xA;&lt;li&gt;方便支付订阅, 界面中文支持较好&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;国外-ai-ide&#34;&gt;国外 AI IDE&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/features/copilot&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;GitHub Copilot★★&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;VSCode 插件形式&lt;/li&gt;&#xA;&lt;li&gt;适合片段式的文件&lt;/li&gt;&#xA;&lt;li&gt;上下文补全能力较弱&lt;/li&gt;&#xA;&lt;li&gt;无法全面定制化&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/cline/cline&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Cline★★&lt;/a&gt;（开源）&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;可自定义任意服务商&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;VSCode 插件形式&lt;/li&gt;&#xA;&lt;li&gt;适合片段式的文件&lt;/li&gt;&#xA;&lt;li&gt;上下文补全能力较弱&lt;/li&gt;&#xA;&lt;li&gt;无法全面定制化&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Kilo-Org/kilocode&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Kilo&lt;/a&gt;（开源）&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;可使用规定的第三方服务商api&lt;/li&gt;&#xA;&lt;li&gt;VSCode 插件形式&lt;/li&gt;&#xA;&lt;li&gt;适合片段式的文件&lt;/li&gt;&#xA;&lt;li&gt;上下文补全能力较弱&lt;/li&gt;&#xA;&lt;li&gt;无法全面定制化&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://www.cursor.so/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Cursor★★★&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;基于 VSCode 深度定制&lt;/li&gt;&#xA;&lt;li&gt;自研模型 Composer 1 (专为编程训练, 功能强大)&lt;/li&gt;&#xA;&lt;li&gt;可使用规定的其他服务商 API&lt;/li&gt;&#xA;&lt;li&gt;agent可以直接连接github远程储存库(特色功能)&lt;/li&gt;&#xA;&lt;li&gt;预设 Prompt 优秀输出质量高，但免费额度少，订阅贵&lt;/li&gt;&#xA;&lt;li&gt;亮眼功能：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;浏览器设计模式&lt;/strong&gt;：可以直接在ide里面打开网页，并且选择元素，方便设计网页&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;debug&lt;/strong&gt;：可以根据log寻找隐藏bug&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://kiro.dev&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;kiro&lt;/a&gt;&lt;/strong&gt;&#xA;电脑安装闪退，我用不了(哭)&lt;/p&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://windsurf.ai/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Windsurf★★★&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;基于 VSCode 深度定制&lt;/li&gt;&#xA;&lt;li&gt;自研模型 SWE-1.5 (专为编程训练, 功能强大)&lt;/li&gt;&#xA;&lt;li&gt;亮眼功能：&#xA;&lt;ul&gt;&#xA;&lt;li&gt;&lt;strong&gt;Memories&lt;/strong&gt;：可以根据对话和习惯生成对应的记忆（ai自动生成记忆，以在对话之间保持上下文连贯性）&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;DeepWiki&lt;/strong&gt;：独家功能,定位项目中关键函数或变量，了解用途和在项目其他地方引用 (方便学习他人的开源项目)&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;CodeMap&lt;/strong&gt;：独家功能,用于分析现有项目代码结构,可以根据输入的问题生成项目代码实现的流程图,点击流程图可以定位对应代码实现的部分（对于解剖他人项目的功能实现很有用）&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;浏览器设计模式&lt;/strong&gt;：可以直接在ide里面打开网页，并且选择元素，方便设计网页&lt;/li&gt;&#xA;&lt;li&gt;&lt;strong&gt;对话消息互通&lt;/strong&gt;：独家功能,不同对话之间可以选择互通消息，如两个不同的项目,具有一定的关联性，我们就可以通过这个功能实现两个项目在对话层面上的互通，而不需要ai去研究另外一个项目的代码，防止添加过多的内容，导致上下文混乱&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;免费额度高，价格便宜&lt;/li&gt;&#xA;&lt;li&gt;支持规定的其他服务商 API&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;li&gt;&#xA;&lt;p&gt;&lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://zed.dev&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Zen Editor&lt;/a&gt;（开源）&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;可使用任意服务商接口&lt;/li&gt;&#xA;&lt;li&gt;自带免费额度高&lt;/li&gt;&#xA;&lt;li&gt;上下文补全能力较弱&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;hr&gt;&#xA;&lt;h2 id=&#34;总结推荐&#34;&gt;总结推荐&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;综合价格、模型能力和上下文补全能力，我个人首推 &lt;strong&gt;&lt;a class=&#34;link&#34; href=&#34;https://windsurf.ai/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Windsurf&lt;/a&gt;&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;DeepWiki、CodeMap 和消息互通是其最大亮点，让其上下文补全能力非常强大&lt;/li&gt;&#xA;&lt;li&gt;其他 AI IDE 在 UI 功能上同质化严重，差别主要在 AI 模型、执行逻辑和预设 Prompt&lt;/li&gt;&#xA;&lt;li&gt;如果不考虑开发效率，单论编码能力,openai的codex和claude code这种命令行式开发可能是最强的一批,其次就是cursor和windsurf&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;</description>
        </item><item>
            <title>GKI 内核不完全编译实战</title>
            <link>https://blog.liao-ke.com/p/android-gki-kernel-compile/</link>
            <pubDate>Fri, 05 Dec 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/android-gki-kernel-compile/</guid>
            <description>&lt;h1 id=&#34;android内核编译&#34;&gt;Android内核编译&#xA;&lt;/h1&gt;&lt;p&gt;&lt;strong&gt;以编译5.10以上的内核为例,所需资源:&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ol&gt;&#xA;&lt;li&gt;一台配置较好的电脑&lt;/li&gt;&#xA;&lt;li&gt;linux系统&lt;/li&gt;&#xA;&lt;li&gt;内核源代码&lt;/li&gt;&#xA;&lt;li&gt;编译链工具&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h2 id=&#34;linux系统&#34;&gt;linux系统&#xA;&lt;/h2&gt;&lt;ul&gt;&#xA;&lt;li&gt;各大Linux系统(Ubuntu系/arch系/fedora系/Wsl2)都可以，网上教程多以Ubuntu lts版本为例(&lt;strong&gt;便于找依赖和教程&lt;/strong&gt;)&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;内核源代码&#34;&gt;内核源代码&#xA;&lt;/h2&gt;&lt;p&gt;从github上搜索自己机型的内核源代码&lt;br&gt;&#xA;如&lt;code&gt;https://github.com/Evolution-X-Devices/kernel_xiaomi_sm8450&lt;/code&gt;(&lt;strong&gt;项目名一般采用   kernel_厂家名_芯片组代号   的形式,5.10之后都是gki内核,所以内核名称基本是以芯片组命名如sm8450,有些项目也可能是按机型代号命名，而不是芯片组&lt;/strong&gt;)&lt;/p&gt;&#xA;&lt;h2 id=&#34;编译链工具&#34;&gt;编译链工具&#xA;&lt;/h2&gt;&lt;p&gt;5.10以上的内核一般采用纯clang/llvm进行编译(低版本内核也可尝试，但有可能能成功编译但会开不了机)&lt;/p&gt;&#xA;&lt;h3 id=&#34;clangllvm&#34;&gt;Clang/llvm&#xA;&lt;/h3&gt;&lt;p&gt;Clang 一般情况下采用的是&lt;a class=&#34;link&#34; href=&#34;https://android.googlesource.com/platform/prebuilts/clang/host/linux-x86/&amp;#43;/refs/heads/main&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;google&lt;/a&gt;的正式分支,也可以采用&lt;a class=&#34;link&#34; href=&#34;https://android.googlesource.com/platform/prebuilts/clang/host/linux-x86/&amp;#43;/refs/heads/mirror-goog-main-prebuilts&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;测试分支&lt;/a&gt;&lt;/p&gt;&#xA;&lt;h2 id=&#34;编译过程&#34;&gt;编译过程&#xA;&lt;/h2&gt;&lt;h3 id=&#34;更新环境依赖&#34;&gt;更新环境依赖&#xA;&lt;/h3&gt;&lt;p&gt;以Ubuntu24.04为例,执行以下命令安装依赖&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;sudo apt-get install git-core gnupg flex bison build-essential zip curl zlib1g-dev gcc-multilib g++-multilib libc6-dev-i386 libncurses5 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev libgl1-mesa-dev libxml2-utils xsltproc tar xz-utils cpio findutils&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;h3 id=&#34;克隆内核源代码和编译链工具&#34;&gt;克隆内核源代码和编译链工具&#xA;&lt;/h3&gt;&lt;p&gt;内核:&lt;code&gt;git clone https://github.com/Evolution-X-Devices/kernel_xiaomi_sm8450.git --depth=1&lt;/code&gt;&lt;br&gt;&#xA;编译链工具:&lt;code&gt;git clone https://android.googlesource.com/platform/prebuilts/clang/host/linux-x86.git --depth=1&lt;/code&gt;&lt;br&gt;&#xA;&lt;strong&gt;depth=1&lt;/strong&gt;只拉取文件，不拉取历史提交，可以极大减少下载时间&lt;br&gt;&#xA;如果想拉取其他的测试分支，也可以在后面加&lt;code&gt;-b 测试分支名字&lt;/code&gt;&lt;br&gt;&#xA;如拉取测试版的编译链则添加&lt;code&gt;-b mirror-goog-main-prebuilts&lt;/code&gt;&lt;/p&gt;&#xA;&lt;h3 id=&#34;设置环境变量&#34;&gt;设置环境变量&#xA;&lt;/h3&gt;&lt;p&gt;注:&lt;code&gt;以下操作需要在同一个终端环境下执行，因为添加的变量是临时变量&lt;/code&gt;&lt;br&gt;&#xA;此时在你的工作目录下面应该会有两个文件夹，一是&lt;code&gt;内核文件夹&lt;/code&gt;，二是&lt;code&gt;编译链工具文件夹&lt;/code&gt;&lt;br&gt;&#xA;打开终端,执行&lt;code&gt;cd 编译链工具文件夹路径&lt;/code&gt;,当前目录下应该会有若干个&lt;code&gt;clang-rxxxx&lt;/code&gt;子文件夹，选择后缀数字最大的最新版本即可,将它下面的/bin添加到环境变量中&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;PATH&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;nv&#34;&gt;$PATH&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;:/../../编译链工具文件夹/clang-rxxxx/bin&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;p&gt;然后再&lt;code&gt;cd 内核源代码文件夹&lt;/code&gt;&lt;br&gt;&#xA;设置编译环境变量&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;3&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;4&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;5&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;6&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;7&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;8&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;ARCH&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;arm64&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;SUBARCH&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;arm64&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;CC&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;clang&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;LLVM&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;m&#34;&gt;1&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;LLVM_IAS&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;m&#34;&gt;1&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;HOSTCC&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;clang&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;LD&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;ld.lld&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;CLANG_TRIPLE&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;aarch64-linux-gnu-&amp;#34;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;p&gt;如果电脑的内存不太够，可以额外设置&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nb&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;nv&#34;&gt;LTO&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;thin&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;h3 id=&#34;执行编译命令&#34;&gt;执行编译命令&#xA;&lt;/h3&gt;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;make &lt;span class=&#34;nv&#34;&gt;ARCH&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;arm64&amp;#34;&lt;/span&gt; gki_defconfig&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;make -j&lt;span class=&#34;k&#34;&gt;$(&lt;/span&gt;nproc --all&lt;span class=&#34;k&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;p&gt;第一行命令是加载配置文件gki_defconfig,他所在的目录是&lt;code&gt;/内核源代码/arch/arm64/configs/gki_defconfig&lt;/code&gt;（可以自行修改里面的配置项）&lt;br&gt;&#xA;编译出来的内核二进制文件会在&lt;code&gt;/内核源代码/arch/arm64/boot/Image&lt;/code&gt;&lt;/p&gt;&#xA;&lt;h2 id=&#34;打包内核&#34;&gt;打包内核&#xA;&lt;/h2&gt;&lt;p&gt;由于没有编译kernel-devicetree,也没ramdisk,所以无法和内核二进制文件打包成boot.img刷入手机分区(也可以用magiskboot把手机原本的boot.img进行解包，把其中的内核二进制文件替换之后,再打包就行了)&lt;br&gt;&#xA;这个时候就需要&lt;a class=&#34;link&#34; href=&#34;https://github.com/osm0sis/AnyKernel3&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;AnyKernel3&lt;/a&gt;对内核二进制文件进行打包&lt;br&gt;&#xA;详细教程参考&lt;br&gt;&#xA;&lt;a class=&#34;link&#34; href=&#34;https://github.com/tiann/KernelSU/discussions/952&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;https://github.com/tiann/KernelSU/discussions/952&lt;/a&gt;&lt;/p&gt;&#xA;&lt;h2 id=&#34;刷入内核&#34;&gt;刷入内核&#xA;&lt;/h2&gt;&lt;p&gt;可以在twrp或一些用于刷写内核的app中刷入打包后的AnyKernel3.zip&lt;/p&gt;&#xA;&lt;h2 id=&#34;注意&#34;&gt;注意&#xA;&lt;/h2&gt;&lt;p&gt;&lt;strong&gt;不同型号内核以及不同版本的编译器，可能对依赖和代码语法要求也有所不同，需要自行解决。&lt;/strong&gt;&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>代理工具的选择</title>
            <link>https://blog.liao-ke.com/p/proxy-tools/</link>
            <pubDate>Wed, 03 Dec 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/proxy-tools/</guid>
            <description>&lt;h1 id=&#34;主流代理核心简介代理核心--前端-ui&#34;&gt;主流代理核心简介（代理核心 + 前端 UI）&#xA;&lt;/h1&gt;&lt;p&gt;所有代理工具本质上都是 &lt;strong&gt;代理核心 + 前端图形界面（UI）&lt;/strong&gt; 组成。&lt;br&gt;&#xA;前端 UI 可以千变万化，但真正承担流量处理的 &lt;strong&gt;代理核心只有少数几种&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;p&gt;以下是目前主流、最常见的核心介绍。&lt;/p&gt;&#xA;&lt;h2 id=&#34;clash更新停滞&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Dreamacro/clash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash&lt;/a&gt;(更新停滞)&#xA;&lt;/h2&gt;&lt;p&gt;Clash 是一个最初由 Go 编写的多协议代理核心（原项目已删除）。&lt;br&gt;&#xA;使用广泛，生态庞大。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;使用统一的 YAML 配置，无需因平台不同而修改&lt;/li&gt;&#xA;&lt;li&gt;GUI 客户端数量最多、生态最大&lt;/li&gt;&#xA;&lt;li&gt;跨平台兼容性极强&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;原项目已停止维护&lt;/li&gt;&#xA;&lt;li&gt;新协议支持较慢（如 Reality、Hysteria2 等）&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;mihomoclash-meta&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/MetaCubeX/mihomo&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Mihomo（Clash Meta）&lt;/a&gt;★★★&#xA;&lt;/h2&gt;&lt;p&gt;MetaCubeX 社区维护的 Clash 增强版，也是目前最主流的 Clash 继承者。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;完全兼容 Clash 配置&lt;/li&gt;&#xA;&lt;li&gt;支持现代协议（Reality、Hysteria2、TUIC 等）&lt;/li&gt;&#xA;&lt;li&gt;活跃维护，性能更高&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;sing-boxsb&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/SagerNet/sing-box&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Sing-Box（sb）&lt;/a&gt;★★&#xA;&lt;/h2&gt;&lt;p&gt;由 SagerNet 开发的现代化代理核心，目前增长最快、架构最先进。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;极度轻量，理论性能高&lt;/li&gt;&#xA;&lt;li&gt;高度可定制的网络与路由配置&lt;/li&gt;&#xA;&lt;li&gt;支持大量现代协议&lt;/li&gt;&#xA;&lt;li&gt;跨平台优秀&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;配置难度高，对新手不友好&lt;/li&gt;&#xA;&lt;li&gt;GUI 生态较少&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;v2ray更新缓慢&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/v2fly/v2ray-core&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;V2Ray&lt;/a&gt;(更新缓慢)&#xA;&lt;/h2&gt;&lt;p&gt;由 v2fly 社区维护的原始 V2Ray 核心。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;配置灵活&lt;/li&gt;&#xA;&lt;li&gt;结构成熟&lt;/li&gt;&#xA;&lt;li&gt;较为轻量&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;开发速度慢&lt;/li&gt;&#xA;&lt;li&gt;新协议支持不佳&lt;/li&gt;&#xA;&lt;li&gt;配置复杂&lt;/li&gt;&#xA;&lt;li&gt;GUI 生态弱&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;xray&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/XTLS/Xray-core&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Xray&lt;/a&gt;&#xA;&lt;/h2&gt;&lt;p&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/v2fly/v2ray-core&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;V2Ray&lt;/a&gt; 的增强版核心，由 XTLS 项目维护。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;完全兼容 V2Ray 配置&lt;/li&gt;&#xA;&lt;li&gt;支持 Reality&lt;/li&gt;&#xA;&lt;li&gt;支持 XTLS，性能大幅提升&lt;/li&gt;&#xA;&lt;li&gt;性能明显高于官方 V2Ray&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;配置复杂&lt;/li&gt;&#xA;&lt;li&gt;GUI 生态较弱&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;dae&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/daeuniverse/dae&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;dae&lt;/a&gt;&#xA;&lt;/h2&gt;&lt;p&gt;基于 eBPF 的 Linux / 路由器高性能代理引擎，更像“下一代分流框架”。&lt;/p&gt;&#xA;&lt;p&gt;&lt;strong&gt;特点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;基于 eBPF，性能极高&lt;/li&gt;&#xA;&lt;li&gt;几乎不占 CPU&lt;/li&gt;&#xA;&lt;li&gt;延迟极低&lt;/li&gt;&#xA;&lt;li&gt;路由分流能力极强&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;p&gt;&lt;strong&gt;缺点：&lt;/strong&gt;&lt;/p&gt;&#xA;&lt;ul&gt;&#xA;&lt;li&gt;仅支持 Linux / OpenWRT&lt;/li&gt;&#xA;&lt;li&gt;配置复杂&lt;/li&gt;&#xA;&lt;li&gt;GUI少&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;各操作系统主流gui代理客户端整体按照知名度排序&#34;&gt;各操作系统主流GUI代理客户端(整体按照知名度排序)&#xA;&lt;/h2&gt;&lt;h3 id=&#34;windows&#34;&gt;Windows&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/2dust/v2rayN&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;v2rayN★★&lt;/a&gt; — 支持 Xray / sing-box / clash/others 内核,支持Windows/Linux/macOS&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Clash-Verge-rev/clash-verge-rev&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Verge Rev★★&lt;/a&gt; — 内置 Mihomo内核,支持 Linux/macOS/Windows&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/mihomo-party-org/clash-party&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Mihomo Party★★★&lt;/a&gt;(推荐)  - 支持linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/karing&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Karing&lt;/a&gt; — 基于 sing-box 内核,支持Android/ios/linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/xishang0128/sparkle&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Sparkle★★&lt;/a&gt; — 基于 Mihomo 内核，支持 Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/clashmi&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Mi&lt;/a&gt; —支持android/ios/Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/chen08209/FlClash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;FlClash&lt;/a&gt; — 基于 Mihomo 内核,支持Android/linux/windows、macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/GUI-for-Cores/GUI.for.Clash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;GUI.for.Clash&lt;/a&gt; — Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/snakem982/Pandora-Box&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Pandora-Box&lt;/a&gt; — 基于 Mihomo 内核,支持linux/windows/macos&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;macos&#34;&gt;macOS&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://nssurge.com&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Surge★★★&lt;/a&gt; — 付费高级客户端,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://apps.apple.com/us/app/quantumult-x/id1443988620&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Quantumult X★★★&lt;/a&gt; — 付费,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://apps.apple.com/us/app/loon/id1373567447&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Loon&lt;/a&gt; —  付费,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/2dust/v2rayN&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;v2rayN&lt;/a&gt; — 支持 Xray / sing-box / clash/others 内核,支持Windows/Linux/macOS&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Clash-Verge-rev/clash-verge-rev&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Verge Rev&lt;/a&gt; — 内置 Mihomo 内核,支持 Linux/macOS/Windows&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/mihomo-party-org/clash-party&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Mihomo Party&lt;/a&gt;  - 支持linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/karing&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Karing&lt;/a&gt; — 基于 sing-box 内核,支持Android/ios/linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/xishang0128/sparkle&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Sparkle&lt;/a&gt; — 基于 Mihomo 内核，支持 Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/chen08209/FlClash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;FlClash&lt;/a&gt; — 基于 Mihomo 内核,支持Android/linux/windows、macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/clashmi&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Mi&lt;/a&gt; —支持android/ios/Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/GUI-for-Cores/GUI.for.Clash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;GUI.for.Clash&lt;/a&gt; — Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://stash.ws&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Stash★★&lt;/a&gt; — 基于 sing-box（付费）&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/snakem982/Pandora-Box&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Pandora-Box&lt;/a&gt; — 基于 Mihomo 内核,支持linux/windows/macos&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;linux&#34;&gt;Linux&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/2dust/v2rayN&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;v2rayN★★&lt;/a&gt; — 支持 Xray / sing-box / clash/others 内核,支持Windows/Linux/macOS&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Clash-Verge-rev/clash-verge-rev&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Verge Rev★★&lt;/a&gt; — 内置 Mihomo 内核,支持 Linux/macOS/Windows&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/mihomo-party-org/clash-party&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Mihomo Party★★★&lt;/a&gt;  - 支持linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/karing&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Karing&lt;/a&gt; — 基于 sing-box 内核,支持Android/ios/linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/xishang0128/sparkle&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Sparkle&lt;/a&gt; — 基于 Mihomo 内核，支持 Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/chen08209/FlClash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;FlClash&lt;/a&gt; — 基于 Mihomo 内核,支持Android/linux/windows、macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/clashmi&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Mi&lt;/a&gt; —支持android/ios/Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/GUI-for-Cores/GUI.for.Clash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;GUI.for.Clash&lt;/a&gt;  — 支持 Linux/macOS/Windows&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/snakem982/Pandora-Box&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Pandora-Box&lt;/a&gt; — 基于 Mihomo 内核,支持linux/windows/macos&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;android&#34;&gt;Android&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/MetaCubeX/ClashMetaForAndroid&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Meta for Android★★★&lt;/a&gt;(推荐)&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/karing&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Karing&lt;/a&gt; — 基于 sing-box 内核,支持Android/ios/linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/clashmi&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Mi&lt;/a&gt; —支持android/ios/Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/chen08209/FlClash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;FlClash★★&lt;/a&gt; — 基于 Mihomo 内核,支持Android/linux/windows、macos&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;ios&#34;&gt;iOS&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://nssurge.com&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Surge★★★&lt;/a&gt; — 付费高级客户端,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://apps.apple.com/us/app/shadowrocket/id932747118&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Shadowrocket★★★&lt;/a&gt; — 付费,支持多协议&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://apps.apple.com/us/app/quantumult-x/id1443988620&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Quantumult X★★★&lt;/a&gt; — 付费,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://apps.apple.com/us/app/loon/id1373567447&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Loon&lt;/a&gt; —  付费,支持ios/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/karing&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Karing&lt;/a&gt; — 基于 sing-box 内核,支持Android/ios/linux/windows/macos&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/KaringX/clashmi&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Clash Mi&lt;/a&gt; —支持android/ios/Windows / macOS / Linux&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;harmonyos-next&#34;&gt;HarmonyOS NEXT&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/xiaobaigroup/ClashBox&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;ClashBox&lt;/a&gt; — 独苗这一块&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h3 id=&#34;路由器openwrt--linux&#34;&gt;路由器（OpenWRT / Linux）&#xA;&lt;/h3&gt;&lt;ul&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/vernesong/OpenClash&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;OpenClash★★&lt;/a&gt; - OpenWRT 上主流的 Clash 客户端&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/nikkinikki-org/OpenWrt-nikki&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;OpenWrt-nikki★★★&lt;/a&gt;(推荐) —  基于clash核心&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/daeuniverse/daed&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;daed&lt;/a&gt; — 基于dae内核&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/xiaorouji/openwrt-passwall&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Passwall2&lt;/a&gt;&lt;/li&gt;&#xA;&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://github.com/Thaolga/openwrt-nekobox&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;openwrt-nekobox&lt;/a&gt; — 基于 Sing-box核心&lt;/li&gt;&#xA;&lt;/ul&gt;&#xA;&lt;h2 id=&#34;总结&#34;&gt;总结&#xA;&lt;/h2&gt;&lt;p&gt;小白无脑选择clash系客户端，有其他要求可自定义选择。&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>博客框架的选择</title>
            <link>https://blog.liao-ke.com/p/blog-framework-choose/</link>
            <pubDate>Tue, 02 Dec 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/blog-framework-choose/</guid>
            <description>&lt;h1 id=&#34;博客框架我们应该如何选择&#34;&gt;博客框架我们应该如何选择？&#xA;&lt;/h1&gt;&lt;p&gt;博客大体上可以分为&lt;strong&gt;静态博客&lt;/strong&gt;和&lt;strong&gt;动态博客&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;p&gt;动态博客采用的是&lt;strong&gt;前端+后端&lt;/strong&gt;的模式,而静态博客就是&lt;strong&gt;纯前端静态文件&lt;/strong&gt;（方便托管）&lt;/p&gt;&#xA;&lt;h2 id=&#34;动态博客的优缺点&#34;&gt;动态博客的优缺点:&#xA;&lt;/h2&gt;&lt;h3 id=&#34;优点&#34;&gt;优点:&#xA;&lt;/h3&gt;&lt;ol&gt;&#xA;&lt;li&gt;适合大型博客或者论坛&lt;/li&gt;&#xA;&lt;li&gt;自带后台管理评论&lt;/li&gt;&#xA;&lt;li&gt;功能集成很多，适合小白，基本不需要额外去弄什么&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h3 id=&#34;缺点&#34;&gt;缺点:&#xA;&lt;/h3&gt;&lt;ol&gt;&#xA;&lt;li&gt;资源占用大&lt;/li&gt;&#xA;&lt;li&gt;必须依赖服务器运行，不可使用静态host主机/serverless服务提供商(cloudflare/vercle/github pages)&lt;/li&gt;&#xA;&lt;li&gt;网站加载速度相对较慢&lt;/li&gt;&#xA;&lt;li&gt;有一定的运维成本(服务器/防火墙等费用)&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h2 id=&#34;静态博客的优缺点&#34;&gt;静态博客的优缺点:&#xA;&lt;/h2&gt;&lt;h3 id=&#34;优点-1&#34;&gt;优点:&#xA;&lt;/h3&gt;&lt;ol&gt;&#xA;&lt;li&gt;加载速度相对较快&lt;/li&gt;&#xA;&lt;li&gt;资源占用少。&lt;/li&gt;&#xA;&lt;li&gt;可以将网站交给serverless服务商托管（白嫖党狂喜，不需要专门的服务器）&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h3 id=&#34;缺点-1&#34;&gt;缺点:&#xA;&lt;/h3&gt;&lt;ol&gt;&#xA;&lt;li&gt;要有一定的web技术功底，会手动改配置文件、布局,写文章模板&lt;/li&gt;&#xA;&lt;li&gt;框架集成的功能较少，如评论功能，音频播放器，需要自行对接第三方接口（不过很多静态博客主题里面已经把功能模板写好了，只需要更换接口地址就行）&lt;/li&gt;&#xA;&lt;li&gt;缺乏统一的后台管理功能&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;h2 id=&#34;动态博客框架&#34;&gt;动态博客框架&#xA;&lt;/h2&gt;&lt;h3 id=&#34;wordpress&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://wordpress.org/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;WordPress★★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt;  世界知名动态博客框架，主题资源插件丰富，教程多。&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;typecho&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://typecho.org/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Typecho&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; 轻量级动态博客框架，主打一个快速部署，快速上线&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;halo&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://halo.run/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Halo★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; 界面很漂亮，资源插件相对来说比较丰富，社区正在逐步发展，安装部署方法较为麻烦，比较吃服务器性能&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h2 id=&#34;静态博客框架&#34;&gt;静态博客框架&#xA;&lt;/h2&gt;&lt;h3 id=&#34;hexo&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://hexo.io/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Hexo★★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; node.js开发,教程很多，社区插件主题资源丰富，缺点是当文章数量&amp;gt;1k时，构建速度会显著减缓&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;hugo&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://gohugo.io/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Hugo★★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; go语言开发,使用go template模板，学习门槛相对其他的来说高点。运行build效率很高,支持热加载,更改不需要刷新网页页面即可生效。教程资源丰富,社区插件资源也很多，稍逊hexo,最大的优势是当文章数量很多时，构建静态网站的速度可以快其他框架几倍.&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;jekyll&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://jekyllrb.com/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Jekyll★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; 资源插件相对较少,界面简洁直观,但有github官方支持,可以直接将存入仓库的md文件转换成网页&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;vitepress&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://vitepress.dev/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;VitePress&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt; 资源插件丰富，可扩性强,常用于构建文档，不用于博客&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h3 id=&#34;astro&#34;&gt;&lt;a class=&#34;link&#34; href=&#34;https://astro.build/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;&#xA;    &gt;Astro★★&lt;/a&gt;&#xA;&lt;/h3&gt;&lt;pre&gt;&lt;code&gt;新一代静态框架,0 javascript的技术理念让网站首页加载起来非常快,采用服务端渲染的技术理念&#xA;可局部初始化组件为spa,增强网站运行效率,可搭配其他前端框架组件使用，但主题资源相对较少。&#xA;&lt;/code&gt;&lt;/pre&gt;&#xA;&lt;h2 id=&#34;总结&#34;&gt;总结&#xA;&lt;/h2&gt;&lt;p&gt;对于零基础的小白，想搭建博客，首先推荐动态博客框架，首选wordpress,有一定技术基础，搭建自己个人的轻量博客推荐静态框架,首选hexo/hugo,想要更快的构建速度和热加载，选择hugo.如果想尝试更先进的技术理念和更快的首页加载速度，可以尝试astro&lt;/p&gt;&#xA;&lt;h2 id=&#34;杂谈&#34;&gt;杂谈&#xA;&lt;/h2&gt;&lt;p&gt;本站采用hugo构建,github仓库储存,cloudflare远程克隆部署,评论功能对接waline。&lt;/p&gt;&#xA;</description>
        </item><item>
            <title>用cloudflare worker实现telegram bot | 开发日记</title>
            <link>https://blog.liao-ke.com/p/cloudflare-worker-telegram-bot/</link>
            <pubDate>Mon, 20 Oct 2025 00:00:00 +0000</pubDate>
            <guid>https://blog.liao-ke.com/p/cloudflare-worker-telegram-bot/</guid>
            <description>&lt;p&gt;这段时间闲着没事，想做一个 Telegram Bot 来玩玩。了解了一下，可实施的开发方案还挺多的，Java/Python 等等都有相对应的库。但是奈何&lt;strong&gt;我没有服务器&lt;/strong&gt;，无法进行传统的前后端开发。&lt;/p&gt;&#xA;&lt;p&gt;于是乎，我想到了另一种开发思路：利用 &lt;strong&gt;Cloudflare 提供的 Serverless 无状态 JavaScript Worker&lt;/strong&gt; 以及 &lt;strong&gt;Telegram Bot 官方支持的 Webhook 功能&lt;/strong&gt;来实现无服务器聊天机器人。&lt;/p&gt;&#xA;&lt;h2 id=&#34;实现原理&#34;&gt;实现原理&#xA;&lt;/h2&gt;&lt;p&gt;我们在聊天机器人的界面发送命令：&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-fallback&#34; data-lang=&#34;fallback&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;/chat 聊天内容&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;&lt;p&gt;通过设置 Webhook 地址指向 Worker，Worker 中写好处理指令的代码，截取 &lt;code&gt;/开始&lt;/code&gt; 后面的文字，然后转发给 &lt;strong&gt;Cloudflare 官方提供的免费的大语言模型后端&lt;/strong&gt;，然后再处理返回的信息，最后再通过 &lt;strong&gt;Telegram Bot API&lt;/strong&gt; 再返回消息到客户端。&lt;/p&gt;&#xA;&lt;p&gt;这样便实现了&lt;strong&gt;无服务器的聊天 AI Bot&lt;/strong&gt;，但是这有个缺点：用户的每一次聊天都是单独的一次请求，bot没有上下文记忆,因为 Worker 本身是个&lt;strong&gt;无状态的js执行器&lt;/strong&gt;，所以这个 Bot 其实相当于是一个&lt;strong&gt;图形化的终端命令请求器&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;h2 id=&#34;但是-cloudflare-有提供免费的额外的-kv-数据库于是我们再改动一下代码&#34;&gt;但是 &lt;strong&gt;Cloudflare 有提供免费的额外的 KV 数据库&lt;/strong&gt;，于是我们再改动一下代码：&#xA;&lt;/h2&gt;&lt;ol&gt;&#xA;&lt;li&gt;用户发来的文字不直接请求大语言模型后端&lt;/li&gt;&#xA;&lt;li&gt;而是先&lt;strong&gt;存入 KV 数据库&lt;/strong&gt;&lt;/li&gt;&#xA;&lt;li&gt;最后将 KV 数据库里的数据一起再发给大语言模型后端&lt;/li&gt;&#xA;&lt;li&gt;处理返回的信息&lt;/li&gt;&#xA;&lt;li&gt;返回 Telegram 客户端&lt;/li&gt;&#xA;&lt;/ol&gt;&#xA;&lt;p&gt;于是Worker通过外挂KV数据库，最终便实现了&lt;strong&gt;带有记忆的无服务器聊天 AI 机器人&lt;/strong&gt;。&lt;/p&gt;&#xA;&lt;h2 id=&#34;实现源代码&#34;&gt;实现源代码&#xA;&lt;/h2&gt;&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;&#xA;&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;  1&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  2&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  3&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  4&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  5&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  6&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  7&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  8&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;  9&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 10&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 11&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 12&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 13&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 14&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 15&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 16&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 17&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 18&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 19&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 20&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 21&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 22&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 23&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 24&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 25&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 26&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 27&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 28&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 29&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 30&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 31&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 32&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 33&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 34&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 35&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 36&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 37&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 38&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 39&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 40&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 41&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 42&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 43&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 44&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 45&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 46&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 47&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 48&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 49&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 50&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 51&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 52&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 53&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 54&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 55&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 56&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 57&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 58&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 59&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 60&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 61&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 62&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 63&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 64&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 65&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 66&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 67&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 68&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 69&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 70&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 71&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 72&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 73&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 74&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 75&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 76&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 77&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 78&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 79&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 80&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 81&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 82&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 83&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 84&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 85&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 86&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 87&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 88&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 89&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 90&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 91&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 92&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 93&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 94&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 95&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 96&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 97&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 98&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 99&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;100&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;101&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;102&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;103&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;104&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;105&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;106&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;107&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;108&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;109&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;110&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;111&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;112&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;113&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;114&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;115&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;116&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;117&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;118&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;119&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;120&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;121&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;122&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;123&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;124&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;125&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;126&#xA;&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;127&#xA;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&#xA;&lt;td class=&#34;lntd&#34;&gt;&#xA;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-javascript&#34; data-lang=&#34;javascript&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;TELEGRAM_BOT_TOKEN&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;CF_API_TOKEN&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;kr&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;kd&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;run&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;model&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;input&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;response&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;fetch&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;sb&#34;&gt;`https://api.cloudflare.com/client/v4/accounts/1f5b3d5417456835c8191a2ec42f449e/ai/run/&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;${&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;model&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;}&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;`&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;headers&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;Authorization&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;sb&#34;&gt;`Bearer &lt;/span&gt;&lt;span class=&#34;si&#34;&gt;${&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;CF_API_TOKEN&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;}&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;`&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;},&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;method&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;POST&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;body&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;input&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;response&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;json&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;();&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;kr&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;kd&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;sendTelegramMessage&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat_id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;k&#34;&gt;try&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;fetch&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;`https://api.telegram.org/bot&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;${&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;TELEGRAM_BOT_TOKEN&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;}&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;/sendMessage`&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;method&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;POST&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;headers&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;Content-Type&amp;#34;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;application/json&amp;#34;&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;},&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;body&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;({&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;chat_id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;parse_mode&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;MarkdownV2&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;p&#34;&gt;}),&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;catch&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;err&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;error&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;发送 Telegram 消息失败:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;err&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;kr&#34;&gt;export&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;default&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;kr&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;fetch&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;request&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;env&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;ctx&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;request&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;method&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;!==&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;POST&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;Response&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;ok&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;status&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;mi&#34;&gt;200&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;k&#34;&gt;try&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;data&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;request&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;json&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;();&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;log&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;Telegram Update:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;data&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;));&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;data&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;!&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;Response&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;ok&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;status&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;mi&#34;&gt;200&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;match&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;match&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/^\/chat(?:@\w+)?(?:\s+([\s\S]+))?$/&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;arg&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;match&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;match&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;[&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;1&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;]&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;||&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;).&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;trim&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;()&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;log&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;完整消息文本:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;log&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;命令参数:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;arg&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;         &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;!&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;arg&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;sendTelegramMessage&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;请在 /chat 后输入要生成的内容，例如：/chat 写一个小故事&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;else&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kd&#34;&gt;let&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;env&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;bot&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;get&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;parse&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;[];&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;push&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;({&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;role&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;user&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;content&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;arg&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;env&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;bot&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;put&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;));&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;aiResponse&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;run&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;@cf/openai/gpt-oss-120b&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;nx&#34;&gt;instructions&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s1&#34;&gt;&amp;#39;你是liaoke的私人中文AI助手，简洁地回答用户的问题。&amp;#39;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;nx&#34;&gt;reasoning&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;effort&amp;#34;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;medium&amp;#34;&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;},&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;nx&#34;&gt;input&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;log&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;AI 原始响应:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;aiResponse&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;));&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;       &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;reasonText&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;aiResponse&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;result&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;output&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;filter&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;type&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;===&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;reasoning&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;map&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;content&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;map&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;c&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;c&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;).&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;join&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;\n&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;filter&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;Boolean&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;join&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;\n\n&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;||&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;AI 无法生成内容&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;outputText&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;aiResponse&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;result&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;output&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;filter&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;type&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;===&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;message&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;map&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;o&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;content&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;?&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;map&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;c&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;c&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;).&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;join&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;\n&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;filter&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;Boolean&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;join&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;\n\n&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;||&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;AI 无法生成内容&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;       &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;escapeMD&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;k&#34;&gt;if&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;!&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;          &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;text&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\\/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\\\&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/`/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\`&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/_/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\_&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\*/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\*&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\[/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\[&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\]/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\]&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/~/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\~&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/&amp;gt;/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\&amp;gt;&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/#/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\#&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\+/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\+&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/-/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\-&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/=/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\=&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\|/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\|&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\{/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\{&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\}/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\}&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/\./g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\.&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;            &lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;replace&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;sr&#34;&gt;/!/g&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;\\!&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;p&#34;&gt;};&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;     &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;messageMD&lt;/span&gt; &lt;span class=&#34;o&#34;&gt;=&lt;/span&gt; &lt;span class=&#34;sb&#34;&gt;`&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;🧠 推理过程：&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;\`\`\`&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;si&#34;&gt;${&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;escapeMD&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;reasonText&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;}&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;\`\`\`&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;💬 最终回答：&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;si&#34;&gt;${&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;escapeMD&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;outputText&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt;&lt;span class=&#34;si&#34;&gt;}&lt;/span&gt;&lt;span class=&#34;sb&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;sb&#34;&gt;        `&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;   &#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;sendTelegramMessage&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;messageMD&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;push&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;({&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;role&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;s2&#34;&gt;&amp;#34;assistant&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;content&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;outputText&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;kr&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;env&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;bot&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;put&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;message&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;chat&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;id&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;JSON&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;stringify&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;history&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;));&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;        &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;log&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;AI 输出发送给用户:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;messageMD&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;Response&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;ok&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;status&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;mi&#34;&gt;200&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;catch&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;err&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;)&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;nx&#34;&gt;console&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;.&lt;/span&gt;&lt;span class=&#34;nx&#34;&gt;error&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;解析 JSON 或处理失败:&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;err&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;);&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;      &lt;span class=&#34;k&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;k&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;Response&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;error&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;{&lt;/span&gt; &lt;span class=&#34;nx&#34;&gt;status&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;mi&#34;&gt;400&lt;/span&gt; &lt;span class=&#34;p&#34;&gt;});&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    &lt;span class=&#34;p&#34;&gt;}&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;p&#34;&gt;},&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;p&#34;&gt;};&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&#xA;&lt;/div&gt;&#xA;&lt;/div&gt;</description>
        </item></channel>
</rss>
