<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom">
    <id>https://jdjwzx233.cn</id>
    <title>jdjwzx233的博客</title>
    <subtitle>如期待奇迹发生，那唯有不停伸手去抓紧，去把握才行</subtitle>
    <icon>https://jdjwzx233.cn/images/favicon.ico</icon>
    <link href="https://jdjwzx233.cn" />
    <author>
      <name>jdjwzx233</name>
    </author>
    <updated>2026-03-03T07:28:19.633Z</updated>
    <category term="web" />
    <category term="编程" />
    <category term="信息技术" />
    <category term="科技" />
    <category term="日常" />
    <entry>
        <id>https://jdjwzx233.cn/2026/03/03/jdjwzx233%E7%9A%84%E5%8D%9A%E5%AE%A2/</id>
        <title>jdjwzx233的博客</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2026/03/03/jdjwzx233%E7%9A%84%E5%8D%9A%E5%AE%A2/"/>
        <content type="html">&lt;ol&gt;
&lt;li&gt;&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如无特别声明，该博客文章均为 jdjwzx233 原创，转载请遵循署名 - 非商业性使用 4.0 国际（CC BY-NC-SA）协议，即转载请注明文章来源。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;如发现用户发布违规内容或评论，管理员将封禁其 IP 地址！（所有 jdjwzx233 的站点将不可访问。如果有误封，请联系 &lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt; 进行申诉）&lt;/strong&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本博客使用 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvLw==&#34;&gt;hexo&lt;/span&gt; 进行搭建，采用 shoka 主题。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本博客属于非商业性质的博客。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如需联系 jdjwzx233，请&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9hcGkuYnRzdHUuY24vcXF0YWxrL2FwaS5waHA/cXE9MTQzODE0ODI0Mw==&#34;&gt;点击这里&lt;/span&gt;，或通过添加好友的方式联系 jdjwzx233-bot（QQ: 1438148243）。在进入 QQ 后，向 jdjwzx233-bot 发送指令 &amp;quot;!rg&amp;quot;，即可获取 jdjwzx233 的联系方式。获取好友验证码请参考第 7 条。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果博客文章、使用的图片等侵犯了您的版权或给您带来了损失，请联系 &lt;strong&gt;&lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt;&lt;/strong&gt;。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;jdjwzx233-bot 的好友验证码为：jdjwzx233blogyyds（不定时更改）。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;jdjwzx233-bot 将于 2023 年二月份关闭，客服业务已经转移到 jdjwzx233-Blog 上。您现在可以通过博客右下角的咨询按钮联系 jdjwzx233-Blog 的管理员。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果喜欢 jdjwzx233-Blog，请&lt;a href=&#34;/Subscribe&#34;&gt;点击这里&lt;/a&gt;订阅，获取 jdjwzx233-Blog 的最新动态。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果您访问本站，即表示您同意本站的&lt;a href=&#34;/Privacy%20policy&#34;&gt;隐私政策&lt;/a&gt;、&lt;a href=&#34;/Cookiepolicy&#34;&gt;Cookie 政策&lt;/a&gt;、&lt;a href=&#34;/Term%20sand%20conditions&#34;&gt;服务条款&lt;/a&gt;和&lt;a href=&#34;/Disclaimer&#34;&gt;免责声明&lt;/a&gt;。如果您不同意相关政策和条款，请勿访问本站。您可以联系 &lt;strong&gt;&lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt;&lt;/strong&gt; 删除您在本站中的一切信息（包括评论、账户、文章等）。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;为了尊重和保护访客和用户的隐私权，我们提供了一种方便的方式来关闭网站跟踪器。您可以在网站底部找到相应选项，以便自主选择是否接受网站跟踪。我们鼓励您在使用我们的网站时行使您的选择权，以获得更加个性化和符合您需求的浏览体验。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本站点已启用腾讯云 CDN 加速，加速网址：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cDovL3d3dy5qZGp3engyMzMuY24=&#34;&gt;www.jdjwzx233.cn&lt;/span&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;您可以使用爱发电赞助本博客的运营和开发。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;赞助感谢名单：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9zcG9uc29ybWUuamRqd3p4MjMzLmNvbS8=&#34;&gt;https://sponsorme.jdjwzx233.com/&lt;/span&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;span class=&#34;exturl image&#34; data-url=&#34;aHR0cHM6Ly9hZmRpYW4uY29tL3UvY2Q3ZjQ5ZjIwZjRiMTFlZDlmM2M1MjU0MDAyNWMzNzc=&#34; data-background-image=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/11/24/logo_0bab5ae4d8eb33ed096e89d0912170f3.png&#34;&gt;&lt;/span&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;span class=&#34;exturl title&#34; data-url=&#34;aHR0cHM6Ly9hZmRpYW4uY29tL3UvY2Q3ZjQ5ZjIwZjRiMTFlZDlmM2M1MjU0MDAyNWMzNzc=&#34;&gt;爱发电-jdjwzx233&lt;/span&gt;
          &lt;p class=&#34;desc&#34;&gt;每月5元，感谢您的赞助&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;广告&lt;/strong&gt;：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;LightNode&lt;/strong&gt;：拥有高质量香港 CN2 GIA 节点与原生 IP (河内、曼谷、华盛顿、柬埔寨)。充值 10 美元，最多账户获得 30 美元，10 美元可用 5 个月，相当于&lt;strong&gt;不要钱&lt;/strong&gt;。（&lt;strong&gt;支持支付宝、银联、paypal 等支付方式&lt;/strong&gt;）。对于想用 VPS 解锁 **「Netflix、 TikTok」** 或者其他流媒体，以及对 CN2 有需求的都可以看看。官网链接：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cubGlnaHRub2RlLmNvbS8/aW52aXRlQ29kZT1BRFFWTUomYW1wO3Byb21vdGVXYXk9TElOSw==&#34;&gt;www.lightnode.com&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;又拍云&lt;/strong&gt;：又拍云有非常多的优惠：加入又拍云联盟 (网站需备案，要在网站 / 应用底部添加又拍云 LOGO 并指向官网) 后，可以获得每月 10G 储存空间和 15G 的 CDN 流量 (按年发放，以 67 元的代金卷发放到账户)；新用户注册 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS9yZWdpc3Rlci8/aW52aXRlPXRJOGxqaXhJVA==&#34;&gt;点我注册&lt;/span&gt;) 还可以直接获得 61 元的代金卷 (有效期一年)。在这些优惠的加成下，你可以零成本建站。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;strong&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jaWFsbG8ubXkv&#34;&gt;Ciallo～(∠・ω&amp;lt; )⌒★&lt;/span&gt;&lt;/strong&gt;&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="梦开始的地方" scheme="https://jdjwzx233.cn/tags/%E6%A2%A6%E5%BC%80%E5%A7%8B%E7%9A%84%E5%9C%B0%E6%96%B9/" />
        <category term="声明" scheme="https://jdjwzx233.cn/tags/%E5%A3%B0%E6%98%8E/" />
        <updated>2026-03-03T07:28:19.633Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2025/05/01/%E7%BD%91%E7%AB%99%E7%BF%BB%E8%AF%91/</id>
        <title>网页自动翻译功能全攻略</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2025/05/01/%E7%BD%91%E7%AB%99%E7%BF%BB%E8%AF%91/"/>
        <content type="html">&lt;h2 id=&#34;前言&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#前言&#34;&gt;#&lt;/a&gt; 前言&lt;/h2&gt;
&lt;p&gt;在全球化互联网生态中，网站访问者往往来自不同语言背景，语言壁垒成为信息传递的天然障碍。传统多语言方案依赖人工维护静态翻译文件，不仅更新滞后、维护成本高昂，更无法应对动态内容和用户生成数据的实时翻译需求。与此同时，许多开发者陷入两难：直接调用谷歌翻译等公共接口可能面临服务稳定性风险，而私有化部署方案又常因技术复杂度望而却步。&lt;/p&gt;
&lt;p&gt;为突破这一困局，现代网页自动翻译技术应运而生。它不仅能实现毫秒级动态内容转化，更通过智能术语库和私有接口对接，在提升用户体验与控制翻译质量之间找到平衡点。&lt;/p&gt;
&lt;h2 id=&#34;一-谷歌翻译原生集成方案&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#一-谷歌翻译原生集成方案&#34;&gt;#&lt;/a&gt; 一、谷歌翻译原生集成方案&lt;/h2&gt;
&lt;h3 id=&#34;1-实现原理&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-实现原理&#34;&gt;#&lt;/a&gt; 1. 实现原理&lt;/h3&gt;
&lt;p&gt;通过动态加载谷歌翻译的脚本（ &lt;code&gt;element.js&lt;/code&gt; ），在页面中插入翻译控件，利用 Google 的云端接口实现实时翻译。&lt;/p&gt;
&lt;h3 id=&#34;2-操作步骤&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2-操作步骤&#34;&gt;#&lt;/a&gt; 2. 操作步骤&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- index.html 中插入脚本加载逻辑 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;onload&lt;/span&gt; = &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; script = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;createElement&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;script&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  script.&lt;span class=&#34;property&#34;&gt;src&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;https://translate.google.com/translate_a/element.js?cb=googleTranslateElementInit&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  script.&lt;span class=&#34;property&#34;&gt;onerror&lt;/span&gt; = &lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &lt;span class=&#34;variable language_&#34;&gt;console&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;error&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;Google 翻译加载失败，请检查网络环境&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;head&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;appendChild&lt;/span&gt;(script);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 翻译控件容器 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;google_translate_element&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;style&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;position:fixed;bottom:20px;right:20px;z-index:999&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// Vue/React 组件中初始化翻译器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;googleTranslateElementInit&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; google.&lt;span class=&#34;property&#34;&gt;translate&lt;/span&gt;.&lt;span class=&#34;title class_&#34;&gt;TranslateElement&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;pageLanguage&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;zh-CN&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;includedLanguages&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;en,ja,ko,es&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;comment&#34;&gt;// 限制可切换语言&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;layout&lt;/span&gt;: google.&lt;span class=&#34;property&#34;&gt;translate&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;TranslateElement&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;InlineLayout&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;SIMPLE&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;google_translate_element&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;注意事项&lt;/strong&gt;：需科学上网环境支持，频繁调用可能触发接口限制。&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;二-使用i18n-jsautotranslate-库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#二-使用i18n-jsautotranslate-库&#34;&gt;#&lt;/a&gt; 二、使用 i18n-jsautotranslate 库&lt;/h2&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// main.js 全局配置&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt; translate &lt;span class=&#34;keyword&#34;&gt;from&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;i18n-jsautotranslate&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;listener&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;start&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 监控动态文本&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;title class_&#34;&gt;Vue&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;prototype&lt;/span&gt;&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;$translate&lt;/span&gt; = translate;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 组件内切换语言&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;variable language_&#34;&gt;this&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;$translate&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;changeLanguage&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;english&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;variable language_&#34;&gt;this&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;$translate&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;execute&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 强制刷新翻译&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;特点&lt;/strong&gt;：轻量级集成，但需手动处理接口返回的动态内容。&lt;/p&gt;
&lt;h2 id=&#34;三-使用translatejs实现此处为简略内容详细的看最后面&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三-使用translatejs实现此处为简略内容详细的看最后面&#34;&gt;#&lt;/a&gt; 三、使用 translate.js 实现 (此处为简略内容，详细的看最后面)&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;使用 GitHub 项目：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRodWIuY29tL3hueDMvdHJhbnNsYXRl&#34;&gt;translate&lt;/span&gt;，如果你觉得这个项目好的话，可以去给项目点个 star&lt;/strong&gt;&lt;/p&gt;
&lt;h3 id=&#34;31-基础集成&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#31-基础集成&#34;&gt;#&lt;/a&gt; 3.1 基础集成&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 引入核心库 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;src&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;https://cdn.staticfile.net/translate.js/3.12.0/translate.js&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 自定义语言切换按钮 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;lang-switcher&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;onclick&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;translate.changeLanguage(&amp;#x27;english&amp;#x27;)&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;English&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;onclick&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;translate.changeLanguage(&amp;#x27;chinese_simplified&amp;#x27;)&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;简体中文&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 初始化配置&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;language&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;setLocal&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;chinese_simplified&amp;#x27;&lt;/span&gt;); &lt;span class=&#34;comment&#34;&gt;// 设置源语言&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;service&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;use&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;client.edge&amp;#x27;&lt;/span&gt;); &lt;span class=&#34;comment&#34;&gt;// 使用边缘计算翻译通道&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;translate.&lt;span class=&#34;title function_&#34;&gt;execute&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 立即执行翻译&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h3 id=&#34;32-核心功能详解&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#32-核心功能详解&#34;&gt;#&lt;/a&gt; 3.2 核心功能详解&lt;/h3&gt;
&lt;h4 id=&#34;1动态内容监控&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1动态内容监控&#34;&gt;#&lt;/a&gt; （1）动态内容监控&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;listener&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;start&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 开启DOM变动监听&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;ignore&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;class&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;no-translate&amp;#x27;&lt;/span&gt;); &lt;span class=&#34;comment&#34;&gt;// 忽略特定class&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;应用场景&lt;/strong&gt;：Vue/React 等框架的动态渲染内容自动翻译。&lt;/p&gt;
&lt;h4 id=&#34;2自定义术语库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2自定义术语库&#34;&gt;#&lt;/a&gt; （2）自定义术语库&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;term&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;OpenAI&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;开放人工智能&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;GPT-4&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;生成式预训练模型4.0&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;效果&lt;/strong&gt;：强制替换指定词汇，解决机器翻译不准确问题。&lt;/p&gt;
&lt;h4 id=&#34;3私有翻译接口&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#3私有翻译接口&#34;&gt;#&lt;/a&gt; （3）私有翻译接口&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;service&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;use&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;http://your-api.com/translate&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 自定义请求头（如API密钥）&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;request&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;Authorization&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;Bearer xxxxxx&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h4 id=&#34;4高级缓存控制&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#4高级缓存控制&#34;&gt;#&lt;/a&gt; （4）高级缓存控制&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 重写本地缓存策略&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;cache&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;setHandler&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;set&lt;/span&gt;: &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;key, value&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &lt;span class=&#34;variable language_&#34;&gt;sessionStorage&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;setItem&lt;/span&gt;(key, value),&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;get&lt;/span&gt;: &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;key&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &lt;span class=&#34;variable language_&#34;&gt;sessionStorage&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getItem&lt;/span&gt;(key)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h3 id=&#34;33-快速实现自动识别语语言并翻译&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#33-快速实现自动识别语语言并翻译&#34;&gt;#&lt;/a&gt; 3.3 快速实现 (自动识别语语言并翻译)&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 页面底部语言切换区 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;span&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;DONOTTRANSLATE&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  语言切换：&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;a&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;href&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;javascript:translate.changeLanguage(&amp;#x27;english&amp;#x27;)&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;English&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;a&lt;/span&gt;&amp;gt;&lt;/span&gt; |&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;a&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;href&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;javascript:translate.changeLanguage(&amp;#x27;japanese&amp;#x27;)&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;日本語&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;a&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;span&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;onload&lt;/span&gt; = &lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;property&#34;&gt;selectLanguageTag&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;show&lt;/span&gt; = &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;; &lt;span class=&#34;comment&#34;&gt;// 隐藏默认切换器&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;property&#34;&gt;ignore&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;id&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;DONOTTRANSLATE&amp;#x27;&lt;/span&gt;); &lt;span class=&#34;comment&#34;&gt;// 保护切换按钮不被翻译&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;title function_&#34;&gt;setAutoDiscriminateLocalLanguage&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 自动识别用户语种&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;property&#34;&gt;listener&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;start&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 监听动态内容&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h3 id=&#34;34-性能优化与调试技巧&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#34-性能优化与调试技巧&#34;&gt;#&lt;/a&gt; 3.4 性能优化与调试技巧&lt;/h3&gt;
&lt;h4 id=&#34;1-按需翻译&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-按需翻译&#34;&gt;#&lt;/a&gt; 1. 按需翻译&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 仅翻译特定区块&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;title function_&#34;&gt;execute&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;selector&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;#main-content, .article-text&amp;#x27;&lt;/span&gt; &lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h4 id=&#34;2-网络优化&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2-网络优化&#34;&gt;#&lt;/a&gt; 2. 网络优化&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 启用CDN加速&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;service&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;use&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;client.cdn&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h4 id=&#34;3-错误捕获&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#3-错误捕获&#34;&gt;#&lt;/a&gt; 3. 错误捕获&lt;/h4&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;title function_&#34;&gt;on&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;error&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;err&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;variable language_&#34;&gt;console&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;error&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;翻译失败:&amp;#x27;&lt;/span&gt;, err.&lt;span class=&#34;property&#34;&gt;message&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;title function_&#34;&gt;fallbackToStaticText&lt;/span&gt;(); &lt;span class=&#34;comment&#34;&gt;// 切换备用方案&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;五-扩展阅读与参考资料&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#五-扩展阅读与参考资料&#34;&gt;#&lt;/a&gt; 五、扩展阅读与参考资料&lt;/h2&gt;
&lt;h3 id=&#34;translatejs-补充教程详细&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#translatejs-补充教程详细&#34;&gt;#&lt;/a&gt; translate.js 补充教程 (详细)&lt;/h3&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;第一章基础集成与配置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一章基础集成与配置&#34;&gt;#&lt;/a&gt; 第一章：基础集成与配置&lt;/h4&gt;
&lt;h5 id=&#34;11-环境搭建与快速启动&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#11-环境搭建与快速启动&#34;&gt;#&lt;/a&gt; 1.1 环境搭建与快速启动&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 标准集成模式 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;src&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;https://cdn.staticfile.net/translate.js/3.12.0/translate.js&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// 设置本地语种为简体中文（影响自动识别逻辑）&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;property&#34;&gt;language&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;setLocal&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;chinese_simplified&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// 使用边缘计算翻译通道（默认服务节点）&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;property&#34;&gt;service&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;use&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;client.edge&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// 初始化后立即执行首次翻译&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;  translate.&lt;span class=&#34;title function_&#34;&gt;execute&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;技术细节&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;使用  &lt;code&gt;setLocal()&lt;/code&gt;  方法声明源语言类型，支持 87 种 ISO 标准语言代码&lt;/li&gt;
&lt;li&gt;&lt;code&gt;client.edge&lt;/code&gt;  模式采用分布式 CDN 节点，平均响应时间 &amp;lt;200ms&lt;/li&gt;
&lt;li&gt;自动执行 DOM 扫描，遍历所有文本节点并建立翻译索引&lt;/li&gt;
&lt;/ul&gt;
&lt;h5 id=&#34;12-服务通道配置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#12-服务通道配置&#34;&gt;#&lt;/a&gt; 1.2 服务通道配置&lt;/h5&gt;
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;通道类型&lt;/th&gt;
&lt;th&gt;代码示例&lt;/th&gt;
&lt;th&gt;适用场景&lt;/th&gt;
&lt;th&gt;并发限制&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;公有云基础版&lt;/td&gt;
&lt;td&gt;&lt;code&gt;translate.service.use(&#39;client.basic&#39;)&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;个人博客 / 小型站点&lt;/td&gt;
&lt;td&gt;100 次 / 分钟&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;边缘计算加速版&lt;/td&gt;
&lt;td&gt;&lt;code&gt;translate.service.use(&#39;client.edge&#39;)&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;企业官网 / 中等流量&lt;/td&gt;
&lt;td&gt;无限制&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;私有化部署版&lt;/td&gt;
&lt;td&gt;&lt;code&gt;translate.service.use(&#39;http://your-api&#39;)&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;金融 / 医疗等敏感行业&lt;/td&gt;
&lt;td&gt;自定义&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;企业专线版&lt;/td&gt;
&lt;td&gt;&lt;code&gt;translate.service.use(&#39;enterprise.pro&#39;)&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;跨国业务 / 高 SLA 要求&lt;/td&gt;
&lt;td&gt;无限制&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;&lt;strong&gt;注意事项&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;私有化部署需配置  &lt;code&gt;translate.request.headers.set(&#39;X-Auth-Key&#39;, &#39;xxx&#39;)&lt;/code&gt;  认证&lt;/li&gt;
&lt;li&gt;企业版需联系官方开通，支持双向 TLS 加密传输&lt;/li&gt;
&lt;/ul&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;第二章核心功能开发&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二章核心功能开发&#34;&gt;#&lt;/a&gt; 第二章：核心功能开发&lt;/h4&gt;
&lt;h5 id=&#34;21-动态内容处理&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#21-动态内容处理&#34;&gt;#&lt;/a&gt; 2.1 动态内容处理&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 开启实时监控（适用于 Vue/React）&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;listener&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;start&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;interval&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;300&lt;/span&gt;, &lt;span class=&#34;comment&#34;&gt;// DOM 检查间隔（ms）&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;depth&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;5&lt;/span&gt;       &lt;span class=&#34;comment&#34;&gt;// 监控嵌套层级&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 自定义忽略规则&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;ignore&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;property&#34;&gt;id&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;ad-container&amp;#x27;&lt;/span&gt;)      &lt;span class=&#34;comment&#34;&gt;// 忽略指定 ID&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;property&#34;&gt;class&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;no-translate&amp;#x27;&lt;/span&gt;)   &lt;span class=&#34;comment&#34;&gt;// 忽略指定 class&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;property&#34;&gt;tag&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;code&amp;#x27;&lt;/span&gt;)             &lt;span class=&#34;comment&#34;&gt;// 忽略代码块&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;property&#34;&gt;text&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;push&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;OpenAI&amp;#x27;&lt;/span&gt;)          &lt;span class=&#34;comment&#34;&gt;// 保留专有名词&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;property&#34;&gt;attr&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;add&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;data-translate&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;false&amp;#x27;&lt;/span&gt;); &lt;span class=&#34;comment&#34;&gt;// 自定义属性标记&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;优化策略&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;使用 MutationObserver 实现增量更新，避免全量扫描&lt;/li&gt;
&lt;li&gt;通过  &lt;code&gt;translate.refresh(element)&lt;/code&gt;  手动刷新指定区域&lt;/li&gt;
&lt;/ul&gt;
&lt;h5 id=&#34;22-术语库管理&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#22-术语库管理&#34;&gt;#&lt;/a&gt; 2.2 术语库管理&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 静态术语配置&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;term&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;GPT-4&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;生成式预训练模型4.0&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;CEO&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;首席执行官&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 动态加载术语库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/dict/custom.json&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;title function_&#34;&gt;then&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;res&lt;/span&gt; =&amp;gt;&lt;/span&gt; res.&lt;span class=&#34;title function_&#34;&gt;json&lt;/span&gt;())&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  .&lt;span class=&#34;title function_&#34;&gt;then&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;data&lt;/span&gt; =&amp;gt;&lt;/span&gt; translate.&lt;span class=&#34;property&#34;&gt;term&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;merge&lt;/span&gt;(data));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 术语优先级配置&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;term&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;priority&lt;/span&gt; = &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;user&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;100&lt;/span&gt;,    &lt;span class=&#34;comment&#34;&gt;// 用户自定义术语&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;system&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;50&lt;/span&gt;    &lt;span class=&#34;comment&#34;&gt;// 系统预设术语&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;高级特性&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;支持正则表达式匹配： &lt;code&gt;translate.term.set(&amp;#123; &#39;/d&amp;#123;4&amp;#125;-d&amp;#123;2&amp;#125;/&#39;: &#39;日期格式&#39; &amp;#125;)&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;提供术语版本控制接口  &lt;code&gt;translate.term.version = &#39;v2.1&#39;&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;h5 id=&#34;23-混合翻译模式&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#23-混合翻译模式&#34;&gt;#&lt;/a&gt; 2.3 混合翻译模式&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 启用本地缓存翻译&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;cache&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;enable&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;ttl&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;86400&lt;/span&gt;,        &lt;span class=&#34;comment&#34;&gt;// 缓存有效期（秒）&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;strategy&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;stale&amp;#x27;&lt;/span&gt;  &lt;span class=&#34;comment&#34;&gt;// 过期后仍使用旧数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 配置离线词库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;offline&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;load&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;hello&amp;#x27;&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;string&#34;&gt;&amp;#x27;zh-CN&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;你好&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;string&#34;&gt;&amp;#x27;ja-JP&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;こんにちは&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 优先级策略设置&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;strategy&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;hybrid&amp;#x27;&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;order&lt;/span&gt;: [&lt;span class=&#34;string&#34;&gt;&amp;#x27;cache&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;offline&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;api&amp;#x27;&lt;/span&gt;]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;性能对比&lt;/strong&gt;：&lt;/p&gt;
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;模式&lt;/th&gt;
&lt;th&gt;首屏加载&lt;/th&gt;
&lt;th&gt;二次加载&lt;/th&gt;
&lt;th&gt;网络依赖&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;纯 API&lt;/td&gt;
&lt;td&gt;1200ms&lt;/td&gt;
&lt;td&gt;800ms&lt;/td&gt;
&lt;td&gt;是&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;混合模式&lt;/td&gt;
&lt;td&gt;1500ms&lt;/td&gt;
&lt;td&gt;200ms&lt;/td&gt;
&lt;td&gt;部分&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;纯离线&lt;/td&gt;
&lt;td&gt;300ms&lt;/td&gt;
&lt;td&gt;50ms&lt;/td&gt;
&lt;td&gt;否&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;第三章企业级部署方案&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三章企业级部署方案&#34;&gt;#&lt;/a&gt; 第三章：企业级部署方案&lt;/h4&gt;
&lt;h5 id=&#34;31-私有化架构设计&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#31-私有化架构设计&#34;&gt;#&lt;/a&gt; 3.1 私有化架构设计&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight bash&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;# 部署翻译引擎&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;docker run -d \&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  -p 8080:80 \&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  -v /data/translate:/app/data \&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  translate/service:enterprise&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;# 配置负载均衡&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;upstream translate_cluster &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  server 10.0.0.1:8080 weight=5;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  server 10.0.0.2:8080 weight=3;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  server 10.0.0.3:8080 weight=2;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;安全方案&lt;/strong&gt;：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;传输层：TLS 1.3 + 双向证书认证&lt;/li&gt;
&lt;li&gt;数据层：AES-256-GCM 端到端加密&lt;/li&gt;
&lt;li&gt;审计层：全量操作日志记录&lt;/li&gt;
&lt;/ul&gt;
&lt;h5 id=&#34;32-高可用性配置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#32-高可用性配置&#34;&gt;#&lt;/a&gt; 3.2 高可用性配置&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 客户端故障转移策略&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;service&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;fallback&lt;/span&gt; = [&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;https://node1.your-domain.com&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;https://node2.your-domain.com&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;string&#34;&gt;&amp;#x27;client.edge&amp;#x27;&lt;/span&gt; &lt;span class=&#34;comment&#34;&gt;// 公有云兜底&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 服务端健康检查&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;setInterval&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/health&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    .&lt;span class=&#34;title function_&#34;&gt;then&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;res&lt;/span&gt; =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!res.&lt;span class=&#34;property&#34;&gt;ok&lt;/span&gt;) &lt;span class=&#34;title class_&#34;&gt;Kubernetes&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;restartPod&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;translate-service&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;, &lt;span class=&#34;number&#34;&gt;60000&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;SLA 指标&lt;/strong&gt;：&lt;/p&gt;
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;指标&lt;/th&gt;
&lt;th&gt;目标值&lt;/th&gt;
&lt;th&gt;监控方式&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;可用性&lt;/td&gt;
&lt;td&gt;99.99%&lt;/td&gt;
&lt;td&gt;Prometheus&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;平均延迟&lt;/td&gt;
&lt;td&gt;&amp;lt;300ms&lt;/td&gt;
&lt;td&gt;Elastic APM&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;错误率&lt;/td&gt;
&lt;td&gt;&amp;lt;0.1%&lt;/td&gt;
&lt;td&gt;Sentry&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;并发容量&lt;/td&gt;
&lt;td&gt;10,000/s&lt;/td&gt;
&lt;td&gt;LoadRunner&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;第四章高级开发技巧&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第四章高级开发技巧&#34;&gt;#&lt;/a&gt; 第四章：高级开发技巧&lt;/h4&gt;
&lt;h5 id=&#34;41-自定义渲染引擎&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#41-自定义渲染引擎&#34;&gt;#&lt;/a&gt; 4.1 自定义渲染引擎&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;CustomRenderer&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;extends&lt;/span&gt; &lt;span class=&#34;title class_ inherited__&#34;&gt;translate.Renderer&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;title function_&#34;&gt;onTextNode&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;node, translation&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (node.&lt;span class=&#34;property&#34;&gt;parentNode&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;tagName&lt;/span&gt; === &lt;span class=&#34;string&#34;&gt;&amp;#x27;H1&amp;#x27;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;`&amp;lt;span class=&amp;quot;highlight&amp;quot;&amp;gt;&lt;span class=&#34;subst&#34;&gt;$&amp;#123;translation&amp;#125;&lt;/span&gt;&amp;lt;/span&amp;gt;`&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; translation;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;renderer&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;use&lt;/span&gt;(&lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;CustomRenderer&lt;/span&gt;());&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h5 id=&#34;42-翻译流水线扩展&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#42-翻译流水线扩展&#34;&gt;#&lt;/a&gt; 4.2 翻译流水线扩展&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 添加预处理插件&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;pipeline&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;before&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;translate&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;text, context&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; text.&lt;span class=&#34;title function_&#34;&gt;replace&lt;/span&gt;(&lt;span class=&#34;regexp&#34;&gt;/\b\d&amp;#123;4&amp;#125;\b/g&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;lt;year&amp;gt;&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 添加后处理插件&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;pipeline&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;after&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;translate&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;text, context&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; text.&lt;span class=&#34;title function_&#34;&gt;replace&lt;/span&gt;(&lt;span class=&#34;regexp&#34;&gt;/&amp;lt;year&amp;gt;/g&lt;/span&gt;, &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Date&lt;/span&gt;().&lt;span class=&#34;title function_&#34;&gt;getFullYear&lt;/span&gt;());&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h5 id=&#34;43-多模态翻译&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#43-多模态翻译&#34;&gt;#&lt;/a&gt; 4.3 多模态翻译&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 图片OCR翻译&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;image&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;translator&lt;/span&gt; = &lt;span class=&#34;title function_&#34;&gt;async&lt;/span&gt; (imgElement) =&amp;gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; text = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;OCR&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;detect&lt;/span&gt;(imgElement.&lt;span class=&#34;property&#34;&gt;src&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; translate.&lt;span class=&#34;title function_&#34;&gt;execute&lt;/span&gt;(text);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 视频字幕处理&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;video&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;handle&lt;/span&gt; = &lt;span class=&#34;function&#34;&gt;(&lt;span class=&#34;params&#34;&gt;videoElement&lt;/span&gt;) =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; tracks = videoElement.&lt;span class=&#34;property&#34;&gt;textTracks&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  tracks.&lt;span class=&#34;title function_&#34;&gt;forEach&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;track&lt;/span&gt; =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    translate.&lt;span class=&#34;property&#34;&gt;subtitle&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;process&lt;/span&gt;(track);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;第五章调试与优化&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第五章调试与优化&#34;&gt;#&lt;/a&gt; 第五章：调试与优化&lt;/h4&gt;
&lt;h5 id=&#34;51-性能分析工具&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#51-性能分析工具&#34;&gt;#&lt;/a&gt; 5.1 性能分析工具&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 开启性能监控&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;monitor&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;enable&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;metrics&lt;/span&gt;: [&lt;span class=&#34;string&#34;&gt;&amp;#x27;dom-parse&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;network&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;render&amp;#x27;&lt;/span&gt;],&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;sampling&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0.1&lt;/span&gt; &lt;span class=&#34;comment&#34;&gt;// 10%采样率&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 自定义性能指标&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;monitor&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;define&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;custom-metric&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; performance.&lt;span class=&#34;title function_&#34;&gt;now&lt;/span&gt;() - &lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;translateStart&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h5 id=&#34;52-内存优化方案&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#52-内存优化方案&#34;&gt;#&lt;/a&gt; 5.2 内存优化方案&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 分块加载策略&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;chunk&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;500&lt;/span&gt;, &lt;span class=&#34;comment&#34;&gt;// 每块500字符&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;parallel&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;3&lt;/span&gt; &lt;span class=&#34;comment&#34;&gt;// 最大并发数&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// DOM 回收机制&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;translate.&lt;span class=&#34;property&#34;&gt;garbageCollector&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;run&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;interval&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;30000&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;policy&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;aggressive&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h4 id=&#34;结语&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#结语&#34;&gt;#&lt;/a&gt; 结语&lt;/h4&gt;
&lt;p&gt;您还可以可通过 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9yZXMuenZvLmNuL3RyYW5zbGF0ZS9kZW1vLmh0bWw=&#34;&gt;官方演示站点&lt;/span&gt; 体验完整功能，更多企业级方案请参考 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRlZS5jb20vbWFpbF9vc2MvdHJhbnNsYXRl&#34;&gt;Gitee 仓库&lt;/span&gt;。&lt;/p&gt;
&lt;h3 id=&#34;参考资料&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#参考资料&#34;&gt;#&lt;/a&gt; 参考资料&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cDovL3RyYW5zbGF0ZS56dm8uY24vNDMwODYuaHRtbA==&#34;&gt;translate.js 官方文档: http://translate.zvo.cn/43086.html&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jbG91ZC5nb29nbGUuY29tL3RyYW5zbGF0ZQ==&#34;&gt;谷歌翻译私有化部署指南: https://cloud.google.com/translate&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9kZXZlbG9wZXJzLmdvb2dsZS5jb20vc2VhcmNoL2RvY3MvYWR2YW5jZWQvY3Jhd2xpbmcvbWFuYWdpbmctbXVsdGktcmVnaW9uYWwtc2l0ZXM=&#34;&gt;多语言 SEO 优化策略: https://developers.google.com/search/docs/advanced/crawling/managing-multi-regional-sites&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;hr /&gt;
&lt;p&gt;&lt;strong&gt;提示&lt;/strong&gt;：访问 &lt;a href=&#34;https://jdjwzx233.cn&#34;&gt;本站： jdjwzx233.cn&lt;/a&gt; 点击页面底部语言切换按钮，可实时体验 translate.js 的实际效果。&lt;/p&gt;
&lt;h2 id=&#34;结尾&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#结尾&#34;&gt;#&lt;/a&gt; 结尾&lt;/h2&gt;
&lt;p&gt;非常感谢你能看到这里，如有什么问题欢迎在评论区中提出！如果可以的话，请订阅我的网站：&lt;a href=&#34;https://jdjwzx233.cn/Subscribe&#34;&gt;https://jdjwzx233.cn/Subscribe&lt;/a&gt;&lt;br /&gt;
 如果你觉得我的博客不错的话，可以赞助我 (・̀ ω・́)✧：&lt;a href=&#34;https://jdjwzx233.cn/support&#34;&gt;https://jdjwzx233.cn/support&lt;/a&gt;。&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="网络" scheme="https://jdjwzx233.cn/categories/%E7%BD%91%E7%BB%9C/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="网络" scheme="https://jdjwzx233.cn/tags/%E7%BD%91%E7%BB%9C/" />
        <category term="Web" scheme="https://jdjwzx233.cn/tags/Web/" />
        <category term="自动翻译" scheme="https://jdjwzx233.cn/tags/%E8%87%AA%E5%8A%A8%E7%BF%BB%E8%AF%91/" />
        <category term="前端" scheme="https://jdjwzx233.cn/tags/%E5%89%8D%E7%AB%AF/" />
        <category term="计算机科学" scheme="https://jdjwzx233.cn/tags/%E8%AE%A1%E7%AE%97%E6%9C%BA%E7%A7%91%E5%AD%A6/" />
        <category term="网站翻译" scheme="https://jdjwzx233.cn/tags/%E7%BD%91%E7%AB%99%E7%BF%BB%E8%AF%91/" />
        <category term="原创" scheme="https://jdjwzx233.cn/tags/%E5%8E%9F%E5%88%9B/" />
        <updated>2025-05-01T13:59:42.795Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2024/09/17/%E4%BD%BF%E7%94%A8Netlify%E6%90%AD%E5%BB%BA%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86/</id>
        <title>使用Netlify搭建反向代理</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2024/09/17/%E4%BD%BF%E7%94%A8Netlify%E6%90%AD%E5%BB%BA%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86/"/>
        <content type="html">&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;&lt;strong&gt;1. 免责声明&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;在撰写本文时，我旨在为技术爱好者提供有关如何使用 Netlify 搭建反向代理的技术指导和示例。请注意，本文中的信息和建议仅供参考，具体实施可能会因实际情况而有所不同。使用本文提供的方法和步骤时，请确保遵循当地法律法规，并充分考虑网络安全和数据保护的要求。&lt;/p&gt;
&lt;p&gt;本文作者和发布平台对因使用本文内容而导致的任何直接或间接损失、损害或法律责任不承担任何责任。建议在实施任何技术方案之前，进行充分的测试和风险评估，并寻求专业意见，以确保符合适用的法律和行业标准。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;2. 合法用途声明&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;请遵守相关法律法规，包括但不限于《中华人民共和国网络安全法》和《互联网信息服务管理办法》。请确保在使用 Netlify 或其他服务时：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;合法合规&lt;/strong&gt;：确保所搭建的反向代理不用于违反法律法规的活动，包括但不限于绕过审查、非法数据传输、或其他违法用途。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;尊重版权和隐私&lt;/strong&gt;：遵守版权法律，确保所代理的内容不侵犯第三方的知识产权。同时，保障用户隐私，遵循数据保护的相关要求。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;网络安全&lt;/strong&gt;：采取必要的安全措施，防止反向代理服务被用于恶意目的，保障系统和用户数据的安全。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;信息透明&lt;/strong&gt;：确保提供的服务信息清晰透明，用户可以明确知晓反向代理的用途和可能的风险。&lt;/li&gt;
&lt;/ol&gt;
&lt;/div&gt;
&lt;h2 id=&#34;前言摘要&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#前言摘要&#34;&gt;#&lt;/a&gt; 前言 / 摘要&lt;/h2&gt;
&lt;p&gt;在当今互联网环境下，尤其是部分国外和国内网站常常由于 DNS 污染和其他原因而无法正常访问，这成为了许多用户的一大困扰。此外，有些网站虽然仅能通过 IP 地址进行访问，却无法绑定自定义域名，这同样限制了其灵活性和可用性。为了解决这些问题，搭建一个反向代理服务器成为了一个有效的解决方案。反向代理不仅可以帮助用户绕过 DNS 污染的问题，还能让我们以自定义的域名来访问那些仅能通过 IP 地址访问的网站。&lt;/p&gt;
&lt;p&gt;在本篇文章中，我们将利用 Netlify 这一强大而易于使用的工具来搭建反向代理。Netlify 的强大之处在于其简洁的配置过程和强大的功能，使得即使是对技术不太熟悉的用户也能轻松上手。要完成这项任务，你只需具备两个基本条件：一个 Netlify 账号和一个 GitHub 账号。接下来，我们将详细介绍如何通过这两个账户配置反向代理。&lt;/p&gt;
&lt;h2 id=&#34;正文&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#正文&#34;&gt;#&lt;/a&gt; 正文&lt;/h2&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;&lt;strong&gt;温馨提示&lt;/strong&gt;&lt;br /&gt;
标题后面有 (选) 的为后台相关内容，如不需要可以跳过&lt;/p&gt;
&lt;/div&gt;
&lt;h3 id=&#34;第一步-准备用于搭建反代的环境&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步-准备用于搭建反代的环境&#34;&gt;#&lt;/a&gt; 第一步 准备用于搭建反代的环境&lt;/h3&gt;
&lt;h4 id=&#34;1-创建储存库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-创建储存库&#34;&gt;#&lt;/a&gt; 1. 创建储存库&lt;/h4&gt;
&lt;p&gt;创建一个用于存放 Netlify 配置文件的 GitHub 储存库&lt;/p&gt;
&lt;p&gt;如图:&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/1726582387299_23298110f4e294999cce8e5ddb9919ed.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/1726582387299_23298110f4e294999cce8e5ddb9919ed.png&#34; /&gt;&lt;/p&gt;
&lt;h4 id=&#34;2-创建配置文件&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2-创建配置文件&#34;&gt;#&lt;/a&gt; 2. 创建配置文件&lt;/h4&gt;
&lt;p&gt;新建名为  &lt;code&gt;netlify.toml&lt;/code&gt;  的配置文件&lt;/p&gt;
&lt;p&gt;如图:&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_b32990708afc79c8ac57533641e18942.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_b32990708afc79c8ac57533641e18942.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;文件内容为：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight toml&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;section&#34;&gt;[[redirects]]&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;from&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;quot;/*&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;to&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;quot;https://github.com/:splat&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;status&lt;/span&gt; = &lt;span class=&#34;number&#34;&gt;200&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h4 id=&#34;选择性内容&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#选择性内容&#34;&gt;#&lt;/a&gt; 选择性内容&lt;/h4&gt;
&lt;p&gt;再新建一个储存库，用于搭建管理后台 (选)&lt;/p&gt;
&lt;p&gt;如图:&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/1726582387299_23298110f4e294999cce8e5ddb9919ed.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/1726582387299_23298110f4e294999cce8e5ddb9919ed.png&#34; /&gt;&lt;/p&gt;
&lt;h5 id=&#34;储存库中包含的文件选&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#储存库中包含的文件选&#34;&gt;#&lt;/a&gt; 储存库中包含的文件 (选):&lt;/h5&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;│  index.html&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;│  package.json&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;│  README.md&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;│&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;└─netlify&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;　　└─functions&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;　　　　auth-callback.js&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;　　　　check-auth.js&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;　　　　update-redirect.js&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;index.html&lt;/strong&gt;：应用的主要前端页面，包含用户登录和配置反向代理的表单。(选)&lt;/li&gt;
&lt;/ol&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;&lt;strong&gt;温馨提示&lt;/strong&gt;&lt;br /&gt;
请在代码中的【这里填你的反代网站，不是后台】中填入你的反代网址 (就是用存放 Netlify 配置文件的 GitHub 储存库搭建的那个)【这里填你的 GitHub clientid】中填入你的 GitHub clientid，获取方法见下文&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;73&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;74&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;75&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;76&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;77&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;78&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;79&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;80&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;81&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;82&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;83&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;84&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;85&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;86&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;87&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;88&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;89&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;90&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;91&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;92&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;93&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;94&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;95&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;96&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;97&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;98&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;99&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;100&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;101&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;102&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;103&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;104&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;105&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;106&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;107&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;108&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;109&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;110&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;111&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;112&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;113&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;114&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;115&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;116&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;117&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;118&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;119&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;120&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;121&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;122&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;123&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;124&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;125&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;126&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;127&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;128&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;129&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;130&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;131&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;132&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;133&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;134&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;135&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;136&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;137&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;138&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;139&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;140&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;141&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;142&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;143&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;144&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;145&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;146&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;147&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;148&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;149&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;150&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;151&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;152&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;153&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;154&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;155&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;156&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;157&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;158&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;159&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;160&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;161&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;162&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;163&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;164&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;165&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;166&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;167&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;168&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;169&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;170&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;171&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;172&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;173&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;174&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;175&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;176&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;177&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;178&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;179&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;180&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;181&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;182&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;183&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;184&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;185&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;186&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;187&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;188&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;189&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;190&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;191&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;192&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;193&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;194&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;195&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;196&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;197&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;198&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;199&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;200&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;201&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;202&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;203&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;204&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;205&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;206&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;207&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;208&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;209&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;210&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;211&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;212&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;213&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;214&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;215&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;216&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;217&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;218&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;219&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;220&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;221&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;222&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;223&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;224&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;225&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;226&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;227&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;228&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;229&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;230&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;231&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;232&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;233&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;234&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;235&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;236&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;237&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;238&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;239&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;240&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;241&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;242&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;243&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;&amp;lt;!DOCTYPE &lt;span class=&#34;keyword&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;lang&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;zh&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;meta&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;charset&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;UTF-8&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;meta&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;name&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;viewport&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;content&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;width=device-width, initial-scale=1.0&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;反代配置&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;style&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;body&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-family&lt;/span&gt;: Arial, sans-serif;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background&lt;/span&gt;: &lt;span class=&#34;built_in&#34;&gt;linear-gradient&lt;/span&gt;(to bottom, &lt;span class=&#34;number&#34;&gt;#87CEFA&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;#FFFFFF&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;display&lt;/span&gt;: flex;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;justify-content&lt;/span&gt;: center;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;align-items&lt;/span&gt;: center;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;height&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;100vh&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;overflow-x&lt;/span&gt;: hidden;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.container&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;text-align&lt;/span&gt;: center;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;width&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;90%&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;max-width&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;500px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;h1&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#333&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-bottom&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1.8em&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;form&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#f9f9f9&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-radius&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;15px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;box-shadow&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;4px&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;8px&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;rgba&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0.1&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;transition&lt;/span&gt;: transform &lt;span class=&#34;number&#34;&gt;0.3s&lt;/span&gt; ease-in-out;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;form&lt;/span&gt;&lt;span class=&#34;selector-pseudo&#34;&gt;:hover&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;transform&lt;/span&gt;: &lt;span class=&#34;built_in&#34;&gt;scale&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;1.02&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;label&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1.2em&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;display&lt;/span&gt;: block;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-bottom&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;10px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#555&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;input&lt;/span&gt;&lt;span class=&#34;selector-attr&#34;&gt;[type=&lt;span class=&#34;string&#34;&gt;&amp;quot;url&amp;quot;&lt;/span&gt;]&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;width&lt;/span&gt;: &lt;span class=&#34;built_in&#34;&gt;calc&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;100%&lt;/span&gt; - &lt;span class=&#34;number&#34;&gt;22px&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;10px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-radius&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;8px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1px&lt;/span&gt; solid &lt;span class=&#34;number&#34;&gt;#ddd&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-bottom&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1em&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;box-sizing&lt;/span&gt;: border-box;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;button&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#87CEFA&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: white;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border&lt;/span&gt;: none;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;10px&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-radius&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;8px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;cursor&lt;/span&gt;: pointer;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1.1em&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;transition&lt;/span&gt;: background-color &lt;span class=&#34;number&#34;&gt;0.3s&lt;/span&gt; ease-in-out;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-tag&#34;&gt;button&lt;/span&gt;&lt;span class=&#34;selector-pseudo&#34;&gt;:hover&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#00BFFF&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-id&#34;&gt;#message&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;font-size&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1.2em&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#333&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-top&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.error-container&lt;/span&gt;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.success-container&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;display&lt;/span&gt;: none;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#f0f8ff&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1px&lt;/span&gt; solid &lt;span class=&#34;number&#34;&gt;#d4edda&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-radius&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;8px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-top&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;20px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;box-shadow&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;4px&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;8px&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;rgba&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0.1&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;text-align&lt;/span&gt;: center;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.error-container&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#f5c6cb&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#f8d7da&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#721c24&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.success-container&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#c3e6cb&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#d4edda&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#155724&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.error-container&lt;/span&gt; &lt;span class=&#34;selector-tag&#34;&gt;p&lt;/span&gt;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.success-container&lt;/span&gt; &lt;span class=&#34;selector-tag&#34;&gt;p&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.success-container&lt;/span&gt; &lt;span class=&#34;selector-tag&#34;&gt;button&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-top&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;10px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#4CAF50&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border&lt;/span&gt;: none;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.success-container&lt;/span&gt; &lt;span class=&#34;selector-tag&#34;&gt;button&lt;/span&gt;&lt;span class=&#34;selector-pseudo&#34;&gt;:hover&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#45a049&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.tooltip&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;position&lt;/span&gt;: relative;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;display&lt;/span&gt;: inline-block;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;cursor&lt;/span&gt;: pointer;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.tooltip&lt;/span&gt; &lt;span class=&#34;selector-class&#34;&gt;.tooltiptext&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;visibility&lt;/span&gt;: hidden;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;width&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;200px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;background-color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#333&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;color&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;#fff&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;text-align&lt;/span&gt;: center;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;border-radius&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;6px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;padding&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;5px&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;10px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;position&lt;/span&gt;: absolute;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;z-index&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;bottom&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;125%&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;left&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;50%&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;margin-left&lt;/span&gt;: -&lt;span class=&#34;number&#34;&gt;100px&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;opacity&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;transition&lt;/span&gt;: opacity &lt;span class=&#34;number&#34;&gt;0.3s&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-class&#34;&gt;.tooltip&lt;/span&gt;&lt;span class=&#34;selector-pseudo&#34;&gt;:hover&lt;/span&gt; &lt;span class=&#34;selector-class&#34;&gt;.tooltiptext&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;visibility&lt;/span&gt;: visible;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;opacity&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &lt;span class=&#34;selector-id&#34;&gt;#loginContainer&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;            &lt;span class=&#34;attribute&#34;&gt;display&lt;/span&gt;: none;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-css&#34;&gt;    &lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;style&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;container&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;h1&lt;/span&gt;&amp;gt;&lt;/span&gt;反代配置器&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;h1&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;loginContainer&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;请登录以访问此页面。&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;loginButton&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;使用 GitHub 登录&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;redirectForm&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;style&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;display: none;&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;tooltip&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;label&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;for&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;website&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;请输入要反代到的网址：&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;label&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;span&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;tooltiptext&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;请输入完整的 URL 地址，例如 https://example.com&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;span&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;input&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;url&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;website&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;name&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;website&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;required&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;submit&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;提交&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;errorMessage&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;error-container&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;errorStatusMessage&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;successMessage&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;success-container&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;successStatusMessage&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;redirectButton&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;style&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;display: none;&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;前往反代网站&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;checkAuthentication&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; response = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/.netlify/functions/check-auth&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; result = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; response.&lt;span class=&#34;title function_&#34;&gt;json&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (result.&lt;span class=&#34;property&#34;&gt;authenticated&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;loginContainer&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;none&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;redirectForm&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;loginContainer&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;redirectForm&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;none&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;loginButton&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;addEventListener&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;click&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;location&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;href&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;`https://github.com/login/oauth/authorize?client_id=【这里填你的GitHub clientid】&amp;amp;redirect_uri=&lt;span class=&#34;subst&#34;&gt;$&amp;#123;&lt;span class=&#34;built_in&#34;&gt;encodeURIComponent&lt;/span&gt;(&lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.location.origin + &lt;span class=&#34;string&#34;&gt;&amp;#x27;/.netlify/functions/auth-callback&amp;#x27;&lt;/span&gt;)&amp;#125;&lt;/span&gt;`&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;redirectForm&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;addEventListener&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;submit&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;title function_&#34;&gt;async&lt;/span&gt; (event) =&amp;gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            event.&lt;span class=&#34;title function_&#34;&gt;preventDefault&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; website = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;website&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;property&#34;&gt;value&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; urlPattern = &lt;span class=&#34;regexp&#34;&gt;/^https?:\/\/[^\/]+$/&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; errorMessageElement = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;errorStatusMessage&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; successMessageElement = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;successStatusMessage&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; errorContainer = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;errorMessage&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; successContainer = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;successMessage&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; redirectButton = &lt;span class=&#34;variable language_&#34;&gt;document&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getElementById&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;redirectButton&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!urlPattern.&lt;span class=&#34;title function_&#34;&gt;test&lt;/span&gt;(website)) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; suggestion = website.&lt;span class=&#34;title function_&#34;&gt;replace&lt;/span&gt;(&lt;span class=&#34;regexp&#34;&gt;/\/+$/&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                errorMessageElement.&lt;span class=&#34;property&#34;&gt;innerText&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;`输入的 URL 格式不正确。请确保网址以 &amp;#x27;https://example.com&amp;#x27; 形式输入。你可能的正确输入是：&lt;span class=&#34;subst&#34;&gt;$&amp;#123;suggestion&amp;#125;&lt;/span&gt;`&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                errorContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                successContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;none&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; response = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/.netlify/functions/update-redirect&amp;#x27;&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;method&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;POST&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                    &lt;span class=&#34;string&#34;&gt;&amp;#x27;Content-Type&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;application/json&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; website &amp;#125;)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; result = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; response.&lt;span class=&#34;title function_&#34;&gt;json&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (result.&lt;span class=&#34;property&#34;&gt;message&lt;/span&gt; === &lt;span class=&#34;string&#34;&gt;&amp;#x27;Redirect updated successfully!&amp;#x27;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                successMessageElement.&lt;span class=&#34;property&#34;&gt;innerText&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;反代配置成功！请等待服务器更新，预计1分钟。&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                successContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                errorContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;none&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                redirectButton.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;inline-block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                redirectButton.&lt;span class=&#34;title function_&#34;&gt;addEventListener&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;click&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;() =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                    &lt;span class=&#34;variable language_&#34;&gt;window&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;location&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;href&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;【这里填你的反代网站，不是后台】&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                errorMessageElement.&lt;span class=&#34;property&#34;&gt;innerText&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;`配置失败：&lt;span class=&#34;subst&#34;&gt;$&amp;#123;result.message&amp;#125;&lt;/span&gt;`&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                errorContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;block&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                successContainer.&lt;span class=&#34;property&#34;&gt;style&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;display&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;none&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// Initialize the authentication check&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &lt;span class=&#34;title function_&#34;&gt;checkAuthentication&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;    &lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;2&#34;&gt;
&lt;li&gt;&lt;strong&gt;/netlify/functions/auth-callback.js&lt;/strong&gt;：处理 GitHub OAuth 回调的函数，设置用户的登录状态。(选)&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;figure class=&#34;highlight js&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;exports&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;handler&lt;/span&gt; = &lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;event, context&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; clientId = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;GITHUB_CLIENT_ID&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; clientSecret = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;GITHUB_CLIENT_SECRET&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; allowedUsers = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;ALLOWED_USERS&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;,&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwtSecret = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;JWT_SECRET&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; code = event.&lt;span class=&#34;property&#34;&gt;queryStringParameters&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;code&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!code) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Missing code parameter&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; fetch = (&lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;node-fetch&amp;#x27;&lt;/span&gt;)).&lt;span class=&#34;property&#34;&gt;default&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwt = (&lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;jsonwebtoken&amp;#x27;&lt;/span&gt;)).&lt;span class=&#34;property&#34;&gt;default&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; response = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;`https://github.com/login/oauth/access_token`&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;method&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;POST&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;string&#34;&gt;&amp;#x27;Accept&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;application/json&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;string&#34;&gt;&amp;#x27;Content-Type&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;application/json&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;client_id&lt;/span&gt;: clientId,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;client_secret&lt;/span&gt;: clientSecret,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;code&lt;/span&gt;: code&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; data = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; response.&lt;span class=&#34;title function_&#34;&gt;json&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (data.&lt;span class=&#34;property&#34;&gt;error&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;throw&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Error&lt;/span&gt;(data.&lt;span class=&#34;property&#34;&gt;error_description&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; userResponse = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;https://api.github.com/user&amp;#x27;&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;title class_&#34;&gt;Authorization&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;`token &lt;span class=&#34;subst&#34;&gt;$&amp;#123;data.access_token&amp;#125;&lt;/span&gt;`&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; userInfo = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; userResponse.&lt;span class=&#34;title function_&#34;&gt;json&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (allowedUsers.&lt;span class=&#34;title function_&#34;&gt;includes&lt;/span&gt;(userInfo.&lt;span class=&#34;property&#34;&gt;login&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; token = jwt.&lt;span class=&#34;title function_&#34;&gt;sign&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;username&lt;/span&gt;: userInfo.&lt;span class=&#34;property&#34;&gt;login&lt;/span&gt; &amp;#125;, jwtSecret, &amp;#123; &lt;span class=&#34;attr&#34;&gt;expiresIn&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;1h&amp;#x27;&lt;/span&gt; &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;302&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                    &lt;span class=&#34;string&#34;&gt;&amp;#x27;Set-Cookie&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;`token=&lt;span class=&#34;subst&#34;&gt;$&amp;#123;token&amp;#125;&lt;/span&gt;; Path=/; HttpOnly`&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                    &lt;span class=&#34;string&#34;&gt;&amp;#x27;Location&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;/&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &amp;#125;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Unauthorized&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (error) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;500&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;`Error: &lt;span class=&#34;subst&#34;&gt;$&amp;#123;error.message&amp;#125;&lt;/span&gt;`&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;3&#34;&gt;
&lt;li&gt;&lt;strong&gt;/netlify/functions/check-auth.js&lt;/strong&gt;：检查用户是否已登录的函数。(选)&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;figure class=&#34;highlight js&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;exports&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;handler&lt;/span&gt; = &lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;event, context&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwtSecret = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;JWT_SECRET&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; cookieHeader = event.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;cookie&lt;/span&gt; || &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; cookies = &lt;span class=&#34;title class_&#34;&gt;Object&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;fromEntries&lt;/span&gt;(cookieHeader.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;; &amp;#x27;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;map&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;cookie&lt;/span&gt; =&amp;gt;&lt;/span&gt; cookie.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;=&amp;#x27;&lt;/span&gt;)));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; token = cookies.&lt;span class=&#34;property&#34;&gt;token&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwt = (&lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;jsonwebtoken&amp;#x27;&lt;/span&gt;)).&lt;span class=&#34;property&#34;&gt;default&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        jwt.&lt;span class=&#34;title function_&#34;&gt;verify&lt;/span&gt;(token, jwtSecret);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;200&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;authenticated&lt;/span&gt;: &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (err) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;authenticated&lt;/span&gt;: &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;4&#34;&gt;
&lt;li&gt;&lt;strong&gt;/netlify/functions/update-redirect.js&lt;/strong&gt;：处理反向代理配置的函数。(选)&lt;/li&gt;
&lt;/ol&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;&lt;strong&gt;温馨提示&lt;/strong&gt;&lt;br /&gt;
请在代码中的【这里填入你的 GitHub 用户名】【用于存放 Netlify 配置文件的 GitHub 储存库名称】中分别填入你的 GitHub 用户名和用于存放 Netlify 配置文件的 GitHub 储存库名称，获取方法见下文&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;&lt;figure class=&#34;highlight js&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;73&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;74&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;75&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;exports&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;handler&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwtSecret = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;JWT_SECRET&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; allowedUsers = process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;ALLOWED_USERS&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;,&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; cookieHeader = event.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;cookie&lt;/span&gt; || &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; cookies = &lt;span class=&#34;title class_&#34;&gt;Object&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;fromEntries&lt;/span&gt;(cookieHeader.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;; &amp;#x27;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;map&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;cookie&lt;/span&gt; =&amp;gt;&lt;/span&gt; cookie.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;=&amp;#x27;&lt;/span&gt;)));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; token = cookies.&lt;span class=&#34;property&#34;&gt;token&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; decodedToken;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; jwt = (&lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;jsonwebtoken&amp;#x27;&lt;/span&gt;)).&lt;span class=&#34;property&#34;&gt;default&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        decodedToken = jwt.&lt;span class=&#34;title function_&#34;&gt;verify&lt;/span&gt;(token, jwtSecret);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (err) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Unauthorized&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!allowedUsers.&lt;span class=&#34;title function_&#34;&gt;includes&lt;/span&gt;(decodedToken.&lt;span class=&#34;property&#34;&gt;username&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Unauthorized&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &amp;#123; &lt;span class=&#34;title class_&#34;&gt;Octokit&lt;/span&gt; &amp;#125; = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;@octokit/rest&amp;#x27;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; octokit = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Octokit&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;attr&#34;&gt;auth&lt;/span&gt;: process.&lt;span class=&#34;property&#34;&gt;env&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;GITHUB_TOKEN&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &amp;#123; website &amp;#125; = &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;parse&lt;/span&gt;(event.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!website) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;No website provided&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; fetch = (&lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;node-fetch&amp;#x27;&lt;/span&gt;)).&lt;span class=&#34;property&#34;&gt;default&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &amp;#123; &lt;span class=&#34;attr&#34;&gt;data&lt;/span&gt;: fileData &amp;#125; = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; octokit.&lt;span class=&#34;property&#34;&gt;repos&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;getContent&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;owner&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;【这里填入你的GitHub用户名】&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;repo&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;【用于存放Netlify配置文件的GitHub储存库名称】&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;path&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;netlify.toml&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; content = &lt;span class=&#34;title class_&#34;&gt;Buffer&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;from&lt;/span&gt;(fileData.&lt;span class=&#34;property&#34;&gt;content&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;base64&amp;#x27;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;toString&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; newContent = content.&lt;span class=&#34;title function_&#34;&gt;replace&lt;/span&gt;(&lt;span class=&#34;regexp&#34;&gt;/to\s*=\s*&amp;quot;[^&amp;quot;]+&amp;quot;/&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;`to = &amp;quot;&lt;span class=&#34;subst&#34;&gt;$&amp;#123;website&amp;#125;&lt;/span&gt;/:splat&amp;quot;`&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; octokit.&lt;span class=&#34;property&#34;&gt;repos&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;createOrUpdateFileContents&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;owner&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;【这里填入你的GitHub用户名】&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;repo&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;【用于存放Netlify配置文件的GitHub储存库名称】&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;path&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;netlify.toml&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Update redirect URL&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;content&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;Buffer&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;from&lt;/span&gt;(newContent).&lt;span class=&#34;title function_&#34;&gt;toString&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;base64&amp;#x27;&lt;/span&gt;),&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;sha&lt;/span&gt;: fileData.&lt;span class=&#34;property&#34;&gt;sha&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;200&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Redirect updated successfully!&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (error) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;variable language_&#34;&gt;console&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;error&lt;/span&gt;(error);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;statusCode&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;500&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: &lt;span class=&#34;title class_&#34;&gt;JSON&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;stringify&lt;/span&gt;(&amp;#123; &lt;span class=&#34;attr&#34;&gt;message&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;Failed to update redirect&amp;#x27;&lt;/span&gt; &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;5&#34;&gt;
&lt;li&gt;&lt;strong&gt;package.json&lt;/strong&gt;：存放依赖的文件。(选)&lt;br /&gt;
&lt;figure class=&#34;highlight json&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;punctuation&#34;&gt;&amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;&amp;quot;name&amp;quot;&lt;/span&gt;&lt;span class=&#34;punctuation&#34;&gt;:&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;quot;Rcs,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;version&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;1.0&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;.0&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;description&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;A reverse proxy configurator with GitHub authentication deployed on Netlify.&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;main&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;index.js&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;scripts&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;start&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;netlify dev&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;build&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;netlify build&lt;span class=&#34;string&#34;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;dependencies&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;@octokit/rest&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;^&lt;span class=&#34;number&#34;&gt;19.0&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;.7&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;jsonwebtoken&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;^&lt;span class=&#34;number&#34;&gt;9.0&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;.2&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;node-fetch&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;^&lt;span class=&#34;number&#34;&gt;3.3&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;.2&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;devDependencies&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;netlify-cli&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;^&lt;span class=&#34;number&#34;&gt;15.0&lt;/span&gt;&lt;span class=&#34;number&#34;&gt;.0&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;engines&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    &amp;quot;&lt;/span&gt;node&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;&amp;gt;=&lt;span class=&#34;number&#34;&gt;16.&lt;/span&gt;x&lt;span class=&#34;string&#34;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;author&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;j23&lt;span class=&#34;string&#34;&gt;&amp;quot;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;  &amp;quot;&lt;/span&gt;license&lt;span class=&#34;string&#34;&gt;&amp;quot;: &amp;quot;&lt;/span&gt;MIT&lt;span class=&#34;string&#34;&gt;&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;&amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;第二步-配置netlify&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步-配置netlify&#34;&gt;#&lt;/a&gt; 第二步 配置 Netlify&lt;/h3&gt;
&lt;h4 id=&#34;1-创建一个站点&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-创建一个站点&#34;&gt;#&lt;/a&gt; 1. 创建一个站点&lt;/h4&gt;
&lt;p&gt;如图：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_24ce560b9f2dc57d0d6f51bfebae6b71.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_24ce560b9f2dc57d0d6f51bfebae6b71.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_d0c9459ade47c217db7d74d4c0dc815f.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_d0c9459ade47c217db7d74d4c0dc815f.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_ee9fc4b5245b51661e8a91a2c509c959.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_ee9fc4b5245b51661e8a91a2c509c959.png&#34; /&gt;&lt;/p&gt;
&lt;ol start=&#34;4&#34;&gt;
&lt;li&gt;选择你的用于存放 Netlify 配置文件的 GitHub 储存库&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_1f40a4eb848a567c69eee524172ba04a.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_1f40a4eb848a567c69eee524172ba04a.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/%E5%B1%8F%E5%B9%95%E6%88%AA%E5%9B%BE_17-9-2024_23297_app.netlify.com_9d63c0ed9504f5a945c156f026d8fc1f.jpeg&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/屏幕截图_17-9-2024_23297_app.netlify.com_9d63c0ed9504f5a945c156f026d8fc1f.jpeg&#34; /&gt;&lt;/p&gt;
&lt;h4 id=&#34;2配置自定义域名&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2配置自定义域名&#34;&gt;#&lt;/a&gt; 2. 配置自定义域名&lt;/h4&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_03b28a83de8ee0c91accd703fdca989d.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_03b28a83de8ee0c91accd703fdca989d.png&#34; /&gt;&lt;/p&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;自此所有基本操作已经完成，如果不需要配置后台，你只需要修改 Netlify 配置文件中的链接，就可以实现更换需要代理的网站。&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;修改内容如下 (注意！，网址格式必须为 https://example.com/，不能删去 https:// 也不能删去最后的 /)：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight toml&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;section&#34;&gt;[[redirects]]&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;from&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;quot;/*&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;to&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;quot;【修改这里】:splat&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;status&lt;/span&gt; = &lt;span class=&#34;number&#34;&gt;200&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h3 id=&#34;选择性内容-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#选择性内容-2&#34;&gt;#&lt;/a&gt; 选择性内容&lt;/h3&gt;
&lt;h4 id=&#34;一github-登录&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#一github-登录&#34;&gt;#&lt;/a&gt; 一.GitHub 登录&lt;/h4&gt;
&lt;p&gt;使用 GitHub 进行 OAuth 登录，确保只有授权用户可以访问配置功能。&lt;/p&gt;
&lt;h5 id=&#34;第一步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步&#34;&gt;#&lt;/a&gt; 第一步：&lt;/h5&gt;
&lt;p&gt;打开下面网址，并填好配置&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRodWIuY29tL3NldHRpbmdzL2FwcGxpY2F0aW9ucy9uZXc=&#34;&gt; https://github.com/settings/applications/new&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_08ba52609ba4bfe62f2563933cbba566.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_08ba52609ba4bfe62f2563933cbba566.png&#34; /&gt;&lt;/p&gt;
&lt;h5 id=&#34;第二步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步&#34;&gt;#&lt;/a&gt; 第二步:&lt;/h5&gt;
&lt;p&gt;获取 Client ID，并生成 Client secrets，后面要用&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_038e6d1208bd8e0990b3b595a40f256e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_038e6d1208bd8e0990b3b595a40f256e.png&#34; /&gt;&lt;br /&gt;
2.&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_0572103207489f7a3ae48fd3a3e2a2b6.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_0572103207489f7a3ae48fd3a3e2a2b6.png&#34; /&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;&lt;strong&gt;警告！&lt;/strong&gt;&lt;br /&gt;
请妥善保管好你的 Client secrets！&lt;/p&gt;
&lt;/div&gt;
&lt;h4 id=&#34;二配置用于修改储存库的密钥&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#二配置用于修改储存库的密钥&#34;&gt;#&lt;/a&gt; 二。配置用于修改储存库的密钥&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;打开下面的网址&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRodWIuY29tL3NldHRpbmdzL3Rva2Vucw==&#34;&gt; https://github.com/settings/tokens&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_29ac6da4b073ffc18764a3748bcc885a.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_29ac6da4b073ffc18764a3748bcc885a.png&#34; /&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;填入相关内容，选择不过期，勾选储存库&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_bdfead6a17b8cdf05219e9ae7e9bd799.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_bdfead6a17b8cdf05219e9ae7e9bd799.png&#34; /&gt;&lt;/p&gt;
&lt;ol start=&#34;3&#34;&gt;
&lt;li&gt;获取到密钥&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_56563b4d40ebd00c25c2ddbc0aea9565.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_56563b4d40ebd00c25c2ddbc0aea9565.png&#34; /&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;&lt;strong&gt;警告！&lt;/strong&gt;&lt;br /&gt;
请妥善保管好你的密钥&lt;/p&gt;
&lt;/div&gt;
&lt;h4 id=&#34;三配置netlify&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三配置netlify&#34;&gt;#&lt;/a&gt; 三。配置 Netlify&lt;/h4&gt;
&lt;h5 id=&#34;第一步创建站点&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步创建站点&#34;&gt;#&lt;/a&gt; 第一步：创建站点&lt;/h5&gt;
&lt;p&gt;如图：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_24ce560b9f2dc57d0d6f51bfebae6b71.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_24ce560b9f2dc57d0d6f51bfebae6b71.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_d0c9459ade47c217db7d74d4c0dc815f.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_d0c9459ade47c217db7d74d4c0dc815f.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_ee9fc4b5245b51661e8a91a2c509c959.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_ee9fc4b5245b51661e8a91a2c509c959.png&#34; /&gt;&lt;/p&gt;
&lt;ol start=&#34;4&#34;&gt;
&lt;li&gt;选择你的后台储存库&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_1f40a4eb848a567c69eee524172ba04a.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_1f40a4eb848a567c69eee524172ba04a.png&#34; /&gt;&lt;/p&gt;
&lt;ol start=&#34;5&#34;&gt;
&lt;li&gt;填入环境变量&lt;br /&gt;
 &lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;ALLOWED_USERS：你授权使用后台的GitHub用户名，用半角逗号隔开，如果只有一个用户，则无需逗号。如：用户名1,用户名2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;GITHUB_CLIENT_ID：你的CLIENT_ID&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;GITHUB_CLIENT_SECRET：你的CLIENT_SECRET&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;GITHUB_TOKEN：你的GitHub账号密钥&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;JWT_SECRET：一个随机的不限位数的字符串，如wfhehfihwjdwefnabwaieu72dub3uigfvqty2UGQWADIWGADIY3UGF378&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_5bb90ceb6dd257c5c3e51cd20423f929.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_5bb90ceb6dd257c5c3e51cd20423f929.png&#34; /&gt;&lt;br /&gt;
 如果这一步漏掉了，可以在下面页面找到并补充&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_1184a04b95f68e809a5360a9e5925ecc.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/18/image_1184a04b95f68e809a5360a9e5925ecc.png&#34; /&gt;&lt;/p&gt;
&lt;h5 id=&#34;第二步配置自定义域名&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步配置自定义域名&#34;&gt;#&lt;/a&gt; 第二步。配置自定义域名&lt;/h5&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_03b28a83de8ee0c91accd703fdca989d.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/9/17/image_03b28a83de8ee0c91accd703fdca989d.png&#34; /&gt;&lt;/p&gt;
&lt;h2 id=&#34;结尾&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#结尾&#34;&gt;#&lt;/a&gt; 结尾&lt;/h2&gt;
&lt;p&gt;非常感谢你能看到这里，如有什么问题欢迎在评论区中提出！如果可以的话，请订阅我的网站：&lt;a href=&#34;https://jdjwzx233.cn/Subscribe&#34;&gt;https://jdjwzx233.cn/Subscribe&lt;/a&gt;&lt;br /&gt;
 如果你觉得我的博客不错的话，可以赞助我 (・̀ ω・́)✧：&lt;a href=&#34;https://jdjwzx233.cn/support&#34;&gt;https://jdjwzx233.cn/support&lt;/a&gt;。&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="网络" scheme="https://jdjwzx233.cn/categories/%E7%BD%91%E7%BB%9C/" />
        <category term="Netlify" scheme="https://jdjwzx233.cn/categories/Netlify/" />
        <category term="网络" scheme="https://jdjwzx233.cn/tags/%E7%BD%91%E7%BB%9C/" />
        <category term="反向代理" scheme="https://jdjwzx233.cn/tags/%E5%8F%8D%E5%90%91%E4%BB%A3%E7%90%86/" />
        <category term="反代" scheme="https://jdjwzx233.cn/tags/%E5%8F%8D%E4%BB%A3/" />
        <category term="Netlify" scheme="https://jdjwzx233.cn/tags/Netlify/" />
        <category term="代理" scheme="https://jdjwzx233.cn/tags/%E4%BB%A3%E7%90%86/" />
        <category term="Web" scheme="https://jdjwzx233.cn/tags/Web/" />
        <updated>2024-09-17T13:38:04.355Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2023/12/23/%E6%90%AD%E5%BB%BAjsdelivr%E9%95%9C%E5%83%8F/</id>
        <title>搭建jsdelivr镜像(又拍云/nginx/cfwokers/Deno)</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2023/12/23/%E6%90%AD%E5%BB%BAjsdelivr%E9%95%9C%E5%83%8F/"/>
        <content type="html">&lt;h2 id=&#34;前言&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#前言&#34;&gt;#&lt;/a&gt; 前言&lt;/h2&gt;
&lt;p&gt;jsDelivr —— 一个免费、快速、可靠的为 JS 和开源项目服务的 CDN。但是由于国内访问速度慢，加之 jsDelivr 备案被吊销和 DNS 污染常出现，国内使用了 jsDelivr 的站点常常出现访问速度慢的问题。&lt;br /&gt;
你可能会问，为什么不去使用别人的镜像站呢？俗话说 &amp;quot;自己动手，丰衣足食&amp;quot;，自建镜像站可以让你更好地掌握自己的数据和服务。使用第三方镜像站存在一些潜在的风险和不确定性。首先，你无法确定第三方镜像站的可靠性和稳定性，它们可能在任何时候关闭或遭遇故障。这将对你的站点造成严重影响，可能导致服务中断。其次，第三方镜像站可能无法及时更新和同步你的站点内容，导致访问者无法获取最新的信息。最后，自建镜像站可以让你更加灵活地定制和管理自己的站点，满足特定需求和提供更好的用户体验。因此，建议在可行的情况下，考虑自建镜像站来确保数据的安全和可靠性。&lt;/p&gt;
&lt;p&gt;同时，本文也适用于其他网站的镜像搭建。&lt;/p&gt;
&lt;h2 id=&#34;方法一使用又拍云搭建&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法一使用又拍云搭建&#34;&gt;#&lt;/a&gt; 方法一：使用又拍云搭建&lt;/h2&gt;
&lt;h3 id=&#34;优点&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#优点&#34;&gt;#&lt;/a&gt; 优点：&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;又拍云是国内知名企业级云服务商，其服务极速、稳定、简单易用，用来搭建镜像站是十分合适的。又拍云有非常多的优惠：加入又拍云联盟 (网站需备案，要在网站 / 应用底部添加又拍云 LOGO 并指向官网) 后，可以获得每月 10G 储存空间和 15G 的 CDN 流量 (按年发放，以 67 元的代金卷发放到账户)；新用户注册 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS9yZWdpc3Rlci8/aW52aXRlPXRJOGxqaXhJVA==&#34;&gt;点我注册&lt;/span&gt;) 还可以直接获得 61 元的代金卷 (有效期一年)。在这些优惠的加成下，你可以零成本搭建一个镜像站。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;2. 加速效果明显 (如图)&lt;/p&gt;
&lt;p&gt;加速前：&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_%E5%8A%A0%E9%80%9F%E5%89%8D_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_加速前_d41d8cd98f00b204e9800998ecf8427e.png&#34; title=&#34;加速前&#34; /&gt;&lt;/p&gt;
&lt;p&gt;加速后：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_%E5%8A%A0%E9%80%9F%E5%90%8E_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_加速后_d41d8cd98f00b204e9800998ecf8427e.png&#34; title=&#34;加速后&#34; /&gt;&lt;/p&gt;
&lt;h3 id=&#34;缺点&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#缺点&#34;&gt;#&lt;/a&gt; 缺点：&lt;/h3&gt;
&lt;p&gt;需要备案！！！&lt;/p&gt;
&lt;h3 id=&#34;推荐指数&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#推荐指数&#34;&gt;#&lt;/a&gt; 推荐指数:⭐⭐⭐⭐⭐&lt;/h3&gt;
&lt;h3 id=&#34;搭建方法&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#搭建方法&#34;&gt;#&lt;/a&gt; 搭建方法：&lt;/h3&gt;
&lt;h4 id=&#34;第一步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步&#34;&gt;#&lt;/a&gt; 第一步：&lt;/h4&gt;
&lt;p&gt;创建又拍云账户 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS9yZWdpc3Rlci8/aW52aXRlPXRJOGxqaXhJVA==&#34;&gt;点我注册&lt;/span&gt;)&lt;/p&gt;
&lt;h4 id=&#34;第二步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步&#34;&gt;#&lt;/a&gt; 第二步：&lt;/h4&gt;
&lt;p&gt;进入控制台的 CDN 管理界面 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS9zZXJ2aWNlcy9jZG4v&#34;&gt;https://console.upyun.com/services/cdn/&lt;/span&gt;), 并创建服务，然后配置服务 (具体参数如下)。&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;服务名称：唯一标识服务，例如：image-upyun-com，一个服务下面可以绑定多个自有域名。&lt;/li&gt;
&lt;/ol&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;&lt;strong&gt;注意事项&lt;/strong&gt;&lt;br /&gt;
服务名称仅限 5～20 位； 必须以小写英文字符开头，仅支持小写英文字符、数字、中划线组合。&lt;/p&gt;
&lt;/div&gt;
&lt;ol start=&#34;2&#34;&gt;
&lt;li&gt;加速域名：填写此次需要配置的加速域名。&lt;/li&gt;
&lt;/ol&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;&lt;strong&gt;注意事项&lt;/strong&gt;&lt;br /&gt;
加速域名必须已在工信部备案； 待加速域名尚未在又拍云 CDN 平台配置。&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;加速域名需要进行&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZWxwLnVweXVuLmNvbS9rbm93bGVkZ2UtYmFzZS9kb21haW4tdmVyaWZ5Lw==&#34;&gt;域名所有权验证&lt;/span&gt;，验证通过后方能添加成功。&lt;/p&gt;
&lt;ol start=&#34;3&#34;&gt;
&lt;li&gt;应用场景：这里选择全站加速&lt;/li&gt;
&lt;li&gt;回源协议：选协议跟随。&lt;/li&gt;
&lt;li&gt;源站证书校验：切记！！不要打开 (实测开了以后不能用)！！！&lt;/li&gt;
&lt;li&gt;线路配置：源站地址填  &lt;code&gt;cdn.jsdelivr.net&lt;/code&gt; , 端口号不要动。&lt;/li&gt;
&lt;/ol&gt;
&lt;h4 id=&#34;第三步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三步&#34;&gt;#&lt;/a&gt; 第三步&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;服务创建成功后，操作界面会提示 CDN 加速服务创建成功，并会自动跳转到该服务的【功能配置】界面&lt;/li&gt;
&lt;li&gt;在功能配置界面，有域名管理、回源管理、缓存配置、性能优化、HTTPS、访问控制、图片处理等功能配置模块，在【域名管理】模块下，可以针对该服务绑定多个自有域名，请耐心等待域名配置（约 10 分钟），查看域名对应的状态是否为［正常］&lt;/li&gt;
&lt;li&gt;可查看 CDN 平台为您分配的 CNAME 地址，此时需要去域名 DNS 解析商处，为该域名添加一条 CNAME 记录，待 CNAME 配置生效之后，方可使用 CDN 服务。&lt;/li&gt;
&lt;/ol&gt;
&lt;h4 id=&#34;第四步非必要但是可以提升体验&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第四步非必要但是可以提升体验&#34;&gt;#&lt;/a&gt; 第四步 (非必要，但是可以提升体验)&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;配置 HTTPS: 点击 [HTTPS], 点击 &amp;quot;HTTPS 配置&amp;quot; 右边的管理 (如图)&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/image_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/image_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt; 然后你可以选择添加自有证书或直接使用又拍云注册证书 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS90b29sYm94L3NzbC8=&#34;&gt;点我前往证书管理&lt;/span&gt;)。添加完后，打开 [HTTPS 访问]，不建议勾选 [强制 HTTPS 访问]。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;建议打开智能压缩和页面压缩 (如图)&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703354977231_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703354977231_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;建议配置缓存、浏览器缓存和分段缓存 (如图)&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355090340_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355090340_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355115278_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355115278_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355198422_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355198422_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355224230_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355224230_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;在 [访问控制] 中，打开 Referer 防盗链、WAF 保护、HTTP 请求体大小限制、IP 访问限制 (如图)&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355343968_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355343968_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355382813_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355382813_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355473637_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355473637_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355505400_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703355505400_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;div class=&#34;note info&#34;&gt;
&lt;p&gt;此配置仅作参考，请根据实际情况进行配置！&lt;/p&gt;
&lt;/div&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;你还可以配置 [边缘规则]，来实现一些特殊效果。(这里不做演示)&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;方法二使用cloudflare-workers搭建&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法二使用cloudflare-workers搭建&#34;&gt;#&lt;/a&gt; 方法二：使用 Cloudflare workers 搭建&lt;/h2&gt;
&lt;h3 id=&#34;优点-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#优点-2&#34;&gt;#&lt;/a&gt; 优点：&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;简单，步骤少，加速范围广&lt;/li&gt;
&lt;li&gt;无需备案，加速效果较好 (如图)&lt;br /&gt;
 加速前：&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_%E5%8A%A0%E9%80%9F%E5%89%8D_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/blog_img_加速前_d41d8cd98f00b204e9800998ecf8427e.png&#34; title=&#34;加速前&#34; /&gt;&lt;br /&gt;
 加速后：&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/cfwokerjsd_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/cfwokerjsd_d41d8cd98f00b204e9800998ecf8427e.png&#34; title=&#34;加速后&#34; /&gt;&lt;/li&gt;
&lt;li&gt;无费用，每天有免费额度 (每天免费 100000 个请求)&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;缺点-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#缺点-2&#34;&gt;#&lt;/a&gt; 缺点:&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;部分地区访问较慢&lt;/li&gt;
&lt;li&gt;免费额度较少，对于访问量大的站点可能不够&lt;/li&gt;
&lt;li&gt;需要有一个挂在 cloudflare 的域名&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;推荐指数-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#推荐指数-2&#34;&gt;#&lt;/a&gt; 推荐指数:⭐⭐⭐⭐&lt;/h3&gt;
&lt;h3 id=&#34;搭建方法-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#搭建方法-2&#34;&gt;#&lt;/a&gt; 搭建方法&lt;/h3&gt;
&lt;h4 id=&#34;第一步-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步-2&#34;&gt;#&lt;/a&gt; 第一步&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;在 Cloudflare 管理面板的 [Workers 和 Pages] 栏 -&amp;gt;[概述]-&amp;gt;[创建应用程序]-&amp;gt;[创建 Worker]（如图）&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703396996483_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703396996483_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397051051_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397051051_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/li&gt;
&lt;li&gt;随便填一个名称，点击 [部署]（如图）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397134262_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397134262_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/p&gt;
&lt;h4 id=&#34;第二步-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步-2&#34;&gt;#&lt;/a&gt; 第二步&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;在创建完成的页面点击 [编辑代码]（如图）&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397288998_d41d8cd98f00b204e9800998ecf8427e.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/23/12/24/1703397288998_d41d8cd98f00b204e9800998ecf8427e.png&#34; /&gt;&lt;/li&gt;
&lt;li&gt;将以下代码直接粘贴进代码框：&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;73&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;74&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;75&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;76&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;77&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;78&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;79&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;80&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;81&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;82&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;83&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;84&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;85&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;86&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;87&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;88&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;89&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;90&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;91&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;92&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;93&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;94&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;95&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;96&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;97&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;98&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;99&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;100&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;101&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;102&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;103&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;104&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;105&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;106&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;107&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;108&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;109&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;110&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;111&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;112&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;113&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;114&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;115&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;116&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;117&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;118&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;119&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;120&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;121&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;122&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;123&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;124&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;125&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;126&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;127&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;128&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;129&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;130&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;131&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;132&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;133&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;134&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;135&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;136&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;137&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;138&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;139&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;140&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;141&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;142&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;143&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;144&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;145&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;146&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;147&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;148&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;149&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;150&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;151&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;152&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;153&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;154&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;155&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;156&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;157&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;158&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;159&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;160&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;161&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;162&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;163&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;164&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;165&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;166&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;167&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;168&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;169&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;170&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;171&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;172&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;173&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;174&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;175&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;176&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;177&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;178&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;179&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;180&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;181&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;182&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;183&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;184&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;185&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;186&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;187&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;188&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;189&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;190&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;191&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;192&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;193&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;194&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;195&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;196&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;197&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;198&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;199&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;200&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;201&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;202&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;203&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;204&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;205&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;206&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;207&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;208&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;209&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;210&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;211&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;212&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;213&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;214&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;215&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;216&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;217&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;218&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;219&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;220&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;221&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;222&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;223&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;224&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;225&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;226&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;227&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;228&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;229&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;230&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;231&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;232&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;233&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;234&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;235&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;236&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;237&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;238&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;239&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;240&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;241&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;242&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;243&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;244&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;245&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;246&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;247&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;248&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;249&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;250&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;251&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;252&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;253&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;254&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;255&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;256&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;257&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;258&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;259&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;260&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;261&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;262&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;263&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;264&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;265&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;266&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;267&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;268&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;269&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;270&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;271&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;272&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;273&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;274&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;275&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;276&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;277&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;278&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;279&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;280&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;281&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;282&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;283&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;284&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;285&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;286&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;287&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;288&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;289&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;290&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;&amp;#x27;use strict&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * static files (404.html, sw.js, conf.js)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;ASSET_URL&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;https://cdn.jsdelivr.net&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;JS_VER&lt;/span&gt; = &lt;span class=&#34;number&#34;&gt;10&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;MAX_RETRY&lt;/span&gt; = &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/** &lt;span class=&#34;doctag&#34;&gt;@type&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;RequestInit&lt;/span&gt;&amp;#125; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;PREFLIGHT_INIT&lt;/span&gt; = &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;status&lt;/span&gt;: &lt;span class=&#34;number&#34;&gt;204&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Headers&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-allow-origin&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;*&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-allow-methods&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;GET,POST,PUT,PATCH,TRACE,DELETE,HEAD,OPTIONS&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-max-age&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;1728000&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;),&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;any&lt;/span&gt;&amp;#125; &lt;span class=&#34;variable&#34;&gt;body&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;number&lt;/span&gt;&amp;#125; &lt;span class=&#34;variable&#34;&gt;status&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;Object&amp;lt;string, string&amp;gt;&lt;/span&gt;&amp;#125; &lt;span class=&#34;variable&#34;&gt;headers&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;body, status = &lt;span class=&#34;number&#34;&gt;200&lt;/span&gt;, headers = &amp;#123;&amp;#125;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  headers[&lt;span class=&#34;string&#34;&gt;&amp;#x27;--ver&amp;#x27;&lt;/span&gt;] = &lt;span class=&#34;variable constant_&#34;&gt;JS_VER&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  headers[&lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-allow-origin&amp;#x27;&lt;/span&gt;] = &lt;span class=&#34;string&#34;&gt;&amp;#x27;*&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Response&lt;/span&gt;(body, &amp;#123;status, headers&amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;string&lt;/span&gt;&amp;#125; urlStr &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;newUrl&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;urlStr&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;URL&lt;/span&gt;(urlStr)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (err) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;title function_&#34;&gt;addEventListener&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;fetch&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;e&lt;/span&gt; =&amp;gt;&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; ret = &lt;span class=&#34;title function_&#34;&gt;fetchHandler&lt;/span&gt;(e)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    .&lt;span class=&#34;title function_&#34;&gt;catch&lt;/span&gt;(&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;params&#34;&gt;err&lt;/span&gt; =&amp;gt;&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;cfworker error:\n&amp;#x27;&lt;/span&gt; + err.&lt;span class=&#34;property&#34;&gt;stack&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;502&lt;/span&gt;))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  e.&lt;span class=&#34;title function_&#34;&gt;respondWith&lt;/span&gt;(ret)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;FetchEvent&lt;/span&gt;&amp;#125; e &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetchHandler&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;e&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; req = e.&lt;span class=&#34;property&#34;&gt;request&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; urlStr = req.&lt;span class=&#34;property&#34;&gt;url&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; urlObj = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;URL&lt;/span&gt;(urlStr)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; path = urlObj.&lt;span class=&#34;property&#34;&gt;href&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;substr&lt;/span&gt;(urlObj.&lt;span class=&#34;property&#34;&gt;origin&lt;/span&gt;.&lt;span class=&#34;property&#34;&gt;length&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (urlObj.&lt;span class=&#34;property&#34;&gt;protocol&lt;/span&gt; === &lt;span class=&#34;string&#34;&gt;&amp;#x27;http:&amp;#x27;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    urlObj.&lt;span class=&#34;property&#34;&gt;protocol&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;#x27;https:&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;301&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;string&#34;&gt;&amp;#x27;strict-transport-security&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;max-age=99999999; includeSubDomains; preload&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;string&#34;&gt;&amp;#x27;location&amp;#x27;&lt;/span&gt;: urlObj.&lt;span class=&#34;property&#34;&gt;href&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (path.&lt;span class=&#34;title function_&#34;&gt;startsWith&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/http/&amp;#x27;&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;httpHandler&lt;/span&gt;(req, path.&lt;span class=&#34;title function_&#34;&gt;substr&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;6&lt;/span&gt;))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;switch&lt;/span&gt; (path) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;case&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;/http&amp;#x27;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;请更新 cfworker 到最新版本!&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;case&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;/ws&amp;#x27;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;not support&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;case&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;/works&amp;#x27;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;it works&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;attr&#34;&gt;default&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// static files&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(&lt;span class=&#34;variable constant_&#34;&gt;ASSET_URL&lt;/span&gt; + path)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;Request&lt;/span&gt;&amp;#125; &lt;span class=&#34;variable&#34;&gt;req&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;string&lt;/span&gt;&amp;#125; &lt;span class=&#34;variable&#34;&gt;pathname&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;httpHandler&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;req, pathname&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; reqHdrRaw = req.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (reqHdrRaw.&lt;span class=&#34;title function_&#34;&gt;has&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;x-jsproxy&amp;#x27;&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Response&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;error&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// preflight&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (req.&lt;span class=&#34;property&#34;&gt;method&lt;/span&gt; === &lt;span class=&#34;string&#34;&gt;&amp;#x27;OPTIONS&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      reqHdrRaw.&lt;span class=&#34;title function_&#34;&gt;has&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-request-headers&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  ) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Response&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;, &lt;span class=&#34;variable constant_&#34;&gt;PREFLIGHT_INIT&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; acehOld = &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; rawSvr = &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; rawLen = &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; rawEtag = &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; reqHdrNew = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Headers&lt;/span&gt;(reqHdrRaw)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  reqHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;x-jsproxy&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;1&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// 此处逻辑和 http-dec-req-hdr.lua 大致相同&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// https://github.com/EtherDream/jsproxy/blob/master/lua/http-dec-req-hdr.lua&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; refer = reqHdrNew.&lt;span class=&#34;title function_&#34;&gt;get&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;referer&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; query = refer.&lt;span class=&#34;title function_&#34;&gt;substr&lt;/span&gt;(refer.&lt;span class=&#34;title function_&#34;&gt;indexOf&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;?&amp;#x27;&lt;/span&gt;) + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!query) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;missing params&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; param = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;URLSearchParams&lt;/span&gt;(query)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; [k, v] &lt;span class=&#34;keyword&#34;&gt;of&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Object&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;entries&lt;/span&gt;(param)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (k.&lt;span class=&#34;title function_&#34;&gt;substr&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;) === &lt;span class=&#34;string&#34;&gt;&amp;#x27;--&amp;#x27;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;comment&#34;&gt;// 系统信息&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;switch&lt;/span&gt; (k.&lt;span class=&#34;title function_&#34;&gt;substr&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;case&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;aceh&amp;#x27;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        acehOld = &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;break&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;case&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;#x27;raw-info&amp;#x27;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        [rawSvr, rawLen, rawEtag] = v.&lt;span class=&#34;title function_&#34;&gt;split&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;|&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;break&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;comment&#34;&gt;// 还原 HTTP 请求头&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (v) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        reqHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(k, v)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        reqHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(k)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!param.&lt;span class=&#34;title function_&#34;&gt;has&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;referer&amp;#x27;&lt;/span&gt;)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    reqHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;referer&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// cfworker 会把路径中的 `//` 合并成 `/`&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; urlStr = pathname.&lt;span class=&#34;title function_&#34;&gt;replace&lt;/span&gt;(&lt;span class=&#34;regexp&#34;&gt;/^(https?):\/+/&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;$1://&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; urlObj = &lt;span class=&#34;title function_&#34;&gt;newUrl&lt;/span&gt;(urlStr)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!urlObj) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;invalid proxy url: &amp;#x27;&lt;/span&gt; + urlStr, &lt;span class=&#34;number&#34;&gt;403&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;/** &lt;span class=&#34;doctag&#34;&gt;@type&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;RequestInit&lt;/span&gt;&amp;#125; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; reqInit = &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;method&lt;/span&gt;: req.&lt;span class=&#34;property&#34;&gt;method&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: reqHdrNew,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;redirect&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;manual&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (req.&lt;span class=&#34;property&#34;&gt;method&lt;/span&gt; === &lt;span class=&#34;string&#34;&gt;&amp;#x27;POST&amp;#x27;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    reqInit.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt; = req.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;proxy&lt;/span&gt;(urlObj, reqInit, acehOld, rawLen, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;URL&lt;/span&gt;&amp;#125; urlObj &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;RequestInit&lt;/span&gt;&amp;#125; reqInit &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;number&lt;/span&gt;&amp;#125; retryTimes &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;proxy&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;urlObj, reqInit, acehOld, rawLen, retryTimes&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; res = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(urlObj.&lt;span class=&#34;property&#34;&gt;href&lt;/span&gt;, reqInit)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; resHdrOld = res.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; resHdrNew = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Headers&lt;/span&gt;(resHdrOld)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; expose = &lt;span class=&#34;string&#34;&gt;&amp;#x27;*&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; [k, v] &lt;span class=&#34;keyword&#34;&gt;of&lt;/span&gt; resHdrOld.&lt;span class=&#34;title function_&#34;&gt;entries&lt;/span&gt;()) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (k === &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-allow-origin&amp;#x27;&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        k === &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-expose-headers&amp;#x27;&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        k === &lt;span class=&#34;string&#34;&gt;&amp;#x27;location&amp;#x27;&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        k === &lt;span class=&#34;string&#34;&gt;&amp;#x27;set-cookie&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    ) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; x = &lt;span class=&#34;string&#34;&gt;&amp;#x27;--&amp;#x27;&lt;/span&gt; + k&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(x, v)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (acehOld) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        expose = expose + &lt;span class=&#34;string&#34;&gt;&amp;#x27;,&amp;#x27;&lt;/span&gt; + x&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      resHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(k)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (acehOld &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;cache-control&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;content-language&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;content-type&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;expires&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;last-modified&amp;#x27;&lt;/span&gt; &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      k !== &lt;span class=&#34;string&#34;&gt;&amp;#x27;pragma&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    ) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      expose = expose + &lt;span class=&#34;string&#34;&gt;&amp;#x27;,&amp;#x27;&lt;/span&gt; + k&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (acehOld) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    expose = expose + &lt;span class=&#34;string&#34;&gt;&amp;#x27;,--s&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;--t&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;1&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;comment&#34;&gt;// verify&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (rawLen) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; newLen = resHdrOld.&lt;span class=&#34;title function_&#34;&gt;get&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;content-length&amp;#x27;&lt;/span&gt;) || &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; badLen = (rawLen !== newLen)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (badLen) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (retryTimes &amp;lt; &lt;span class=&#34;variable constant_&#34;&gt;MAX_RETRY&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        urlObj = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;parseYtVideoRedir&lt;/span&gt;(urlObj, newLen, res)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (urlObj) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;proxy&lt;/span&gt;(urlObj, reqInit, acehOld, rawLen, retryTimes + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;makeRes&lt;/span&gt;(res.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;string&#34;&gt;&amp;#x27;--error&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;`bad len: &lt;span class=&#34;subst&#34;&gt;$&amp;#123;newLen&amp;#125;&lt;/span&gt;, except: &lt;span class=&#34;subst&#34;&gt;$&amp;#123;rawLen&amp;#125;&lt;/span&gt;`&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-expose-headers&amp;#x27;&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;#x27;--error&amp;#x27;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (retryTimes &amp;gt; &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;--retry&amp;#x27;&lt;/span&gt;, retryTimes)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;let&lt;/span&gt; status = res.&lt;span class=&#34;property&#34;&gt;status&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-expose-headers&amp;#x27;&lt;/span&gt;, expose)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;access-control-allow-origin&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;#x27;*&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;--s&amp;#x27;&lt;/span&gt;, status)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;set&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;--ver&amp;#x27;&lt;/span&gt;, &lt;span class=&#34;variable constant_&#34;&gt;JS_VER&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;content-security-policy&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;content-security-policy-report-only&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  resHdrNew.&lt;span class=&#34;title function_&#34;&gt;delete&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;clear-site-data&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (status === &lt;span class=&#34;number&#34;&gt;301&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      status === &lt;span class=&#34;number&#34;&gt;302&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      status === &lt;span class=&#34;number&#34;&gt;303&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      status === &lt;span class=&#34;number&#34;&gt;307&lt;/span&gt; ||&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      status === &lt;span class=&#34;number&#34;&gt;308&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  ) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    status = status + &lt;span class=&#34;number&#34;&gt;10&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Response&lt;/span&gt;(res.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt;, &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    status,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: resHdrNew,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;URL&lt;/span&gt;&amp;#125; urlObj &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;isYtUrl&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;urlObj&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; (&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    urlObj.&lt;span class=&#34;property&#34;&gt;host&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;endsWith&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;.googlevideo.com&amp;#x27;&lt;/span&gt;) &amp;amp;&amp;amp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    urlObj.&lt;span class=&#34;property&#34;&gt;pathname&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;startsWith&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;#x27;/videoplayback&amp;#x27;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  )&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;/**&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;URL&lt;/span&gt;&amp;#125; urlObj &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;number&lt;/span&gt;&amp;#125; newLen &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; * &lt;span class=&#34;doctag&#34;&gt;@param&lt;/span&gt; &amp;#123;&lt;span class=&#34;type&#34;&gt;Response&lt;/span&gt;&amp;#125; res &lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt; */&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;async&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;parseYtVideoRedir&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;urlObj, newLen, res&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (newLen &amp;gt; &lt;span class=&#34;number&#34;&gt;2000&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!&lt;span class=&#34;title function_&#34;&gt;isYtUrl&lt;/span&gt;(urlObj)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;try&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; data = &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; res.&lt;span class=&#34;title function_&#34;&gt;text&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    urlObj = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;URL&lt;/span&gt;(data)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125; &lt;span class=&#34;keyword&#34;&gt;catch&lt;/span&gt; (err) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!&lt;span class=&#34;title function_&#34;&gt;isYtUrl&lt;/span&gt;(urlObj)) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;null&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; urlObj&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;3. 点击 [保存并部署]。&lt;/p&gt;
&lt;h4 id=&#34;第三步-2&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三步-2&#34;&gt;#&lt;/a&gt; 第三步&lt;/h4&gt;
&lt;p&gt;回到 [概述]，点击你刚才创建的项目，点击 [触发器]，点击 [添加自定义域]，填入一个你账户中的域名或其子域名，点击 [添加自定义域]，完成搭建。&lt;/p&gt;
&lt;h2 id=&#34;方法三使用deno-playground搭建&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法三使用deno-playground搭建&#34;&gt;#&lt;/a&gt; 方法三：使用 Deno Playground 搭建&lt;/h2&gt;
&lt;h3 id=&#34;优点-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#优点-3&#34;&gt;#&lt;/a&gt; 优点：&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;配置十分简单，加速范围广&lt;/li&gt;
&lt;li&gt;无需备案，加速效果较好 (如图)&lt;br /&gt;
 加速前：&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_ee2ba28d08999e625e9e68716f43db68.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_ee2ba28d08999e625e9e68716f43db68.png&#34; /&gt;&lt;br /&gt;
 加速后：&lt;br /&gt;
&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_dc2d54ac2088cec188556bc6e5582c9a.png&#34; alt=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_dc2d54ac2088cec188556bc6e5582c9a.png&#34; title=&#34;加速后&#34; /&gt;&lt;/li&gt;
&lt;li&gt;免费额度多，每月 1000000 次请求，100G 流量&lt;/li&gt;
&lt;li&gt;只要 DNS 解析就行，不用像 Cloudflare 一样需要修改域名 NS&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;缺点-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#缺点-3&#34;&gt;#&lt;/a&gt; 缺点:&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;部分地区访问较慢&lt;/li&gt;
&lt;li&gt;没有攻击防护和其他安全功能，存在被攻击或刷流量的风险&lt;/li&gt;
&lt;li&gt;官方自带的域名被墙，需要自备域名&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;推荐指数-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#推荐指数-3&#34;&gt;#&lt;/a&gt; 推荐指数:⭐⭐⭐⭐⭐&lt;/h3&gt;
&lt;h3 id=&#34;搭建方法-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#搭建方法-3&#34;&gt;#&lt;/a&gt; 搭建方法&lt;/h3&gt;
&lt;h4 id=&#34;第一步-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一步-3&#34;&gt;#&lt;/a&gt; 第一步&lt;/h4&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;登录后，在主页右上角点击 [New Playground]&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_df83a1d70d519c100210e71c5aec864d.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;进入代码编辑页面：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_6b286fe6d87f51dc041d9bf86b27acd7.png&#34; alt=&#34;&#34; /&gt;&lt;br /&gt;
如果你没有进入此页面，也可以在主页找到你创建的项目，点击 [Playground] 进入编辑&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_d8d0b8aecb44e3d7631f209870cf5a88.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;h4 id=&#34;第二步-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二步-3&#34;&gt;#&lt;/a&gt; 第二步&lt;/h4&gt;
&lt;p&gt;将以下代码直接粘贴进代码框：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight javascript&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;variable constant_&#34;&gt;HOST&lt;/span&gt; = &lt;span class=&#34;string&#34;&gt;&amp;quot;fastly.jsdelivr.net&amp;quot;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;title class_&#34;&gt;Deno&lt;/span&gt;.&lt;span class=&#34;title function_&#34;&gt;serve&lt;/span&gt;(&lt;span class=&#34;title function_&#34;&gt;async&lt;/span&gt; (request) =&amp;gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; url = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;URL&lt;/span&gt;(request.&lt;span class=&#34;property&#34;&gt;url&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;url.&lt;span class=&#34;property&#34;&gt;host&lt;/span&gt; = &lt;span class=&#34;variable constant_&#34;&gt;HOST&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;const&lt;/span&gt; newRequest = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Request&lt;/span&gt;(url.&lt;span class=&#34;title function_&#34;&gt;toString&lt;/span&gt;(), &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;attr&#34;&gt;headers&lt;/span&gt;: request.&lt;span class=&#34;property&#34;&gt;headers&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;attr&#34;&gt;method&lt;/span&gt;: request.&lt;span class=&#34;property&#34;&gt;method&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;attr&#34;&gt;body&lt;/span&gt;: request.&lt;span class=&#34;property&#34;&gt;body&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;attr&#34;&gt;redirect&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;quot;follow&amp;quot;&lt;/span&gt;,&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;await&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;fetch&lt;/span&gt;(newRequest);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;3. 点击 [Save &amp;amp; Deploy]。&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_413cb7fc502499db25d9dcdbbfc72fc8.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;h4 id=&#34;第三步-3&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三步-3&#34;&gt;#&lt;/a&gt; 第三步&lt;/h4&gt;
&lt;p&gt;回到你的项目管理页面，点击 [Settings]，点击 [Domains]，再点击 [Add Domain]，填入一个你的域名或其子域名，点击 [Setup], 按照指示完成 DNS 解析后，点击 [Validate], 并点击自动配置证书，完成搭建。(下方有示例图)&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_ebbd1ba342ad1fff1c83ec3404755559.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_d9c4095ac6c21865fc773e2bcca5e5f6.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_9fda6e5f7ae41060e59b3cc092bc552d.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/25/5/4/image_80297be1451d4fb7c0e47e581267e4f0.png&#34; alt=&#34;&#34; /&gt;&lt;/p&gt;
&lt;h2 id=&#34;方法四使用nginx&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法四使用nginx&#34;&gt;#&lt;/a&gt; 方法四：使用 nginx&lt;/h2&gt;
&lt;h3 id=&#34;优点简单&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#优点简单&#34;&gt;#&lt;/a&gt; 优点：简单&lt;/h3&gt;
&lt;h3 id=&#34;缺点-4&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#缺点-4&#34;&gt;#&lt;/a&gt; 缺点:&lt;/h3&gt;
&lt;p&gt;加速范围不广，速度受到服务器性能和速度限制。&lt;/p&gt;
&lt;h3 id=&#34;推荐指数-4&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#推荐指数-4&#34;&gt;#&lt;/a&gt; 推荐指数:⭐⭐⭐&lt;/h3&gt;
&lt;p&gt;新建一个网站，然后把下面内容覆盖到 nginx 配置文件&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;server &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    listen 80;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    listen 443 ssl http2;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    # 请更改为你的证书路径&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    ssl_certificate fullchain.pem;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    ssl_certificate_key privkey.pem;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    # 请更改为你的镜像域名&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    server_name jsd.ucbk.cn;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    location / &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_pass https://cdn.jsdelivr.net;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_set_header Host $proxy_host;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_set_header Accept-Encoding &amp;#x27;&amp;#x27;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_ssl_server_name on;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_ssl_name $proxy_host;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_redirect / /;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        # Proxy Cache&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache jsdelivr;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_lock on;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_lock_timeout 15s;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_use_stale updating;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_background_update on;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_key $host$request_uri;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_valid 200 301 302 30d;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_valid 500 501 502 503 15s;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        proxy_cache_valid any 5m;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        # Replace Domain&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        sub_filter_once off;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        sub_filter_types application/javascript application/json text/xml text/css;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        sub_filter &amp;#x27;$proxy_host&amp;#x27; &amp;#x27;$host&amp;#x27;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;# 缓存路径请根据需要更改&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;proxy_cache_path /var/tmp/nginx/jsdelivr levels=1:2 use_temp_path=off keys_zone=jsdelivr:300m inactive=30d max_size=30g;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;之后直接把网站涉及到  &lt;code&gt;cdn.jsdelivr.net&lt;/code&gt;  都改成你自己的就可以了，如果不想改的话直接在你网站 nginx 配置中加以下内容就可以了&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;sub_filter_once  off;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;sub_filter_types application/javascript application/json text/xml text/css;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;sub_filter &amp;#x27;cdn.jsdelivr.net&amp;#x27;  &amp;#x27;jsd.ucbk.cn&amp;#x27;;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;h2 id=&#34;结尾&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#结尾&#34;&gt;#&lt;/a&gt; 结尾&lt;/h2&gt;
&lt;p&gt;除了上述的服务之外，还有其他同样优秀的云服务商可以用于搭建镜像，如腾讯云、阿里云等等，但都存在一个致命的问题：需要备案。希望本文提供的方法可以帮到你，你同样也可以将这个方法用在其他网站的镜像上 (只需要修改一下代码就行)&lt;/p&gt;
&lt;p&gt;博主已经搭建了一个镜像站:&lt;/p&gt;
&lt;p&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9teXN0aWNnbG93LmRwZG5zLm9yZw==&#34;&gt;mysticglow.dpdns.org&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;这个镜像站目前还没被墙，如有需要的，可以拿去使用，这个镜像站每个月只有 100 万次请求数和 100G 的流量，如果可以的话请自行搭建，不会或懒得搭建的可以使用本站的 (๑・ᴗ・๑)♡&lt;/p&gt;
&lt;p&gt;非常感谢你能看到这里，如有什么问题欢迎在评论区中提出！&lt;br /&gt;
如果你觉得我的博客不错的话，可以赞助我 (・̀ ω・́)✧：&lt;/p&gt;
&lt;p&gt;&lt;a href=&#34;https://jdjwzx233.cn/support&#34; title=&#34;赞助我吧，要饿死了QWQ&#34;&gt;https://jdjwzx233.cn/support&lt;/a&gt;。&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="网络" scheme="https://jdjwzx233.cn/categories/%E7%BD%91%E7%BB%9C/" />
        <category term="jsdelivr" scheme="https://jdjwzx233.cn/categories/jsdelivr/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="网络" scheme="https://jdjwzx233.cn/tags/%E7%BD%91%E7%BB%9C/" />
        <category term="代理" scheme="https://jdjwzx233.cn/tags/%E4%BB%A3%E7%90%86/" />
        <category term="jsdelivr" scheme="https://jdjwzx233.cn/tags/jsdelivr/" />
        <category term="又拍云" scheme="https://jdjwzx233.cn/tags/%E5%8F%88%E6%8B%8D%E4%BA%91/" />
        <category term="nginx" scheme="https://jdjwzx233.cn/tags/nginx/" />
        <category term="Cloudflare" scheme="https://jdjwzx233.cn/tags/Cloudflare/" />
        <category term="Cloudflare wokers" scheme="https://jdjwzx233.cn/tags/Cloudflare-wokers/" />
        <category term="镜像" scheme="https://jdjwzx233.cn/tags/%E9%95%9C%E5%83%8F/" />
        <category term="deno" scheme="https://jdjwzx233.cn/tags/deno/" />
        <updated>2023-12-23T17:09:45.101Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2023/06/25/edge%E4%BF%9D%E7%95%99%E6%95%B0%E6%8D%AE%E9%80%80%E5%87%BA%E7%99%BB%E5%BD%95/</id>
        <title>Edge在保留数据的情况下退出微软账户登录</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2023/06/25/edge%E4%BF%9D%E7%95%99%E6%95%B0%E6%8D%AE%E9%80%80%E5%87%BA%E7%99%BB%E5%BD%95/"/>
        <content type="html">&lt;p&gt;现在，越来越多的人使用 Edge 浏览器来进行网络浏览，但有时候您可能需要退出微软账户登录。问题是，当您退出时，您是否会失去本地存储设备上的数据？本文将解答您的疑惑，告诉您如何在退出微软账户前保留本地数据。&lt;/p&gt;
&lt;h2 id=&#34;正文&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#正文&#34;&gt;#&lt;/a&gt; 正文&lt;/h2&gt;
&lt;p&gt;当我们无法登录账户时，如果要在 Edge 中退出微软账户登录，可能需要进入该账户的主页才能退出，否则只能使用删除该用户配置才可退出，但这会导致数据丢失，并使一些平台需要重新登录，非常的不方便。&lt;/p&gt;
&lt;p&gt;但是，我们可以使用一些其他的方法保留数据退出登录。&lt;/p&gt;
&lt;p&gt;在 Windows 的资源管理器中，找到你的用户数据文件夹 (正常情况都在这里)。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;C:\Users\用户名\AppData\Local\Microsoft\Edge\User Data&lt;/code&gt;&lt;/p&gt;
&lt;p&gt;一般来说，你的数据都存储在 Default 文件夹中，如图：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/26/image_901d395526eefaf6e30a26fdc9a90d16.png&#34; alt=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/26/image_901d395526eefaf6e30a26fdc9a90d16.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;但是有时候你使用了其他用户配置，那么你的数据可能在 &lt;code&gt;Profile+数字&lt;/code&gt; 文件夹中，这个要根据你的实际情况进行选择。&lt;/p&gt;
&lt;div class=&#34;note danger&#34;&gt;
&lt;p&gt;注意！以下操作可能会导致数据丢失，请提前备份好相关数据，再进行操作！&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;当你找到自己的数据文件夹后，你需要关闭 Edge 浏览器，注意！要到 &lt;code&gt;任务管理器&lt;/code&gt; 中关闭，直接关闭是无效的。&lt;/p&gt;
&lt;p&gt;关闭后，你需要备份这个文件夹，完成后，你就可以开始进行退出登录的操作了。&lt;/p&gt;
&lt;p&gt;在你的文件夹中，找到这几个文件，如图：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/25/image_4a0ce70e5fa19687d509e4752fdb97af.png&#34; alt=&#34;https://image.jdjwzx233.cn/upload/Qexo/2023/6/25/image_4a0ce70e5fa19687d509e4752fdb97af.png&#34; /&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;以下操作可能会使你保存的密码全部丢失，请提前到设置中导出密码，再进行本操作，导入导出密码的教程放在文章结尾。&lt;/p&gt;
&lt;/div&gt;
&lt;p&gt;然后删除 &lt;code&gt;Preferences&lt;/code&gt; ， &lt;code&gt;Login Data-journal&lt;/code&gt; ， &lt;code&gt;Login Data&lt;/code&gt;  这三个文件。回到浏览器后，你会发现，你的数据还在，但你的账户被退出了。&lt;/p&gt;
&lt;p&gt;在登录你的微软账号后，你就可以导入原来的密码，完成这步后，那么恭喜你，你已经成功完成了退出微软账户保留本地数据的操作！&lt;/p&gt;
&lt;h2 id=&#34;转移数据&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#转移数据&#34;&gt;#&lt;/a&gt; 转移数据&lt;/h2&gt;
&lt;p&gt;本方法同样适用于转移数据，你只需要将需要转移的用户文件夹中的内容，复制替换掉新的用户文件夹中的内容即可，在此操作之前，你需要备份被替换的用户文件夹中 &lt;code&gt;Preferences&lt;/code&gt; ， &lt;code&gt;Login Data-journal&lt;/code&gt; ， &lt;code&gt;Login Data&lt;/code&gt;  这三个文件，在完成数据转移后，再移动回来，这样，你就完成了数据转移。&lt;/p&gt;
&lt;h3 id=&#34;导出或导入密码&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#导出或导入密码&#34;&gt;#&lt;/a&gt; 导出或导入密码&lt;/h3&gt;
&lt;p&gt;首先，打开 &lt;code&gt;Edge://settings/passwords&lt;/code&gt;  或者你可以打开 &lt;code&gt;设置&lt;/code&gt;  -&amp;gt; &lt;code&gt;个人资料&lt;/code&gt;  -&amp;gt; &lt;code&gt;密码&lt;/code&gt; 。&lt;/p&gt;
&lt;p&gt;然后，在这个地方点击右边的三个点，如图：&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/26/image_1c76ad526b021903d93f8f1a5a944e60.png&#34; alt=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/26/image_1c76ad526b021903d93f8f1a5a944e60.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;选择 &lt;code&gt;导出密码&lt;/code&gt; ，在进行这一步时，你可能需要验证你的身份，按照步骤来就行。&lt;/p&gt;
&lt;p&gt;最后，将你的密码保存到一个安全的地方，后面导入密码时，同样也是在此地方进行。&lt;br /&gt;
如果你觉得我的博客不错的话，可以赞助我 (・̀ ω・́)✧：&lt;a href=&#34;https://jdjwzx233.cn/support&#34;&gt;https://jdjwzx233.cn/support&lt;/a&gt;。&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="Edge" scheme="https://jdjwzx233.cn/categories/Edge/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="Edge" scheme="https://jdjwzx233.cn/tags/Edge/" />
        <category term="微软账号" scheme="https://jdjwzx233.cn/tags/%E5%BE%AE%E8%BD%AF%E8%B4%A6%E5%8F%B7/" />
        <category term="微软账户" scheme="https://jdjwzx233.cn/tags/%E5%BE%AE%E8%BD%AF%E8%B4%A6%E6%88%B7/" />
        <category term="浏览器" scheme="https://jdjwzx233.cn/tags/%E6%B5%8F%E8%A7%88%E5%99%A8/" />
        <category term="数据转移" scheme="https://jdjwzx233.cn/tags/%E6%95%B0%E6%8D%AE%E8%BD%AC%E7%A7%BB/" />
        <updated>2023-06-25T23:49:09.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2023/01/28/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E4%BA%BA%E9%97%B4%E7%83%9F%E9%9B%A8%EF%BC%8C%E6%84%9F%E8%B0%A2%E6%9C%89%E4%BD%A0/</id>
        <title>优秀作文分享——人间烟雨，感谢有你</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2023/01/28/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E4%BA%BA%E9%97%B4%E7%83%9F%E9%9B%A8%EF%BC%8C%E6%84%9F%E8%B0%A2%E6%9C%89%E4%BD%A0/"/>
        <content type="html">&lt;p&gt;烟雨迷蒙，如同人生。回首往事，最难忘却的莫过于与你相遇时的情景了吧！—— 题记&lt;/p&gt;
&lt;p&gt;烟雨中的你是否还记得那一抹清丽的身影？这个女孩子很特别，她不像其他小姑娘一样喜欢花裙子和洋娃娃，而更爱穿着布鞋踏遍青石板路上的每一处角落。&lt;/p&gt;
&lt;p&gt;只因为从前年幼无知的我们都曾经问过彼此：“妈妈说下雨天地面湿滑会摔跤，可以光脚走吗？” 看到大家齐刷刷摇头后便兴高采烈地脱掉了凉鞋，赤足跑进水坑或泥泞里玩耍去了…… 渐渐长大后才明白当初母亲微笑背后的苦涩心酸，也终于理解了你对我们所谓 “放养式教育” 的坚持。&lt;/p&gt;
&lt;p&gt;多么希望能够再次见到你啊！但愿岁月静好，现世安稳。 在我眼里，你就是仙女姐姐般美好纯洁的存在，你总是用温柔细腻的手抚摸着我们受伤的心灵，告诉我们要勇敢、乐观地活出精彩。&lt;/p&gt;
&lt;p&gt;即使偶尔发脾气，嘴巴也依旧甜甜软软的。我想你应该永远是那副没什么烦恼的模样吧，虽然我们之间隔着千山万水，但我始终觉得你离我并不遥远。尽管我们素未谋面，甚至连声音都听不真切，但仿佛冥冥之中早已注定，我们将会成为最熟悉的陌生人。&lt;/p&gt;
&lt;p&gt;直到今日我仍深信缘分二字，命运让我们相识又让我们重逢，这种感觉实在太奇妙了。&lt;/p&gt;
&lt;p&gt;“有朋自远方来，不亦乐乎”。古人诚不欺我，每当收到你寄来的贺卡，打开它时内心的欣喜溢于言表；翻阅它时脑海中浮现的画面似电影般闪过；合起它时鼻尖萦绕的香味久久挥散不去… 待我读懂了你的文字，品尝了你送给我的巧克力糖果，体验了你讲述的动人故事，享受了你赠予我的珍贵礼物，聆听了你传授的宝贵经验，我恍然顿悟原来我们的相遇竟是命中注定。如若不是在茫茫人海中邂逅，怎会碰撞出绚烂火花？倘若不是被你治愈了伤痛，怎会触及到柔软的内心？谢谢你，带给我的点滴暖意；谢谢你，陪伴我度过的漫长旅程；谢谢你，让我学会了坦然释怀；谢谢你，令我变得越来越优秀。&lt;/p&gt;
&lt;p&gt;烟雨朦胧，梦境斑驳，轻捻指尖，满目芬芳。烟雨中的你，是否还记得我呢？我期盼着，下一场烟雨，我们能再次相约。&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/categories/%E4%BD%9C%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/tags/%E4%BD%9C%E6%96%87/" />
        <category term="范文" scheme="https://jdjwzx233.cn/tags/%E8%8C%83%E6%96%87/" />
        <updated>2023-01-28T23:17:19.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2023/01/28/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E4%BB%8E%E6%9C%AA%E8%B5%B0%E8%BF%9C/</id>
        <title>优秀作文分享——从未走远</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2023/01/28/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E4%BB%8E%E6%9C%AA%E8%B5%B0%E8%BF%9C/"/>
        <content type="html">&lt;p&gt;我们从未走远，只是你没发现而已。—— 题记&lt;/p&gt;
&lt;p&gt;一个人的心中有多少秘密？谁也无法知道，就像这世界上永远都会存在着许多令人费解之谜一样，它总是让那些充满智慧与灵感的人去猜测、探索和研究。但他们却始终得不到真正的答案。或许，每当夜深人静时，思绪便开始飞扬了吧！&lt;/p&gt;
&lt;p&gt;于是，所谓的诗情画意，便油然而生；所谓的浪漫气息，亦由此而来…… 于是乎，古往今来，凡大家名流，皆如痴似醉地沉浸其间。对于爱情，更是乐此不疲，因为美丽的故事总能打动人心，给予读者以无限遐想空间。 “最好不相见，免得我牵念”，唐朝才子元稹写下了千古绝唱《离思》。王维用笔墨将红豆寄托出相思之苦，李商隐则借芭蕉抒怀别恨。屈原哀叹自己遭谗被疏，伍子胥含泪鞭尸，苏轼愁断肝肠，陆游悲痛欲绝。&lt;/p&gt;
&lt;p&gt;明月照亮了黑暗，星光点缀了寂寞，文字带来了希望，纸张承载了梦想。文学作品里蕴藏着太多的内涵，需要细细揣摩，慢慢体味。&lt;br /&gt;
尽管岁月悠长，风尘渐起，惟愿历史的车轮碾过后，还留下几颗闪烁的珍珠供后人欣赏玩味。蓦然回首，青春年华早已逝去，伴随成长的足迹踏遍万水千山。可惜韶华易老，昔日容颜不再。 曾经沧海难为水，除却巫山不是云。纵使身处闹市，又怎敌得过高山流水遇知音的旷达胸襟呢？&lt;/p&gt;
&lt;p&gt;虽说花开堪折直须折，莫待无花空折枝。然而人非草木孰能无情？面对眼前的诱惑，恐怕很难把持住自己，甚至迷失方向。尤其是看惯了灯红酒绿的繁华景象，听够了莺歌燕舞的靡靡之音，享受惯了富贵荣华的锦衣玉食，接触多了形形色色的社会百态，岂能不贪恋权势金钱？试问：哪位君主甘愿做平民百姓？即使退一步讲，倘若抛弃了功名利禄，选择归隐田园，那么就必定淡泊名利吗？显然并非如此。&lt;/p&gt;
&lt;p&gt;陶渊明辞官归隐，采菊东篱下，悠然见南山，依旧钟情于 “结庐在人境，而无车马喧” 的闲适恬淡。周敦颐厌恶官场，宁愿隐居西湖孤山，仍保持清白廉洁的节操。欧阳修贬谪滁州，饱尝艰辛困顿，仍坚守信念，矢志不渝，毫不改变初衷。… 数不胜数，比比皆是。&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/categories/%E4%BD%9C%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/tags/%E4%BD%9C%E6%96%87/" />
        <category term="范文" scheme="https://jdjwzx233.cn/tags/%E8%8C%83%E6%96%87/" />
        <updated>2023-01-28T22:28:30.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2023/01/26/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E6%88%91%EF%BC%8C%E5%9C%A8%E6%B5%99%E9%87%8C/</id>
        <title>优秀作文分享——我，在浙里</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2023/01/26/%E4%BC%98%E7%A7%80%E4%BD%9C%E6%96%87%E5%88%86%E4%BA%AB%E2%80%94%E2%80%94%E6%88%91%EF%BC%8C%E5%9C%A8%E6%B5%99%E9%87%8C/"/>
        <content type="html">&lt;h2 id=&#34;第一篇&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一篇&#34;&gt;#&lt;/a&gt; 第一篇:&lt;/h2&gt;
&lt;p&gt;浙江，是一片神奇美丽的土地；浙江，孕育了中华民族灿烂悠久的文明；浙江，承载着数以亿计的浙商走向世界！&lt;/p&gt;
&lt;p&gt;“三十功名尘与土，八千里路云和月”。一首《满江红》道出了岳飞壮志难酬、报国无门的悲愤心情。但他没有被挫折所压倒，反而更加坚定自己的信念 —— 收复失地，还于旧都。在历史上留下了浓墨重彩的一笔。&lt;/p&gt;
&lt;p&gt;“位卑未敢忘忧国”。身为汉臣却始终忠心耿耿，宁死也要捍卫祖国领土完整。我想到了周恩来总理。他曾说过：“为中华崛起而读书！” 就是凭借这种强烈的爱国精神，才使得那么多仁人志士投入革命洪流，推翻黑暗统治，建立新中国！&lt;/p&gt;
&lt;p&gt;“先天下之忧而忧，后天下之乐而乐”。范仲淹从小便怀抱远大理想，立志成为像孔子一般博学多识、胸怀天下苍生的圣贤。正因此，他能够舍弃高官厚禄，毅然决然地辞职回乡，开启了著名的 “庆历新政”。虽然最终因保守势力太强而失败，但其忧国忧民的思想却永垂青史。&lt;/p&gt;
&lt;p&gt;“居庙堂之高则忧其君，处江湖之远则忧其民”。范仲淹两度遭贬，依然关注百姓疾苦，体恤黎民百姓。在他看来，只有让老百姓安居乐业，社会才能稳定发展。&lt;/p&gt;
&lt;p&gt;古人云：“读万卷书不如行千里路。” 不错，纸上谈兵并非真英雄。真正的勇者应当深入实践，躬亲实干。“宝剑锋从磨砺出，梅花香自苦寒来”。鲁迅先生把握住了知识分子的特点，用手中的笔作武器，唤醒麻木的国民。他写杂文，抨击封建制度的弊端，揭露军阀混战的罪恶；他写小说，描绘人民群众受压迫、受剥削的惨状，表现对劳动人民的同情和热爱。鲁迅先生用自己犀利的笔尖戳破假面具，撕去画皮，将丑陋的灵魂暴露给世人。他的每篇杂文犹如匕首，刺痛敌人的心脏。鲁迅先生毫不畏惧，奋斗一生，为后人树立了榜样。&lt;/p&gt;
&lt;p&gt;我们生活在这样一个伟大的时代，感谢科技进步带来的方便快捷。我们拥有丰富的物质财富，可以享受电影院、健身房等娱乐设施。但是，别忘记，今日的幸福生活离不开前辈们披荆斩棘的努力拼搏。我相信，在党的领导下，我们必将创造属于我们的辉煌！&lt;/p&gt;
&lt;h2 id=&#34;第二篇&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二篇&#34;&gt;#&lt;/a&gt; 第二篇:&lt;/h2&gt;
&lt;p&gt;浙里，我在这里。我来自浙南的温州，因为那儿有最美丽的海滨城市 —— 厦门；也许你会问：“怎么没有听说过‘东方夏威夷’呢？” 不错，它就是福建省第二大岛 —— 平潭县。而我们今天要去游览的则是被称之为 “小上海” 的浙江省会 --- 杭州。&lt;/p&gt;
&lt;p&gt;浙江是一个人杰地灵的好地方，孕育了无数名扬四海的文化巨匠和商业奇才，还造就了灿若星辰的艺术瑰宝！古代中国有四大发明，其中三项便产生于此，可见她对世界所做出的贡献之伟大啊！&lt;/p&gt;
&lt;p&gt;如果说北京是帝王将相聚集的地方，那么杭州绝对是富家子弟云集的场所。想当年，乾隆皇帝下江南时曾到过此处，并留下了千古佳句：“江南忆，最忆是杭州”。由此可以看出，杭州是多么令人向往与憧憬呀！ “日出江花红胜火，春来江水绿如蓝”，从诗中描绘的情境可知，春季的杭州正值桃李芬芳，鸟语花香的好时节。但作者却只用了两句话概括了整个杭州的特点，让读者更加感受到了杭州的魅力与神韵。或许，每个人都有属于他（她）心目中的杭州吧！&lt;/p&gt;
&lt;p&gt;杭州西湖景色秀丽、山清水秀，素有 “人间天堂” 的美誉。尤其是湖中央的三座小岛 - - 小瀛洲、湖心亭和阮公墩，各具风姿。&lt;/p&gt;
&lt;p&gt;小瀛洲面积较大，岛上遍植花木，环境幽静。湖心亭是西湖中赏荷观鱼的最佳处，岛上建筑精巧别致，有水中仙子的雅号。阮公墩虽然面积比前两个小岛略小些，但却十分别致，登高远眺，西湖全景尽收眼底…… 傍晚，夕阳斜照在西湖上，映着波光粼粼的湖面，闪烁着金光，仿佛给湖面铺上了一层碎金似的，煞是耀眼夺目。微风吹拂着柳树，使它轻轻摇摆起来，像是姑娘们甩动长发跳舞一般，婀娜多姿，楚楚动人。夜幕降临后，月亮升空，皎洁的月光倾泻而下，洒落在湖面上，泛起阵阵银白色的涟漪，宛如仙女散花，又犹如牛郎织女隔河相望，真是妙趣横生！倘若遇到皓月当空，繁星满天的夜晚，坐在船头仰望苍穹，定能领悟到苏轼《水调歌头》中所写道的 “欲把西湖比西子，淡妆浓抹总相宜” 的意蕴吧！&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/categories/%E4%BD%9C%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="作文" scheme="https://jdjwzx233.cn/tags/%E4%BD%9C%E6%96%87/" />
        <category term="范文" scheme="https://jdjwzx233.cn/tags/%E8%8C%83%E6%96%87/" />
        <category term="浙江" scheme="https://jdjwzx233.cn/tags/%E6%B5%99%E6%B1%9F/" />
        <category term="家乡" scheme="https://jdjwzx233.cn/tags/%E5%AE%B6%E4%B9%A1/" />
        <updated>2023-01-26T23:22:20.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/12/24/%E5%B0%86ChatGPT%E9%83%A8%E7%BD%B2%E5%88%B0%E7%BD%91%E7%AB%99%E4%B8%8A/</id>
        <title>将ChatGPT部署到网站上</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/12/24/%E5%B0%86ChatGPT%E9%83%A8%E7%BD%B2%E5%88%B0%E7%BD%91%E7%AB%99%E4%B8%8A/"/>
        <content type="html">&lt;p&gt;ChatGPT 是一个用于自然语言对话的预训练语言模型。要将 ChatGPT 部署到网站上，你需要执行以下步骤：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;下载 ChatGPT 模型：你可以从 Hugging Face 的 Transformers 库中下载 ChatGPT 模型。&lt;/li&gt;
&lt;li&gt;使用 Python 的 Flask 库创建一个 Web 应用程序。Flask 是一种轻量级的 Web 应用框架，可以让你快速构建 Web 应用程序。&lt;/li&gt;
&lt;li&gt;在 Web 应用中加载 ChatGPT 模型：在 Web 应用程序中，你可以使用 Transformers 库中的 &lt;code&gt;AutoModelWithLMHead&lt;/code&gt;  类加载 ChatGPT 模型。&lt;/li&gt;
&lt;li&gt;创建一个 HTML 表单，允许用户输入对话文本。&lt;/li&gt;
&lt;li&gt;使用 ChatGPT 模型对用户输入的文本进行响应：当用户提交表单时，你可以使用 ChatGPT 模型的 &lt;code&gt;generate&lt;/code&gt;  方法生成响应文本。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;以下是一个简单的例子，展示了如何使用 Flask 和 ChatGPT 构建一个简单的 Web 应用程序：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight python&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;from&lt;/span&gt; flask &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt; Flask, render_template, request&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;from&lt;/span&gt; transformers &lt;span class=&#34;keyword&#34;&gt;import&lt;/span&gt; AutoModelWithLMHead, AutoTokenizer&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;app = Flask(__name__)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;# 加载ChatGPT模型&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;model = AutoModelWithLMHead.from_pretrained(&lt;span class=&#34;string&#34;&gt;&amp;quot;microsoft/DialoGPT-small&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;tokenizer = AutoTokenizer.from_pretrained(&lt;span class=&#34;string&#34;&gt;&amp;quot;microsoft/DialoGPT-small&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;@app.route(&lt;span class=&#34;params&#34;&gt;&lt;span class=&#34;string&#34;&gt;&amp;quot;/&amp;quot;&lt;/span&gt;, methods=[&lt;span class=&#34;string&#34;&gt;&amp;quot;GET&amp;quot;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;quot;POST&amp;quot;&lt;/span&gt;]&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;def&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;index&lt;/span&gt;():&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; request.method == &lt;span class=&#34;string&#34;&gt;&amp;quot;POST&amp;quot;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;# 获取用户输入的文本&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        input_text = request.form[&lt;span class=&#34;string&#34;&gt;&amp;quot;input_text&amp;quot;&lt;/span&gt;]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;# 使用ChatGPT模型生成响应文本&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        prompt = (input_text, &lt;span class=&#34;string&#34;&gt;&amp;quot;&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        response = model.generate(prompt, max_length=&lt;span class=&#34;number&#34;&gt;1024&lt;/span&gt;, do_sample=&lt;span class=&#34;literal&#34;&gt;True&lt;/span&gt;, temperature=&lt;span class=&#34;number&#34;&gt;0.7&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        response_text = tokenizer.decode(response[&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;], skip_special_tokens=&lt;span class=&#34;literal&#34;&gt;True&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; render_template(&lt;span class=&#34;string&#34;&gt;&amp;quot;index.html&amp;quot;&lt;/span&gt;, response_text=response_text)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; render_template(&lt;span class=&#34;string&#34;&gt;&amp;quot;index.html&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; __name__ == &lt;span class=&#34;string&#34;&gt;&amp;quot;__main__&amp;quot;&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    app.run()&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们使用了 Flask 的 &lt;code&gt;render_template&lt;/code&gt;  函数来渲染一个 HTML 模板，并将响应文本传递给模板。我们还使用了 Transformers 库中的 &lt;code&gt;AutoTokenizer&lt;/code&gt;  类来将响应文本解码为可读的文本。&lt;/p&gt;
&lt;p&gt;下面是一个简单的 HTML 模板，你可以使用它来显示用户输入和 ChatGPT 响应：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;ChatGPT Demo&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;method&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;POST&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;label&lt;/span&gt;&amp;gt;&lt;/span&gt;输入文本：&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;label&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;input&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;text&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;name&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;input_text&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;placeholder&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;输入文本&amp;quot;&lt;/span&gt; /&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;submit&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;发送&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#123;% if response_text %&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;响应文本：&amp;#123;&amp;#123; response_text &amp;#125;&amp;#125;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;p&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#123;% endif %&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这个 HTML 模板中，我们创建了一个表单，允许用户输入对话文本。当用户提交表单时，Web 应用程序会使用 ChatGPT 模型生成响应文本，并使用 Flask 的 &lt;code&gt;render_template&lt;/code&gt;  函数将响应文本传递给 HTML 模板。&lt;/p&gt;
&lt;p&gt;要运行这个 Web 应用程序，你需要安装 Flask 和 Transformers 库，然后运行代码：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight powershell&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;pip install flask transformers&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;python app.py&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;然后，你就可以在浏览器中访问&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cDovL2xvY2FsaG9zdDo1MDAwLw==&#34;&gt; http://localhost:5000/&lt;/span&gt; 来使用这个 Web 应用程序了。&lt;/p&gt;
&lt;p&gt;要在上述代码的基础上创建一个更美观的界面，你可以使用 HTML、CSS 和 JavaScript 来设计界面，并使用 AJAX 技术在用户输入文本后异步获取 ChatGPT 响应。&lt;/p&gt;
&lt;p&gt;下面是一个示例代码，展示了如何使用这些技术创建一个类似聊天系统的界面：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight html&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;ChatGPT Demo&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;title&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 引入Bootstrap框架 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;link&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;rel&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;stylesheet&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;href&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;integrity&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;sha384-9aIt2nRpC12Uk9gS9baDl411NQApFmC26EwAOH8WgZl5MYYxFfc+NcPb1dKGj7Sk&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;crossorigin&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;anonymous&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;head&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 创建聊天窗口 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;container mt-5&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;card&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;card-header&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          聊天窗口&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;card-body p-0&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;messages&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 显示聊天记录 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;row mb-2&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;col-md-2&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;col-md-10 text-right&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;              你好，我是ChatGPT，有什么想聊的？&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 创建输入框 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;card-footer&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;form-group&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;              &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;input&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;text&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;form-control&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;input_text&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;placeholder&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;输入文本&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;submit&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;class&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;btn btn-primary&amp;quot;&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;id&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;send_button&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;发送&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;button&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;          &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;form&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;      &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;div&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 引入jQuery库 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt; &lt;span class=&#34;attr&#34;&gt;src&lt;/span&gt;=&lt;span class=&#34;string&#34;&gt;&amp;quot;https://code.jquery.com/jquery-3.5.1.min.js&amp;quot;&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;&amp;lt;!-- 设置AJAX请求 --&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;tag&#34;&gt;&amp;lt;&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;      $(&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        $(&lt;span class=&#34;string&#34;&gt;&amp;quot;form&amp;quot;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;submit&lt;/span&gt;(&lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;event&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          event.&lt;span class=&#34;title function_&#34;&gt;preventDefault&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          &lt;span class=&#34;comment&#34;&gt;// 获取用户输入的文本&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          &lt;span class=&#34;keyword&#34;&gt;var&lt;/span&gt; input_text = $(&lt;span class=&#34;string&#34;&gt;&amp;quot;#input_text&amp;quot;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;val&lt;/span&gt;();&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          &lt;span class=&#34;comment&#34;&gt;// 将文本添加到聊天记录中&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          $(&lt;span class=&#34;string&#34;&gt;&amp;quot;#messages&amp;quot;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;append&lt;/span&gt;(&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;lt;div class=&amp;quot;row mb-2&amp;quot;&amp;gt;&amp;lt;div class=&amp;quot;col-md-2&amp;quot;&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;div class=&amp;quot;col-md-10&amp;quot;&amp;gt;&amp;#x27;&lt;/span&gt; + input_text + &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;lt;/div&amp;gt;&amp;lt;/div&amp;gt;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          );&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          &lt;span class=&#34;comment&#34;&gt;// 发送AJAX请求&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          $.&lt;span class=&#34;title function_&#34;&gt;ajax&lt;/span&gt;(&amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;type&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;quot;POST&amp;quot;&lt;/span&gt;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;url&lt;/span&gt;: &lt;span class=&#34;string&#34;&gt;&amp;quot;/chat&amp;quot;&lt;/span&gt;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;data&lt;/span&gt;: &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;              &lt;span class=&#34;string&#34;&gt;&amp;quot;input_text&amp;quot;&lt;/span&gt;: input_text&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;,&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &lt;span class=&#34;attr&#34;&gt;success&lt;/span&gt;: &lt;span class=&#34;keyword&#34;&gt;function&lt;/span&gt;(&lt;span class=&#34;params&#34;&gt;response&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;              &lt;span class=&#34;comment&#34;&gt;// 将GPT的回复添加到聊天记录中&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;              $(&lt;span class=&#34;string&#34;&gt;&amp;quot;#messages&amp;quot;&lt;/span&gt;).&lt;span class=&#34;title function_&#34;&gt;append&lt;/span&gt;(&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;                &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;lt;div class=&amp;quot;row mb-2&amp;quot;&amp;gt;&amp;lt;div class=&amp;quot;col-md-10 text-left&amp;quot;&amp;gt;&amp;#x27;&lt;/span&gt; + response + &lt;span class=&#34;string&#34;&gt;&amp;#x27;&amp;lt;/div&amp;gt;&amp;lt;div class=&amp;quot;col-md-2&amp;quot;&amp;gt;&amp;lt;/div&amp;gt;&amp;lt;/div&amp;gt;&amp;#x27;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;              );&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;          &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;        &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;      &amp;#125;);&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;language-javascript&#34;&gt;    &lt;/span&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;script&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;body&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;tag&#34;&gt;&amp;lt;/&lt;span class=&#34;name&#34;&gt;html&lt;/span&gt;&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;上面的代码是一个基于 HTML 和 jQuery 的聊天系统模板，使用了 Bootstrap 框架进行布局。&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;HTML 部分：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;页面中包含一个聊天窗口，其中有一个卡片（card），卡片中包含聊天记录（card-body）和输入框（card-footer）。&lt;/li&gt;
&lt;li&gt;聊天记录中默认显示一条消息：“你好，我是 ChatGPT，有什么想聊的？”&lt;/li&gt;
&lt;li&gt;输入框中包含一个文本输入框（input）和一个发送按钮（button）。&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;jQuery 部分：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;页面加载完成后，通过 jQuery 监听表单提交事件（submit）。当表单提交时，jQuery 会触发一个回调函数，这个回调函数中的代码会被执行。&lt;/li&gt;
&lt;li&gt;当用户在输入框中输入文本并点击发送按钮时，表单提交事件（submit）被触发。&lt;/li&gt;
&lt;li&gt;在表单提交事件的回调函数中，首先使用 &lt;code&gt;event.preventDefault()&lt;/code&gt;  阻止默认的表单提交行为。&lt;/li&gt;
&lt;li&gt;然后使用 &lt;code&gt;$(&amp;quot;#input_text&amp;quot;).val()&lt;/code&gt;  获取用户输入的文本。&lt;/li&gt;
&lt;li&gt;接着使用 &lt;code&gt;$(&amp;quot;#messages&amp;quot;).append()&lt;/code&gt;  将文本添加到聊天记录中。&lt;/li&gt;
&lt;li&gt;最后，使用 jQuery 的 AJAX 功能发送一个 POST 请求到服务器，将用户输入的文本作为请求参数。&lt;/li&gt;
&lt;li&gt;当服务器返回响应时，将服务器返回的内容添加到聊天记录中。&lt;/li&gt;
&lt;li&gt;最后，清空文本输入框，准备下一次聊天。&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;整个流程如下：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;用户在文本输入框中输入文本，点击发送按钮。&lt;/li&gt;
&lt;li&gt;jQuery 监听到表单提交事件，阻止默认的表单提交行为。&lt;/li&gt;
&lt;li&gt;获取用户输入的文本。&lt;/li&gt;
&lt;li&gt;将文本添加到聊天记录中。&lt;/li&gt;
&lt;li&gt;发送 AJAX 请求，将用户输入的文本作为请求参数。&lt;/li&gt;
&lt;li&gt;服务器返回响应，将响应的内容添加到聊天记录中。&lt;/li&gt;
&lt;li&gt;清空文本输入框，准备下一次聊天。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;这个 HTML 模板只是个简单的框架，具体的逻辑实现还需要你在服务器端进行开发。&lt;/p&gt;
&lt;p&gt;感谢您阅读这篇文章，希望能帮助到您。在这篇文章中，我们介绍了如何将 ChatGPT 部署到网站上，并使用 jQuery 和 Bootstrap 构建聊天系统的界面。如果您有任何疑问或建议，欢迎在评论区留言。最后，如果这篇文章对您有所帮助，希望能给个打赏鼓励一下作者。&lt;br /&gt;
如果你觉得我的博客不错的话，可以赞助我 (・̀ ω・́)✧：&lt;a href=&#34;https://jdjwzx233.cn/support&#34;&gt;https://jdjwzx233.cn/support&lt;/a&gt;。&lt;/p&gt;
&lt;/li&gt;
&lt;/ul&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="编程" scheme="https://jdjwzx233.cn/categories/%E7%BC%96%E7%A8%8B/" />
        <category term="ChatGpt" scheme="https://jdjwzx233.cn/categories/ChatGpt/" />
        <category term="python" scheme="https://jdjwzx233.cn/categories/python/" />
        <category term="Flask" scheme="https://jdjwzx233.cn/categories/Flask/" />
        <category term="Web" scheme="https://jdjwzx233.cn/categories/Web/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="Web" scheme="https://jdjwzx233.cn/tags/Web/" />
        <category term="编程" scheme="https://jdjwzx233.cn/tags/%E7%BC%96%E7%A8%8B/" />
        <category term="信息技术" scheme="https://jdjwzx233.cn/tags/%E4%BF%A1%E6%81%AF%E6%8A%80%E6%9C%AF/" />
        <category term="ChatGpt" scheme="https://jdjwzx233.cn/tags/ChatGpt/" />
        <category term="python" scheme="https://jdjwzx233.cn/tags/python/" />
        <category term="Flask" scheme="https://jdjwzx233.cn/tags/Flask/" />
        <updated>2022-12-24T18:26:35.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/12/23/%E8%BF%9C%E7%A8%8B%E6%A1%8C%E9%9D%A2%E6%8E%A7%E5%88%B6%E5%99%A8/</id>
        <title>远程桌面控制器-用c++实现</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/12/23/%E8%BF%9C%E7%A8%8B%E6%A1%8C%E9%9D%A2%E6%8E%A7%E5%88%B6%E5%99%A8/"/>
        <content type="html">&lt;p&gt;写一个远程桌面控制器是一个非常复杂的任务，需要熟悉许多网络协议、图像处理技术以及用户界面设计等知识。这里给出的是一个基本的框架，你可以在此基础上进行扩展和完善。&lt;/p&gt;
&lt;p&gt;首先，我们需要用到一些库来帮助我们实现远程桌面控制器。在这里，我们假设你使用的是 Windows 系统，并使用了以下几个库：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;WinSock：用于实现网络通信。&lt;/li&gt;
&lt;li&gt;GDI+：用于处理图像。&lt;/li&gt;
&lt;li&gt;MFC：用于创建图形用户界面。&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;下面是使用这些库编写远程桌面控制器的基本步骤：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;创建一个 MFC 应用程序。&lt;/li&gt;
&lt;li&gt;使用 WinSock 库创建一个网络连接。&lt;/li&gt;
&lt;li&gt;使用 GDI+ 库获取远程桌面的屏幕截图。&lt;/li&gt;
&lt;li&gt;将屏幕截图显示在 MFC 窗口中。&lt;/li&gt;
&lt;li&gt;为用户提供一组控制命令，例如鼠标移动、鼠标单击、键盘输入等。&lt;/li&gt;
&lt;li&gt;使用 WinSock 库将用户的控制命令发送到远程桌面。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;下面是使用这些库编写远程桌面控制器的示例代码：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;73&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;74&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;75&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;76&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;77&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;78&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;79&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;80&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;81&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;82&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;83&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;84&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;85&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;86&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;87&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;88&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;89&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;90&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;91&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;92&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;93&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;94&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;95&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;96&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;97&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;98&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;99&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;100&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;101&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;102&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;103&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;104&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;105&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;106&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;107&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;108&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;109&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;110&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;111&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;112&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;113&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;114&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;115&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;116&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;117&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;118&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;119&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;120&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;121&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;122&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;123&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;124&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;125&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;126&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;127&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;128&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;129&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;130&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;131&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;132&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;133&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;134&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;135&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;136&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;137&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;138&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;139&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;140&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;141&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;142&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;143&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;144&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;145&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;146&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;147&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;148&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;149&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;150&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;151&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;152&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;153&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;154&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;155&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;156&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;157&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;158&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;159&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;160&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;161&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;162&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;163&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;164&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;165&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;166&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;167&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;168&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;169&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;170&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;171&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;172&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;173&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;174&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;175&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;176&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;177&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;178&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;179&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;180&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;181&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;182&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;183&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;184&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;185&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;186&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;187&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;188&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;189&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;190&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;191&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;192&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;193&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;194&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;195&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;196&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;197&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;198&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;199&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;200&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;201&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;202&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;203&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;204&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;205&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;206&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;207&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;208&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;209&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;210&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;211&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;212&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;213&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;214&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;215&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;216&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;217&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;218&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;219&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;220&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;221&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;222&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;223&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;224&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;225&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;226&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;227&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;228&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;229&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;230&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;231&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;232&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;233&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;234&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;235&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;236&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;237&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;238&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;239&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;240&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;241&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;242&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;243&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;244&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;245&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;246&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;247&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;248&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;249&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;250&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;251&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;252&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;253&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;254&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;255&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;256&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;257&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;258&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;259&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;260&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;261&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;262&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;263&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;264&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;265&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;266&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;267&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;winsock2.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;gdiplus.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;afxwin.h&amp;gt;&lt;/span&gt; &lt;span class=&#34;comment&#34;&gt;// 包含 MFC 的头文件&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;using&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;namespace&lt;/span&gt; Gdiplus;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 定义一个 Socket 类，用于封装网络通信相关的操作&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Socket&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	WSADATA m_wsaData;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	SOCKET m_sock;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	sockaddr_in m_serverAddr;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	&lt;span class=&#34;built_in&#34;&gt;Socket&lt;/span&gt;() : &lt;span class=&#34;built_in&#34;&gt;m_sock&lt;/span&gt;(INVALID_SOCKET) &amp;#123;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 初始化 WinSock 库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Init&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;WSAStartup&lt;/span&gt;(&lt;span class=&#34;built_in&#34;&gt;MAKEWORD&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;), &amp;amp;m_wsaData) != &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 创建套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Create&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; af, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; type, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; protocol)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_sock = &lt;span class=&#34;built_in&#34;&gt;socket&lt;/span&gt;(af, type, protocol);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (m_sock == INVALID_SOCKET)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 连接到服务器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Connect&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* ip, &lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;short&lt;/span&gt; port)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_family = AF_INET;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_port = &lt;span class=&#34;built_in&#34;&gt;htons&lt;/span&gt;(port);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_addr.S_un.S_addr = &lt;span class=&#34;built_in&#34;&gt;inet_addr&lt;/span&gt;(ip);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;connect&lt;/span&gt;(m_sock, (sockaddr*)&amp;amp;m_serverAddr, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(m_serverAddr)) == SOCKET_ERROR)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 发送数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Send&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* buf, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; len)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;send&lt;/span&gt;(m_sock, buf, len, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 接收数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Receive&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* buf, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; len)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;recv&lt;/span&gt;(m_sock, buf, len, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 关闭套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Close&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;closesocket&lt;/span&gt;(m_sock);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_sock = INVALID_SOCKET;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 清理 WinSock 库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Cleanup&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;WSACleanup&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 定义一个 RemoteDesktop 类，用于控制远程桌面&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;RemoteDesktop&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    Socket m_socket; &lt;span class=&#34;comment&#34;&gt;// 用于网络通信的套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    Image* m_image; &lt;span class=&#34;comment&#34;&gt;// 当前屏幕截图&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;RemoteDesktop&lt;/span&gt;() : &lt;span class=&#34;built_in&#34;&gt;m_image&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;) &amp;#123;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 连接到远续桌面服务器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Connect&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* ip, &lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;short&lt;/span&gt; port)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Init&lt;/span&gt;())&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Create&lt;/span&gt;(AF_INET, SOCK_STREAM, IPPROTO_TCP))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Connect&lt;/span&gt;(ip, port))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 断开与远程桌面服务器的连接&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Disconnect&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Close&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Cleanup&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;delete&lt;/span&gt; m_image;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_image = &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 获取远程桌面的屏幕截图&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;GetScreenshot&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 先发送获取屏幕截图的命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* cmd = &lt;span class=&#34;string&#34;&gt;&amp;quot;screenshot&amp;quot;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;(cmd, &lt;span class=&#34;built_in&#34;&gt;strlen&lt;/span&gt;(cmd));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 接收屏幕截图的大小&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; size;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;size, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(size));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 分配内存空间，准备接收屏幕截图的数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* data = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;[size];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 接收屏幕截图的数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; bytesReceived = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (bytesReceived &amp;lt; size)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; count = m_socket.&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;(data + bytesReceived, size - bytesReceived);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (count &amp;lt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;delete&lt;/span&gt;[] data;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            bytesReceived += count;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将接收到的数据转换为 GDI+ 图像&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;delete&lt;/span&gt; m_image;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_image = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;Image&lt;/span&gt;(data, size);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;delete&lt;/span&gt;[] data;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 获取当前屏幕截图&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;Image* &lt;span class=&#34;title&#34;&gt;GetImage&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;const&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; m_image;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 发送鼠标移动命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;MoveMouse&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; y)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 封装命令格式，发送命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* cmd = &lt;span class=&#34;string&#34;&gt;&amp;quot;mouse move&amp;quot;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;(cmd, &lt;span class=&#34;built_in&#34;&gt;strlen&lt;/span&gt;(cmd));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;x, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(x));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;y, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(y));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 发送鼠标单击命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;ClickMouse&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; y)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 封装命令格式，发送命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* cmd = &lt;span class=&#34;string&#34;&gt;&amp;quot;mouse click&amp;quot;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;(cmd, &lt;span class=&#34;built_in&#34;&gt;strlen&lt;/span&gt;(cmd));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;x, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(x));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;y, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(y));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 发送键盘输入命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;InputKey&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; keyCode)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 封装命令格式，发送命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* cmd = &lt;span class=&#34;string&#34;&gt;&amp;quot;key input&amp;quot;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;(cmd, &lt;span class=&#34;built_in&#34;&gt;strlen&lt;/span&gt;(cmd));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_socket.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;keyCode, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(keyCode));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 定义一个 RemoteDesktopDialog 类，用于显示远程桌面的界面&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;RemoteDesktopDialog&lt;/span&gt; : &lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt; CDialog&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    RemoteDesktop m_rd; &lt;span class=&#34;comment&#34;&gt;// 用于控制远程桌面的对象&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 使用 MFC 对话框的基本操作&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;RemoteDesktopDialog&lt;/span&gt;() : &lt;span class=&#34;built_in&#34;&gt;CDialog&lt;/span&gt;(IDD_DIALOG1) &amp;#123;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;protected&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;virtual&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;DoDataExchange&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(CDataExchange* pDX)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        CDialog::&lt;span class=&#34;built_in&#34;&gt;DoDataExchange&lt;/span&gt;(pDX);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 连接到远程桌面服务器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Connect&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* ip, &lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;short&lt;/span&gt; port)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; m_rd.&lt;span class=&#34;built_in&#34;&gt;Connect&lt;/span&gt;(ip, port);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 断开与远程桌面服务器的连接&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Disconnect&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_rd.&lt;span class=&#34;built_in&#34;&gt;Disconnect&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;protected&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 绘制远程桌面的界面&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;afx_msg &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;OnPaint&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;function&#34;&gt;CPaintDC &lt;span class=&#34;title&#34;&gt;dc&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;keyword&#34;&gt;this&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;; &lt;span class=&#34;comment&#34;&gt;// 用于绘制的设备上下文&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        CRect rect;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GetClientRect&lt;/span&gt;(&amp;amp;rect); &lt;span class=&#34;comment&#34;&gt;// 获取对话框的客户区域&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;comment&#34;&gt;// 获取屏幕截图，并绘制到界面上&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        Image* image = m_rd.&lt;span class=&#34;built_in&#34;&gt;GetImage&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (image != &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;function&#34;&gt;Graphics &lt;span class=&#34;title&#34;&gt;graphics&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(dc)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            graphics.&lt;span class=&#34;built_in&#34;&gt;DrawImage&lt;/span&gt;(image, rect);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理鼠标移动事件&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;afx_msg &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;OnMouseMove&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(UINT nFlags, CPoint point)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_rd.&lt;span class=&#34;built_in&#34;&gt;MoveMouse&lt;/span&gt;(point.x, point.y);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理鼠标单击事件&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;afx_msg &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;OnLButtonDown&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(UINT nFlags, CPoint point)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_rd.&lt;span class=&#34;built_in&#34;&gt;ClickMouse&lt;/span&gt;(point.x, point.y);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理键盘输入事件&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;afx_msg &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;OnKeyDown&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(UINT nChar, UINT nRepCnt, UINT nFlags)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_rd.&lt;span class=&#34;built_in&#34;&gt;InputKey&lt;/span&gt;(nChar);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;DECLARE_MESSAGE_MAP&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;BEGIN_MESSAGE_MAP&lt;/span&gt;(RemoteDesktopDialog, CDialog)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;ON_WM_PAINT&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;ON_WM_MOUSEMOVE&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;ON_WM_LBUTTONDOWN&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;ON_WM_KEYDOWN&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;END_MESSAGE_MAP&lt;/span&gt;()&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 初始化 GDI+&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    GdiplusStartupInput gdiplusStartupInput;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    ULONG_PTR gdiplusToken;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;GdiplusStartup&lt;/span&gt;(&amp;amp;gdiplusToken, &amp;amp;gdiplusStartupInput, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 创建对话框并运行&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    RemoteDesktopDialog dlg;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    dlg.&lt;span class=&#34;built_in&#34;&gt;DoModal&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 清理 GDI+&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们定义了三个类：Socket、RemoteDesktop 和 RemoteDesktopDialog。Socket 类封装了网络通信的相关操作，RemoteDesktop 类用于控制远程桌面，RemoteDesktopDialog 类用于显示远程桌面的界面。&lt;/p&gt;
&lt;p&gt;使用这个远程桌面控制器的流程如下：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;调用 Socket 类的 Init 函数初始化 WinSock 库。&lt;/li&gt;
&lt;li&gt;调用 Socket 类的 Create 函数创建一个套接字。&lt;/li&gt;
&lt;li&gt;调用 Socket 类的 Connect 函数连接到远程桌面服务器。&lt;/li&gt;
&lt;li&gt;调用 RemoteDesktop 类的 GetScreenshot 函数获取远程桌面的屏幕截图。&lt;/li&gt;
&lt;li&gt;调用 RemoteDesktop 类的 MoveMouse、ClickMouse 或 InputKey 函数发送控制命令。&lt;/li&gt;
&lt;li&gt;重复步骤 4 和 5，实时更新远程桌面的屏幕截图并发送控制命令。&lt;/li&gt;
&lt;li&gt;当远程桌面控制结束时，调用 RemoteDesktop 类的 Disconnect 函数断开与远程桌面服务器的连接，并调用 Socket 类的 Cleanup 函数清理 WinSock 库。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;需要注意的是，这段代码使用了 MFC 库来绘制界面，因此需要在 Visual Studio 中创建一个 MFC 应用程序，并在对话框资源中添加一个对话框。然后将上面的代码放入主窗口类的 .cpp 文件中，并在 .h 文件中声明相应的消息映射函数。&lt;/p&gt;
&lt;p&gt;以下是服务端代码：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;40&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;41&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;42&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;43&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;44&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;45&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;46&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;47&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;48&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;49&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;50&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;51&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;52&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;53&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;54&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;55&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;56&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;57&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;58&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;59&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;60&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;61&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;62&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;63&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;64&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;65&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;66&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;67&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;68&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;69&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;70&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;71&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;72&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;73&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;74&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;75&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;76&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;77&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;78&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;79&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;80&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;81&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;82&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;83&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;84&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;85&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;86&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;87&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;88&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;89&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;90&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;91&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;92&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;93&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;94&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;95&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;96&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;97&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;98&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;99&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;100&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;101&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;102&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;103&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;104&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;105&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;106&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;107&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;108&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;109&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;110&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;111&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;112&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;113&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;114&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;115&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;116&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;117&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;118&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;119&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;120&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;121&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;122&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;123&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;124&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;125&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;126&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;127&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;128&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;129&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;130&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;131&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;132&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;133&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;134&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;135&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;136&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;137&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;138&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;139&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;140&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;141&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;142&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;143&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;144&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;145&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;146&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;147&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;148&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;149&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;150&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;151&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;152&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;153&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;154&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;155&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;156&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;157&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;158&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;159&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;160&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;161&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;162&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;163&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;164&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;165&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;166&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;167&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;168&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;169&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;170&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;171&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;172&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;173&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;174&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;175&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;176&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;177&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;178&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;179&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;180&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;181&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;182&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;183&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;184&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;185&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;186&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;187&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;188&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;189&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;190&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;191&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;192&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;193&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;194&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;195&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;196&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;197&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;198&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;199&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;200&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;201&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;202&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;203&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;204&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;205&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;206&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;207&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;208&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;209&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;210&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;211&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;212&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;213&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;214&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;215&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;216&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;217&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;218&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;219&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;220&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;221&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;222&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;223&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;224&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;225&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;226&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;227&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;228&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;229&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;230&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;231&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;232&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;233&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;234&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;235&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;236&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;237&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;238&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;239&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;240&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;241&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;242&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;243&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;244&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;245&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;246&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;247&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;248&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;249&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;250&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;251&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;252&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;253&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;254&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;255&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;256&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;257&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;258&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;259&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;260&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;261&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;262&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;263&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;264&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;265&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;266&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;267&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;268&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;269&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;270&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;271&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;272&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;273&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;274&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;275&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;276&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;277&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;278&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;279&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;280&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;281&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;282&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;283&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;284&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;285&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;286&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;287&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;288&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;289&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;290&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;291&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;292&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;293&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;294&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;295&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;296&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;297&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;298&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;299&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;300&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;301&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;302&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;303&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;304&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;305&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;306&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;307&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;308&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;309&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;310&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;311&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;312&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;313&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;314&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;315&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;316&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;317&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;318&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;319&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;320&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;321&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;322&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;323&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;324&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;325&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;326&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;327&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;328&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;329&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;330&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;331&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;332&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;333&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;334&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;335&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;336&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;337&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;338&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;339&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;340&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;341&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;342&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;343&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;344&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;345&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;346&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;347&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;348&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;349&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;350&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;351&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;352&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;353&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;354&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;355&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;356&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;357&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;358&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;359&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;360&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;361&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;362&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;363&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;364&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;365&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;366&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;367&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;368&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;369&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;370&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;371&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;372&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;373&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;374&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;375&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;376&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;377&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;378&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;379&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;380&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;381&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;382&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;383&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;384&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;385&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;386&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;387&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;388&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;389&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;390&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;391&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;392&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;393&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;394&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;395&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;396&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;397&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;398&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;399&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;400&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;401&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;402&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;403&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;404&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;405&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;406&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;407&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;408&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;409&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;410&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;411&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;412&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;413&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;414&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;415&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;416&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;417&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;418&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;419&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;420&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;421&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;422&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;423&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;424&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;425&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;426&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;427&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;428&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;429&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;430&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;431&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;432&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;433&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;434&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;435&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;436&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;437&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;438&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;439&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;440&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;441&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;442&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;443&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;444&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;445&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;446&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;447&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;448&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;449&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;450&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;451&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;452&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;453&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;454&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;455&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;456&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;457&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;Windows.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;GdiPlus.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;winsock2.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt;&lt;span class=&#34;string&#34;&gt;&amp;lt;iostream&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;pragma&lt;/span&gt; comment(lib, &lt;span class=&#34;string&#34;&gt;&amp;quot;gdiplus.lib&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;pragma&lt;/span&gt; comment(lib, &lt;span class=&#34;string&#34;&gt;&amp;quot;ws2_32.lib&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;using&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;namespace&lt;/span&gt; std;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;using&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;namespace&lt;/span&gt; Gdiplus;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 定义一个 Socket 类，用于封装网络通信相关的操作&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;Socket&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	WSADATA m_wsaData;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	SOCKET m_sock;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	sockaddr_in m_serverAddr;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	sockaddr_in m_clientAddr;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;	&lt;span class=&#34;built_in&#34;&gt;Socket&lt;/span&gt;() : &lt;span class=&#34;built_in&#34;&gt;m_sock&lt;/span&gt;(INVALID_SOCKET) &amp;#123;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 初始化 WinSock 库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Init&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;WSAStartup&lt;/span&gt;(&lt;span class=&#34;built_in&#34;&gt;MAKEWORD&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;), &amp;amp;m_wsaData) != &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 创建套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Create&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; af, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; type, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; protocol)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_sock = &lt;span class=&#34;built_in&#34;&gt;socket&lt;/span&gt;(af, type, protocol);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (m_sock == INVALID_SOCKET)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 绑定套接字到本地地址和端口&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Bind&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;short&lt;/span&gt; port)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;memset&lt;/span&gt;(&amp;amp;m_serverAddr, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(m_serverAddr));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_family = AF_INET;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_addr.s_addr = &lt;span class=&#34;built_in&#34;&gt;htonl&lt;/span&gt;(INADDR_ANY);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_serverAddr.sin_port = &lt;span class=&#34;built_in&#34;&gt;htons&lt;/span&gt;(port);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;bind&lt;/span&gt;(m_sock, (sockaddr*)&amp;amp;m_serverAddr, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(m_serverAddr)) == SOCKET_ERROR)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 监听套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Listen&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; backlog)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;listen&lt;/span&gt;(m_sock, backlog) == SOCKET_ERROR)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 接受客户端的连接&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Accept&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(Socket&amp;amp; client)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; addrLen = &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(m_clientAddr);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        client.m_sock = &lt;span class=&#34;built_in&#34;&gt;accept&lt;/span&gt;(m_sock, (sockaddr*)&amp;amp;m_clientAddr, &amp;amp;addrLen);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (client.m_sock == INVALID_SOCKET)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 接收数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Receive&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* buffer, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; len)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;recv&lt;/span&gt;(m_sock, buffer, len, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 发送数据&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Send&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;* buffer, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; len)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;send&lt;/span&gt;(m_sock, buffer, len, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 关闭套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Close&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;closesocket&lt;/span&gt;(m_sock);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        m_sock = INVALID_SOCKET;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 清理 WinSock 库&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Cleanup&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;WSACleanup&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 定义一个 RemoteDesktopServer 类，用于提供远程桌面服务&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;class&lt;/span&gt; &lt;span class=&#34;title class_&#34;&gt;RemoteDesktopServer&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    Socket m_socket; &lt;span class=&#34;comment&#34;&gt;// 用于网络通信的套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;public&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 初始化远程桌面服务器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Init&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;short&lt;/span&gt; port)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Init&lt;/span&gt;())&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Create&lt;/span&gt;(AF_INET, SOCK_STREAM, IPPROTO_TCP))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Bind&lt;/span&gt;(port))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Listen&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;10&lt;/span&gt;))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 运行远程桌面服务器&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;Run&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 不断循环，接受客户端的连接&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (&lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            Socket client;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!m_socket.&lt;span class=&#34;built_in&#34;&gt;Accept&lt;/span&gt;(client))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;continue&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;comment&#34;&gt;// 为客户端创建一个线程，用于处理客户端的请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            HANDLE hThread = &lt;span class=&#34;built_in&#34;&gt;CreateThread&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, ClientThreadProc, &amp;amp;client, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (hThread == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                client.&lt;span class=&#34;built_in&#34;&gt;Close&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;continue&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;CloseHandle&lt;/span&gt;(hThread);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 客户端线程的回调函数，用于处理客户端的请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; DWORD WINAPI &lt;span class=&#34;title&#34;&gt;ClientThreadProc&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(LPVOID lpParam)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        Socket* pClient = (Socket*)lpParam;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 不断循环，处理客户端的请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (&lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;comment&#34;&gt;// 接收客户端的命令&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; cmd[&lt;span class=&#34;number&#34;&gt;256&lt;/span&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; len = pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;(cmd, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(cmd));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (len &amp;lt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;break&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;comment&#34;&gt;// 根据命令类型执行相应的操作&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;strcmp&lt;/span&gt;(cmd, &lt;span class=&#34;string&#34;&gt;&amp;quot;screenshot&amp;quot;&lt;/span&gt;) == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;comment&#34;&gt;// 处理屏幕截图请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;built_in&#34;&gt;HandleScreenshotRequest&lt;/span&gt;(*pClient);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;strcmp&lt;/span&gt;(cmd, &lt;span class=&#34;string&#34;&gt;&amp;quot;mouse move&amp;quot;&lt;/span&gt;) == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;comment&#34;&gt;// 处理鼠标移动请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, y;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;x, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(x));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;y, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(y));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;built_in&#34;&gt;HandleMouseMoveRequest&lt;/span&gt;(x, y);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;strcmp&lt;/span&gt;(cmd, &lt;span class=&#34;string&#34;&gt;&amp;quot;mouse click&amp;quot;&lt;/span&gt;) == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;comment&#34;&gt;// 处理鼠标单击请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, y;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;x, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(x));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;y, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(y));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;built_in&#34;&gt;HandleMouseClickRequest&lt;/span&gt;(x, y);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;strcmp&lt;/span&gt;(cmd, &lt;span class=&#34;string&#34;&gt;&amp;quot;key input&amp;quot;&lt;/span&gt;) == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;comment&#34;&gt;// 处理键盘输入请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; key;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Receive&lt;/span&gt;(&amp;amp;key, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(key));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;built_in&#34;&gt;HandleKeyInputRequest&lt;/span&gt;(key);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;break&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 关闭客户端的套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        pClient-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Close&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;delete&lt;/span&gt; pClient;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理屏幕截图请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;HandleScreenshotRequest&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(Socket&amp;amp; client)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 获取屏幕的宽高&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; width = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CXSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; height = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CYSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 创建内存 DC&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HDC hdcMem = &lt;span class=&#34;built_in&#34;&gt;CreateCompatibleDC&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (hdcMem == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 创建位图&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HBITMAP hbm = &lt;span class=&#34;built_in&#34;&gt;CreateCompatibleBitmap&lt;/span&gt;(&lt;span class=&#34;built_in&#34;&gt;GetDC&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;), width, height);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (hbm == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将位图选入内存 DC&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HBITMAP hbmOld = (HBITMAP)&lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (hbmOld == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将屏幕拷贝到内存 DC&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!&lt;span class=&#34;built_in&#34;&gt;BitBlt&lt;/span&gt;(hdcMem, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, width, height, &lt;span class=&#34;built_in&#34;&gt;GetDC&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;), &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, SRCCOPY))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmOld);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将内存 DC 的图像保存到缓冲区&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        BITMAPINFOHEADER bih;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;memset&lt;/span&gt;(&amp;amp;bih, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(bih));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biSize = &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(bih);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biWidth = width;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biHeight = -height;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biPlanes = &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biBitCount = &lt;span class=&#34;number&#34;&gt;24&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bih.biCompression = BI_RGB;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        BYTE* pBuf = &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HBITMAP hbmDib = &lt;span class=&#34;built_in&#34;&gt;CreateDIBSection&lt;/span&gt;(hdcMem, (BITMAPINFO*)&amp;amp;bih, DIB_RGB_COLORS, (&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt;**)&amp;amp;pBuf, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (hbmDib == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmOld);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将内存 DC 的图像复制到位图中&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!&lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmDib))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbmDib);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmOld);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将位图的图像转换为 JPEG 格式并发送到客户端&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!&lt;span class=&#34;built_in&#34;&gt;SendScreenshot&lt;/span&gt;(client, pBuf, width, height))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbmDib);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmOld);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 清理资源&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbmDib);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;SelectObject&lt;/span&gt;(hdcMem, hbmOld);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;DeleteObject&lt;/span&gt;(hbm);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;DeleteDC&lt;/span&gt;(hdcMem);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 将位图的图像转换为 JPEG 格式并发送到客户端&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;bool&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;SendScreenshot&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(Socket&amp;amp; client, BYTE* pBuf, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; width, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; height)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 初始化 GDI+&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        GdiplusStartupInput gdiplusStartupInput;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        ULONG_PTR gdiplusToken;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GdiplusStartup&lt;/span&gt;(&amp;amp;gdiplusToken, &amp;amp;gdiplusStartupInput, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将位图的图像转换为 JPEG 格式&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;function&#34;&gt;Bitmap &lt;span class=&#34;title&#34;&gt;bmp&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(width, height, width * &lt;span class=&#34;number&#34;&gt;3&lt;/span&gt;, PixelFormat24bppRGB, pBuf)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        CLSID clsid;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GetEncoderClsid&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;L&amp;quot;image/jpeg&amp;quot;&lt;/span&gt;, &amp;amp;clsid);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        IStream* pStream = &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bmp.&lt;span class=&#34;built_in&#34;&gt;Save&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;L&amp;quot;screenshot.jpg&amp;quot;&lt;/span&gt;, &amp;amp;clsid, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;CreateStreamOnHGlobal&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;, TRUE, &amp;amp;pStream) != S_OK)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        bmp.&lt;span class=&#34;built_in&#34;&gt;Save&lt;/span&gt;(pStream, &amp;amp;clsid, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HGLOBAL hGlobal = &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;; &lt;span class=&#34;comment&#34;&gt;// 修改为 HGLOBAL 类型&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;GetHGlobalFromStream&lt;/span&gt;(pStream, &amp;amp;hGlobal) != S_OK) &lt;span class=&#34;comment&#34;&gt;// 修改为 HGLOBAL 类型&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Release&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        ULONG cbSize = &lt;span class=&#34;built_in&#34;&gt;GlobalSize&lt;/span&gt;(hGlobal); &lt;span class=&#34;comment&#34;&gt;// 修改为 HGLOBAL 类型&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        BYTE* pJpegBuf = (BYTE*)&lt;span class=&#34;built_in&#34;&gt;GlobalLock&lt;/span&gt;(hGlobal); &lt;span class=&#34;comment&#34;&gt;// 修改为 HGLOBAL 类型&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (pJpegBuf == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Release&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        LARGE_INTEGER li;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        li.QuadPart = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Seek&lt;/span&gt;(li, STREAM_SEEK_SET, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;) != S_OK)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GlobalFree&lt;/span&gt;(pJpegBuf);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Release&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Read&lt;/span&gt;(pJpegBuf, cbSize, &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;) != S_OK)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GlobalFree&lt;/span&gt;(pJpegBuf);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Release&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        pStream-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;Release&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GdiplusShutdown&lt;/span&gt;(gdiplusToken);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将 JPEG 数据的长度发送到客户端&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (client.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)&amp;amp;cbSize, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(cbSize)) &amp;lt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GlobalFree&lt;/span&gt;(pJpegBuf);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 将 JPEG 数据发送到客户端&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (client.&lt;span class=&#34;built_in&#34;&gt;Send&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)pJpegBuf, cbSize) &amp;lt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;built_in&#34;&gt;GlobalFree&lt;/span&gt;(pJpegBuf);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;false&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 清理资源&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GlobalFree&lt;/span&gt;(pJpegBuf);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;literal&#34;&gt;true&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 获取图像编码器的 CLSID&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;GetEncoderClsid&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; WCHAR* format, CLSID* pClsid)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        UINT num = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, size = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GetImageEncodersSize&lt;/span&gt;(&amp;amp;num, &amp;amp;size);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (size == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        ImageCodecInfo* pImageCodecInfo = (ImageCodecInfo*)&lt;span class=&#34;built_in&#34;&gt;malloc&lt;/span&gt;(size);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (pImageCodecInfo == &lt;span class=&#34;literal&#34;&gt;NULL&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;GetImageEncoders&lt;/span&gt;(num, size, pImageCodecInfo);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (UINT i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt; num; ++i)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (&lt;span class=&#34;built_in&#34;&gt;wcscmp&lt;/span&gt;(pImageCodecInfo[i].MimeType, format) == &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                *pClsid = pImageCodecInfo[i].Clsid;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;built_in&#34;&gt;free&lt;/span&gt;(pImageCodecInfo);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;free&lt;/span&gt;(pImageCodecInfo);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理鼠标移动请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;HandleMouseMoveRequest&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; y)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 获取屏幕的宽高&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; width = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CXSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; height = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CYSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 计算相对于屏幕的坐标&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;double&lt;/span&gt; fx = (&lt;span class=&#34;type&#34;&gt;double&lt;/span&gt;)x / &lt;span class=&#34;number&#34;&gt;65535.0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 移动鼠标&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;SetCursorPos&lt;/span&gt;(x, y);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理鼠标单击请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;HandleMouseClickRequest&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; x, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; y)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 获取屏幕的宽高&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; width = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CXSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; height = &lt;span class=&#34;built_in&#34;&gt;GetSystemMetrics&lt;/span&gt;(SM_CYSCREEN);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 计算相对于屏幕的坐标&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;double&lt;/span&gt; fx = (&lt;span class=&#34;type&#34;&gt;double&lt;/span&gt;)x / &lt;span class=&#34;number&#34;&gt;65535.0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;double&lt;/span&gt; fy = (&lt;span class=&#34;type&#34;&gt;double&lt;/span&gt;)y / &lt;span class=&#34;number&#34;&gt;65535.0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; cx = (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt;)(fx * width);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; cy = (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt;)(fy * height);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 移动鼠标&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;SetCursorPos&lt;/span&gt;(cx, cy);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 发送鼠标左键单击消息&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        INPUT input;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;memset&lt;/span&gt;(&amp;amp;input, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(input));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        input.type = INPUT_MOUSE;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        input.mi.dwFlags = MOUSEEVENTF_LEFTDOWN | MOUSEEVENTF_LEFTUP;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;SendInput&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;, &amp;amp;input, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(input));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;comment&#34;&gt;// 处理键盘输入请求&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;static&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;HandleKeyInputRequest&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; key)&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;    &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 获取键盘的输入模式&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        HKL layout = &lt;span class=&#34;built_in&#34;&gt;GetKeyboardLayout&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        UINT vk = &lt;span class=&#34;built_in&#34;&gt;MapVirtualKeyExA&lt;/span&gt;(&lt;span class=&#34;built_in&#34;&gt;VkKeyScanExA&lt;/span&gt;(key, layout), &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, layout);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;comment&#34;&gt;// 发送键盘输入消息&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        INPUT input;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;memset&lt;/span&gt;(&amp;amp;input, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(input));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        input.type = INPUT_KEYBOARD;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        input.ki.wVk = vk;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;SendInput&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;, &amp;amp;input, &lt;span class=&#34;built_in&#34;&gt;sizeof&lt;/span&gt;(input));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;private&lt;/span&gt;:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    Socket m_socket; &lt;span class=&#34;comment&#34;&gt;// 监听套接字&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    RemoteDesktopServer server;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (!server.&lt;span class=&#34;built_in&#34;&gt;Init&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;5555&lt;/span&gt;))&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        cout&amp;lt;&amp;lt;&lt;span class=&#34;string&#34;&gt;&amp;quot;启动服务器失败！&amp;quot;&lt;/span&gt;&amp;lt;&amp;lt;endl;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    server.&lt;span class=&#34;built_in&#34;&gt;Run&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;希望这些代码能帮到你！&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/categories/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/categories/%E7%BC%96%E7%A8%8B/" />
        <category term="远程桌面" scheme="https://jdjwzx233.cn/categories/%E8%BF%9C%E7%A8%8B%E6%A1%8C%E9%9D%A2/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/tags/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/tags/%E7%BC%96%E7%A8%8B/" />
        <category term="信息技术" scheme="https://jdjwzx233.cn/tags/%E4%BF%A1%E6%81%AF%E6%8A%80%E6%9C%AF/" />
        <category term="远程桌面" scheme="https://jdjwzx233.cn/tags/%E8%BF%9C%E7%A8%8B%E6%A1%8C%E9%9D%A2/" />
        <category term="控制器" scheme="https://jdjwzx233.cn/tags/%E6%8E%A7%E5%88%B6%E5%99%A8/" />
        <category term="WinSock" scheme="https://jdjwzx233.cn/tags/WinSock/" />
        <category term="GDI+" scheme="https://jdjwzx233.cn/tags/GDI/" />
        <category term="MFC" scheme="https://jdjwzx233.cn/tags/MFC/" />
        <updated>2022-12-23T09:12:13.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/12/22/%E5%86%99%E5%9B%BE%E5%83%8F%E7%95%8C%E9%9D%A2%E8%BD%AF%E4%BB%B6/</id>
        <title>用c++写图像界面软件(QT)</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/12/22/%E5%86%99%E5%9B%BE%E5%83%8F%E7%95%8C%E9%9D%A2%E8%BD%AF%E4%BB%B6/"/>
        <content type="html">&lt;p&gt;&lt;strong&gt;在 C++ 中编写图形界面软件的方法有很多种，下面介绍一种使用 Qt 库来编写图形界面软件的方法。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;首先，需要安装 Qt 开发环境。你可以在 Qt 官网下载安装包，并按照安装说明进行安装。&lt;br /&gt;
然后，在 Qt Creator 中创建一个新的项目。在项目向导中，选择 “应用程序”，并选择 “控件” 作为模板。这会创建一个有一个窗口和几个控件（按钮、标签等）的基本图形界面应用程序。&lt;br /&gt;
现在，你可以开始在界面中添加各种控件，例如图片、文本框、复选框等。可以使用 Qt Designer 工具来设计界面。&lt;/p&gt;
&lt;p&gt;在设计界面时，你可以使用拖放控件的方式，将控件放到界面上。然后，你可以使用属性编辑器来设置控件的各种属性，例如大小、颜色、字体等。&lt;/p&gt;
&lt;p&gt;在代码中，你可以使用信号和槽机制来连接界面中的控件和应用程序的功能。例如，可以让按钮的单击信号连接到一个槽函数，从而在按钮被单击时执行特定的操作。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;下面是一个简单的示例代码，显示了如何使用 Qt 创建一个带有一个按钮的窗口，并在按钮被单击时弹出对话框：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QPushButton&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QMessageBox&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QPushButton &lt;span class=&#34;title&#34;&gt;button&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Click me&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QObject::&lt;span class=&#34;built_in&#34;&gt;connect&lt;/span&gt;(&amp;amp;button, &amp;amp;QPushButton::clicked, []() &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        QMessageBox::&lt;span class=&#34;built_in&#34;&gt;information&lt;/span&gt;(&lt;span class=&#34;literal&#34;&gt;nullptr&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;quot;Title&amp;quot;&lt;/span&gt;, &lt;span class=&#34;string&#34;&gt;&amp;quot;Hello, World!&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    button.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;接下来，我们来看如何在代码中添加菜单栏。&lt;/p&gt;
&lt;p&gt;首先，在界面设计器中添加一个菜单栏控件。然后，在代码中使用  &lt;code&gt;QMenuBar&lt;/code&gt;  类创建一个菜单栏对象，并将其添加到窗口中。&lt;/p&gt;
&lt;p&gt;接下来，你可以使用  &lt;code&gt;QMenu&lt;/code&gt;  类创建菜单，并添加到菜单栏中。你还可以使用  &lt;code&gt;QAction&lt;/code&gt;  类创建菜单项，并添加到菜单中。&lt;/p&gt;
&lt;p&gt;例如，下面的代码演示了如何创建一个带有 “文件” 菜单的菜单栏，其中包含 “打开” 和 “保存” 两个菜单项：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QMainWindow&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QMenuBar&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QMenu&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QAction&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QMainWindow window;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    window.&lt;span class=&#34;built_in&#34;&gt;setWindowTitle&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;My App&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QMenuBar *menuBar = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QMenuBar&lt;/span&gt;(&amp;amp;window);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QMenu *fileMenu = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QMenu&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;File&amp;quot;&lt;/span&gt;, menuBar);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QAction *openAction = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QAction&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Open&amp;quot;&lt;/span&gt;, fileMenu);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QAction *saveAction = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QAction&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Save&amp;quot;&lt;/span&gt;, fileMenu);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    fileMenu-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addAction&lt;/span&gt;(openAction);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    fileMenu-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addAction&lt;/span&gt;(saveAction);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    menuBar-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addMenu&lt;/span&gt;(fileMenu);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    window.&lt;span class=&#34;built_in&#34;&gt;setMenuBar&lt;/span&gt;(menuBar);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    window.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;为了在图形界面软件中显示图片，你可以使用 Qt 中的  &lt;code&gt;QLabel&lt;/code&gt;  控件。&lt;/p&gt;
&lt;p&gt;首先，在界面设计器中添加一个  &lt;code&gt;QLabel&lt;/code&gt;  控件。然后，在代码中，你可以使用  &lt;code&gt;QLabel&lt;/code&gt;  类的  &lt;code&gt;setPixmap&lt;/code&gt;  方法来设置要显示的图片。&lt;/p&gt;
&lt;p&gt;例如，下面的代码演示了如何在图形界面中显示一张名为 “image.png” 的图片：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QLabel&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QPixmap&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QLabel label;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QPixmap &lt;span class=&#34;title&#34;&gt;pixmap&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;image.png&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;setPixmap&lt;/span&gt;(pixmap);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;注意，在使用  &lt;code&gt;QLabel&lt;/code&gt;  显示图片时，需要使用  &lt;code&gt;QPixmap&lt;/code&gt;  类来加载图片文件。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;如果你想要在图形界面中显示动态图像，你可以使用 Qt 中的  &lt;code&gt;QMovie&lt;/code&gt;  类。 &lt;code&gt;QMovie&lt;/code&gt;  类可以用来播放 GIF 动画。&lt;/p&gt;
&lt;p&gt;例如，下面的代码演示了如何在图形界面中播放名为 “animation.gif” 的 GIF 动画：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QLabel&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QMovie&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QLabel label;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QMovie &lt;span class=&#34;title&#34;&gt;movie&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;animation.gif&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;setMovie&lt;/span&gt;(&amp;amp;movie);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    movie.&lt;span class=&#34;built_in&#34;&gt;start&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;现在，我们来看如何在图形界面软件中添加图表。&lt;/p&gt;
&lt;p&gt;首先，你需要在界面设计器中添加一个图表控件。Qt 中有多种图表控件可供选择，包括柱状图、折线图、饼图等。&lt;/p&gt;
&lt;p&gt;然后，你可以使用  &lt;code&gt;QChart&lt;/code&gt;  类创建图表对象，并使用  &lt;code&gt;QAbstractSeries&lt;/code&gt;  类的子类（例如  &lt;code&gt;QLineSeries&lt;/code&gt; 、 &lt;code&gt;QBarSeries&lt;/code&gt;  等）创建数据序列。你还可以使用  &lt;code&gt;QValueAxis&lt;/code&gt;  类创建坐标轴，并将它们添加到图表中。&lt;/p&gt;
&lt;p&gt;例如，下面的代码演示了如何创建一个带有两个数据序列的柱状图：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;33&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;34&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;35&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;36&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;37&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;38&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;39&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QChart&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QChartView&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QBarSeries&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QBarSet&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QValueAxis&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QBarSet *set1 = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QBarSet&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Data 1&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    *set1 &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;3&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;4&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;5&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QBarSet *set2 = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QBarSet&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Data 2&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    *set2 &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;5&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;4&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;3&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt; &amp;lt;&amp;lt; &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QBarSeries *series = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QBarSeries&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    series-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;append&lt;/span&gt;(set1);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    series-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;append&lt;/span&gt;(set2);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QChart *chart = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QChart&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addSeries&lt;/span&gt;(series);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setTitle&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Example Chart&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QValueAxis *axisX = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QValueAxis&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    axisX-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setRange&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;6&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    axisX-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setLabelFormat&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;%g&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addAxis&lt;/span&gt;(axisX, Qt::AlignBottom);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    series-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;attachAxis&lt;/span&gt;(axisX);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QValueAxis *axisY = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QValueAxis&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    axisY-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setRange&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;6&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    axisY-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setTitleText&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Y-axis&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addAxis&lt;/span&gt;(axisY, Qt::AlignLeft);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    series-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;attachAxis&lt;/span&gt;(axisY);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QChartView &lt;span class=&#34;title&#34;&gt;chartView&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(chart)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;setRenderHint&lt;/span&gt;(QPainter::Antialiasing);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;resize&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;300&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们首先创建了两个数据序列（使用  &lt;code&gt;QBarSet&lt;/code&gt;  类），然后将它们添加到一个  &lt;code&gt;QBarSeries&lt;/code&gt;  对象中。接着，我们创建了一个  &lt;code&gt;QChart&lt;/code&gt;  对象，并将数据序列添加到图表中。最后，我们创建了两个坐标轴（使用  &lt;code&gt;QValueAxis&lt;/code&gt;  类），并将它们添加到图表中。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;接下来，让我们来看如何在图形界面软件中添加交互式图表。&lt;/p&gt;
&lt;p&gt;为了实现交互式图表，你可以使用 Qt 中的  &lt;code&gt;QChartView&lt;/code&gt;  类。 &lt;code&gt;QChartView&lt;/code&gt;  类提供了一些内置的交互工具，包括缩放、拖拽、轴调整等。&lt;/p&gt;
&lt;p&gt;要使用  &lt;code&gt;QChartView&lt;/code&gt;  类，你需要先创建一个  &lt;code&gt;QChart&lt;/code&gt;  对象，然后将其传递给  &lt;code&gt;QChartView&lt;/code&gt;  的构造函数。例如，下面的代码演示了如何创建一个交互式的折线图：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QChart&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QChartView&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QLineSeries&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QValueAxis&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QLineSeries *series = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QLineSeries&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    *series &amp;lt;&amp;lt; &lt;span class=&#34;built_in&#34;&gt;QPointF&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;) &amp;lt;&amp;lt; &lt;span class=&#34;built_in&#34;&gt;QPointF&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;) &amp;lt;&amp;lt; &lt;span class=&#34;built_in&#34;&gt;QPointF&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;4&lt;/span&gt;) &amp;lt;&amp;lt; &lt;span class=&#34;built_in&#34;&gt;QPointF&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;3&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;9&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QChart *chart = &lt;span class=&#34;keyword&#34;&gt;new&lt;/span&gt; &lt;span class=&#34;built_in&#34;&gt;QChart&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;addSeries&lt;/span&gt;(series);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;setTitle&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;Simple line chart example&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chart-&amp;gt;&lt;span class=&#34;built_in&#34;&gt;createDefaultAxes&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QChartView &lt;span class=&#34;title&#34;&gt;chartView&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(chart)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;setRenderHint&lt;/span&gt;(QPainter::Antialiasing);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;resize&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;400&lt;/span&gt;, &lt;span class=&#34;number&#34;&gt;300&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    chartView.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们首先创建了一个数据序列（使用  &lt;code&gt;QLineSeries&lt;/code&gt;  类），然后将它添加到一个  &lt;code&gt;QChart&lt;/code&gt;  对象中。接着，我们调用  &lt;code&gt;QChart&lt;/code&gt;  类的  &lt;code&gt;createDefaultAxes&lt;/code&gt;  方法来创建默认的坐标轴。最后，我们创建了一个  &lt;code&gt;QChartView&lt;/code&gt;  对象，并将图表传递给它。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;接下来，让我们来看如何在图形界面软件中使用 OpenCV 读取和显示图像。&lt;/p&gt;
&lt;p&gt;首先，你需要安装 OpenCV 库。在 Windows 上，你可以使用 vcpkg 工具安装 OpenCV。在 Linux 上，你可以使用包管理器安装 OpenCV。&lt;/p&gt;
&lt;p&gt;然后，你需要在 Qt 工程中添加 OpenCV 的头文件和库文件。具体方法可以参考 Qt 文档。&lt;/p&gt;
&lt;p&gt;接着，你就可以使用 OpenCV 的  &lt;code&gt;cv::Mat&lt;/code&gt;  类来读取和显示图像了。例如，下面的代码演示了如何使用 OpenCV 读取名为 “image.png” 的图片并在图形界面中显示：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QLabel&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;opencv2/opencv.hpp&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    cv::Mat image = cv::&lt;span class=&#34;built_in&#34;&gt;imread&lt;/span&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;image.png&amp;quot;&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QImage qimage = &lt;span class=&#34;built_in&#34;&gt;QImage&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)(image.data),&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                           image.cols, image.rows, image.step, QImage::Format_RGB888);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QLabel label;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;setPixmap&lt;/span&gt;(QPixmap::&lt;span class=&#34;built_in&#34;&gt;fromImage&lt;/span&gt;(qimage));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们使用 OpenCV 的  &lt;code&gt;imread&lt;/code&gt;  函数读取图片，然后将图片数据转换为  &lt;code&gt;QImage&lt;/code&gt;  对象。最后，我们使用  &lt;code&gt;QLabel&lt;/code&gt;  类显示图片。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;注意，如果你想要在图形界面软件中显示动态图像，你可以使用 Qt 中的  &lt;code&gt;QTimer&lt;/code&gt;  类来实现。&lt;/p&gt;
&lt;p&gt;例如，下面的代码演示了如何使用 OpenCV 读取视频并在图形界面中显示：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QApplication&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QLabel&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;QTimer&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;opencv2/opencv.hpp&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;main&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; argc, &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt; *argv[])&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;QApplication &lt;span class=&#34;title&#34;&gt;app&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(argc, argv)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;function&#34;&gt;cv::VideoCapture &lt;span class=&#34;title&#34;&gt;capture&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;string&#34;&gt;&amp;quot;video.mp4&amp;quot;&lt;/span&gt;)&lt;/span&gt;&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QLabel label;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QTimer timer;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    QObject::&lt;span class=&#34;built_in&#34;&gt;connect&lt;/span&gt;(&amp;amp;timer, &amp;amp;QTimer::timeout, [&amp;amp;]() &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        cv::Mat frame;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        capture &amp;gt;&amp;gt; frame;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (frame.&lt;span class=&#34;built_in&#34;&gt;empty&lt;/span&gt;()) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            capture.&lt;span class=&#34;built_in&#34;&gt;set&lt;/span&gt;(cv::CAP_PROP_POS_AVI_RATIO, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            capture &amp;gt;&amp;gt; frame;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        QImage qimage = &lt;span class=&#34;built_in&#34;&gt;QImage&lt;/span&gt;((&lt;span class=&#34;type&#34;&gt;const&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;unsigned&lt;/span&gt; &lt;span class=&#34;type&#34;&gt;char&lt;/span&gt;*)(frame.data),&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                               frame.cols, frame.rows, frame.step, QImage::Format_RGB888);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        label.&lt;span class=&#34;built_in&#34;&gt;setPixmap&lt;/span&gt;(QPixmap::&lt;span class=&#34;built_in&#34;&gt;fromImage&lt;/span&gt;(qimage));&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    timer.&lt;span class=&#34;built_in&#34;&gt;start&lt;/span&gt;(&lt;span class=&#34;number&#34;&gt;1000&lt;/span&gt; / &lt;span class=&#34;number&#34;&gt;30&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    label.&lt;span class=&#34;built_in&#34;&gt;show&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; app.&lt;span class=&#34;built_in&#34;&gt;exec&lt;/span&gt;();&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;在这段代码中，我们使用 OpenCV 的  &lt;code&gt;VideoCapture&lt;/code&gt;  类读取视频，然后使用  &lt;code&gt;QTimer&lt;/code&gt;  类定时获取视频帧并更新图像。注意，我们使用  &lt;code&gt;QImage&lt;/code&gt;  类将视频帧转换为图像，并使用  &lt;code&gt;QLabel&lt;/code&gt;  类显示图像。&lt;/p&gt;
&lt;p&gt;这是一个简单的示例，你还可以自己添加更多的功能，例如暂停、快进、播放速度调整等。&lt;/p&gt;
&lt;hr /&gt;
&lt;p&gt;&lt;strong&gt;希望这些信息对你有帮助！如果喜欢的话，可以在下方打赏作者哦&lt;/strong&gt;&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/categories/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/categories/%E7%BC%96%E7%A8%8B/" />
        <category term="QT" scheme="https://jdjwzx233.cn/categories/QT/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/tags/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/tags/%E7%BC%96%E7%A8%8B/" />
        <category term="信息技术" scheme="https://jdjwzx233.cn/tags/%E4%BF%A1%E6%81%AF%E6%8A%80%E6%9C%AF/" />
        <category term="QT" scheme="https://jdjwzx233.cn/tags/QT/" />
        <category term="图像界面" scheme="https://jdjwzx233.cn/tags/%E5%9B%BE%E5%83%8F%E7%95%8C%E9%9D%A2/" />
        <updated>2022-12-22T22:49:22.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/12/22/%E5%B8%B8%E7%94%A8%E7%9A%84%E6%8E%92%E5%BA%8F%E7%AE%97%E6%B3%95/</id>
        <title>C++中常用的排序算法</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/12/22/%E5%B8%B8%E7%94%A8%E7%9A%84%E6%8E%92%E5%BA%8F%E7%AE%97%E6%B3%95/"/>
        <content type="html">&lt;p&gt;在 C++ 中，常用的排序算法包括：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;冒泡排序（Bubble Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;冒泡排序是一种简单的排序算法，它通过重复地遍历要排序的数列并比较相邻的两个数来排序。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;bubbleSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt; n - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; j = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; j &amp;lt; n - i - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; j++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (arr[j] &amp;gt; arr[j + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;]) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[j];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                arr[j] = arr[j + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                arr[j + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;2&#34;&gt;
&lt;li&gt;选择排序（Selection Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;选择排序是一种简单的排序算法，它通过遍历数列来找到最小值并将其放到数列的起始位置，然后再从剩余未排序的数列中继续寻找最小值并放到已排序的数列末尾，以此类推直到所有数列排序完毕。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;selectionSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt; n - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; minIndex = i;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; j = i + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; j &amp;lt; n; j++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (arr[j] &amp;lt; arr[minIndex]) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                minIndex = j;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[i] = arr[minIndex];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[minIndex] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;3&#34;&gt;
&lt;li&gt;插入排序（Insertion Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;插入排序是一种简单的排序算法，它通过将数列分成已排序和未排序两部分，然后从未排序的数列中取出第一个数，并插入到已排序的数列中的适当位置，使得已排序的数列仍然有序。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;insertionSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; i &amp;lt; n; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; key = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; j = i - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (j &amp;gt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt; &amp;amp;&amp;amp; arr[j] &amp;gt; key) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[j + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;] = arr[j];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            j--;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[j + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;] = key;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;4&#34;&gt;
&lt;li&gt;归并排序（Merge Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;归并排序是一种分治算法，它通过递归地将数列分成两半，然后将两半分别排序，最后将两半合并起来得到最终的排序结果。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;30&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;31&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;32&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;merge&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; left[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; leftSize, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; right[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; rightSize)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, j = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, k = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (i &amp;lt; leftSize &amp;amp;&amp;amp; j &amp;lt; rightSize) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (left[i] &amp;lt; right[j]) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[k++] = left[i++];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125; &lt;span class=&#34;keyword&#34;&gt;else&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[k++] = right[j++];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (i &amp;lt; leftSize) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[k++] = left[i++];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (j &amp;lt; rightSize) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[k++] = right[j++];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;mergeSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (n &amp;lt; &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;) &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; mid = n / &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; left[mid];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; right[n - mid];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt; mid; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        left[i] = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = mid; i &amp;lt; n; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        right[i - mid] = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;mergeSort&lt;/span&gt;(left, mid);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;mergeSort&lt;/span&gt;(right, n - mid);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;built_in&#34;&gt;merge&lt;/span&gt;(arr, left, mid, right, n - mid);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;5&#34;&gt;
&lt;li&gt;快速排序（Quick Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;快速排序是一种分治算法，它通过选择一个基准元素，将数列分成两部分，使得左边的所有元素都小于基准元素，右边的所有元素都大于基准元素，然后递归地对两部分进行快速排序，最终得到有序的数列。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;partition&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; low, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; high)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; pivot = arr[high];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = low - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; j = low; j &amp;lt;= high - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; j++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (arr[j] &amp;lt; pivot) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            i++;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[i] = arr[j];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[j] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[i + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    arr[i + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;] = arr[high];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    arr[high] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;return&lt;/span&gt; i + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;quickSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; low, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; high)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (low &amp;lt; high) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; pi = &lt;span class=&#34;built_in&#34;&gt;partition&lt;/span&gt;(arr, low, high);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;quickSort&lt;/span&gt;(arr, low, pi - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;quickSort&lt;/span&gt;(arr, pi + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;, high);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;这些排序算法的时间复杂度各不相同，在不同情况下可能会有所差异。你可以根据自己的需要来选择适合的排序算法。&lt;br /&gt;
除了以上几种常用的排序算法之外，还有其他一些不太常用的排序算法，例如：&lt;/p&gt;
&lt;ol start=&#34;6&#34;&gt;
&lt;li&gt;希尔排序（Shell Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;希尔排序是一种插入排序的变种，它通过设置一个间隔来将数列划分成若干个小的数列，然后对每个小数列进行插入排序，最终得到有序的数列。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;shellSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; gap = n / &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;; gap &amp;gt; &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; gap /= &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = gap; i &amp;lt; n; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; j;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (j = i; j &amp;gt;= gap &amp;amp;&amp;amp; arr[j - gap] &amp;gt; temp; j -= gap) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;                arr[j] = arr[j - gap];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[j] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;7&#34;&gt;
&lt;li&gt;堆排序（Heap Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;堆排序是一种选择排序的变种，它通过建立一个堆来选择最大（或最小）的元素并放到数列末尾，然后将剩余的数列重新建堆并继续选择最大（或最小）的元素，以此类推直到所有数列排序完毕。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;15&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;16&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;17&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;18&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;19&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;20&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;21&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;22&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;23&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;24&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;25&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;26&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;27&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;28&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;29&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;heapify&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; largest = i;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; left = &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt; * i + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; right = &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt; * i + &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (left &amp;lt; n &amp;amp;&amp;amp; arr[left] &amp;gt; arr[largest]) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        largest = left;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (right &amp;lt; n &amp;amp;&amp;amp; arr[right] &amp;gt; arr[largest]) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        largest = right;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;if&lt;/span&gt; (largest != i) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[i] = arr[largest];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        arr[largest] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;built_in&#34;&gt;heapify&lt;/span&gt;(arr, n, largest);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;heapSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = n / &lt;span class=&#34;number&#34;&gt;2&lt;/span&gt; - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; i &amp;gt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i--) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;heapify&lt;/span&gt;(arr, n, i);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = n - &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;; i &amp;gt;= &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i--) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; temp = arr[&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;arr[&lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;] = arr[i];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;arr[i] = temp;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;built_in&#34;&gt;heapify&lt;/span&gt;(arr, i, &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;);&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;ol start=&#34;8&#34;&gt;
&lt;li&gt;计数排序（Counting Sort）&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;计数排序是一种非比较排序算法，它通过计算数列中每个数出现的次数来排序。它的时间复杂度为 O (n)，因此在数据范围较小的情况下可以使用计数排序。&lt;/p&gt;
&lt;p&gt;代码如下：&lt;/p&gt;
&lt;p&gt;&lt;figure class=&#34;highlight cpp&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;function&#34;&gt;&lt;span class=&#34;type&#34;&gt;void&lt;/span&gt; &lt;span class=&#34;title&#34;&gt;countingSort&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;(&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; arr[], &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; n, &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; maxValue)&lt;/span&gt; &lt;/span&gt;&amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; counts[maxValue + &lt;span class=&#34;number&#34;&gt;1&lt;/span&gt;];&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt;= maxValue; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        counts[i] = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt; n; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        counts[arr[i]]++;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &lt;span class=&#34;keyword&#34;&gt;for&lt;/span&gt; (&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; i = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;, j = &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;; i &amp;lt;= maxValue; i++) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &lt;span class=&#34;keyword&#34;&gt;while&lt;/span&gt; (counts[i]-- &amp;gt; &lt;span class=&#34;number&#34;&gt;0&lt;/span&gt;) &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;            arr[j++] = i;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;        &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    &amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;以上是 C++ 中的几种排序算法的代码，希望能帮到你。&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/categories/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/categories/%E7%BC%96%E7%A8%8B/" />
        <category term="算法" scheme="https://jdjwzx233.cn/categories/%E7%AE%97%E6%B3%95/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="c++" scheme="https://jdjwzx233.cn/tags/c/" />
        <category term="编程" scheme="https://jdjwzx233.cn/tags/%E7%BC%96%E7%A8%8B/" />
        <category term="信息技术" scheme="https://jdjwzx233.cn/tags/%E4%BF%A1%E6%81%AF%E6%8A%80%E6%9C%AF/" />
        <category term="算法" scheme="https://jdjwzx233.cn/tags/%E7%AE%97%E6%B3%95/" />
        <category term="排序" scheme="https://jdjwzx233.cn/tags/%E6%8E%92%E5%BA%8F/" />
        <category term="冒泡排序" scheme="https://jdjwzx233.cn/tags/%E5%86%92%E6%B3%A1%E6%8E%92%E5%BA%8F/" />
        <category term="选择排序" scheme="https://jdjwzx233.cn/tags/%E9%80%89%E6%8B%A9%E6%8E%92%E5%BA%8F/" />
        <category term="插入排序" scheme="https://jdjwzx233.cn/tags/%E6%8F%92%E5%85%A5%E6%8E%92%E5%BA%8F/" />
        <category term="归并排序" scheme="https://jdjwzx233.cn/tags/%E5%BD%92%E5%B9%B6%E6%8E%92%E5%BA%8F/" />
        <category term="快速排序" scheme="https://jdjwzx233.cn/tags/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F/" />
        <category term="希尔排序" scheme="https://jdjwzx233.cn/tags/%E5%B8%8C%E5%B0%94%E6%8E%92%E5%BA%8F/" />
        <category term="堆排序" scheme="https://jdjwzx233.cn/tags/%E5%A0%86%E6%8E%92%E5%BA%8F/" />
        <category term="计数排序" scheme="https://jdjwzx233.cn/tags/%E8%AE%A1%E6%95%B0%E6%8E%92%E5%BA%8F/" />
        <updated>2022-12-22T21:58:31.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/12/19/%E7%AE%80%E7%88%B1%E6%AF%8F%E7%AB%A0%E6%A6%82%E6%8B%AC%E8%B5%8F%E6%9E%90/</id>
        <title>《简爱》每章概括+赏析</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/12/19/%E7%AE%80%E7%88%B1%E6%AF%8F%E7%AB%A0%E6%A6%82%E6%8B%AC%E8%B5%8F%E6%9E%90/"/>
        <content type="html">&lt;h1 id=&#34;每章概括&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#每章概括&#34;&gt;#&lt;/a&gt; &lt;strong&gt;每章概括&lt;/strong&gt;：&lt;/h1&gt;
&lt;h2 id=&#34;第一章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第一章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第一章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简・爱的父亲是个穷牧师，当她还在幼年时，父母就染病双双去世。简・爱被送到盖茨海德庄园的舅母里德太太家抚养.&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二章:&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;舅父里德先生在红房子中去世后，简爱过了 10 年受尽歧视和虐待的生活。一次，由于反抗表哥的殴打，简被关进了红房子。肉体上的痛苦和心灵上的屈辱和恐惧，使她大病了一场。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第三章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第三章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;舅母把她视作眼中钉，并把她和自己的孩子隔离开来，并决定把她送进达罗沃德孤儿院。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第四章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第四章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第四章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;由于她与舅母的对抗更加公开和坚决，里德太太加快了送简爱去孤儿院的脚步，为了赶走简爱，她在勃洛克赫斯特先生面前处处中伤简爱，毁坏简爱的名誉。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第五章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第五章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第五章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;孤儿院教规严厉，生活艰苦，院长是个冷酷的伪君子。他用种种办法从精神和肉体上摧残孤儿。简爱吃不饱、穿不暖，继续受尽非人的折磨。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第六章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第六章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第六章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简・爱与孤儿海伦结成好友，教师潭泊尔小姐也很关心她。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第七章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第七章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第七章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱失手打碎了石板，被惩罚站在凳子上，当众受到羞辱，是海伦的微笑给了简爱力量。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第八章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第八章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第八章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;伤心的简爱到学校下课时才从凳子上下来，悲愤不已，海伦给她端来咖啡和面包，并不断开导她。谭波小姐也来看望她，并与海伦谈古论今，使简爱佩服不已。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第九章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第九章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第九章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;在孤儿院里一场传染性的斑疹伤寒，夺走了许多孤儿的生命，海伦就在这场伤寒中死去，这对简・爱 打击很大。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;斑疹伤寒使孤儿院有了大规模的改善。简在新的环境下接受了六年的教育，并在这所学校任教两年。由于谭波尔儿小姐的离开，简厌倦了孤儿院里的生活，登广告谋求家庭教师的职业。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十一章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十一章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十一章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;桑菲尔德庄园的女管家聘用了她。偌大的宅第只有一个不到 10 岁的女孩阿黛拉・瓦朗，罗切斯特先生是她的保护人，她是简爱的学生。简爱来到了桑费尔德庄园，那里的一切很庄严和气派。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十二章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十二章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十二章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;一天黄昏，简・爱外出散步，邂逅刚从国外归来的主人，这是他们第一次见面。罗切斯特从受惊的马上摔了下来，简急忙上前去扶他，回到家后简才知道他便是庄园主罗切斯特。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十三章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十三章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十三章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;阿黛尔很不容易教，不专心，处处找借口去寻找罗伯斯特先生。罗伯斯特先生与简爱面对面交流，了解简爱的过去，并对简爱的画做出评价。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十四章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十四章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十四章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;她发现她的主人是个性格忧郁、喜怒无常的人，对她的态度时好时坏。整幢房子沉郁空旷。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十五章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十五章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十五章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;夜里，简・爱简被一阵奇怪的笑声惊醒，发现罗切斯特的房门开着，床上着了火，她叫醒罗切斯特并扑灭火。罗切斯特告诉简・爱三楼住着一个女栽缝格雷斯・普尔，她神经错乱，时常发出令人毛骨悚然的狂笑声，并要她对此事严守秘密。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十六章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十六章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十六章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱苦思冥想理不清头绪，胡乱猜测缘由，想见到罗伯斯特先生又盼不到他。第十七章：罗切斯特回来后经常举行家宴，桑费尔德庄园上上下下开始忙碌起来。在一次家宴上他向一位名叫英格拉姆的漂亮小姐大献殷勤，简被召进客厅，却受到布兰奇母女的冷遇，她忍受屈辱，离开客厅。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十八章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十八章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十八章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;在宴会上罗切斯特坚持要简・爱也到客厅里去，客人们对简・爱的态度十分傲慢，而罗切斯特却邀请简・爱跳舞，此时罗切斯特已爱上简，而简也感觉到自己对罗切斯特产生感情。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第十九章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第十九章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第十九章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;罗切斯特外出，家里来了一个蒙着盖头的吉卜赛人。当轮到给简・爱算命时，简・爱发现这个神秘的吉卜赛人就是罗切斯特，他想借此试探简对他的感情。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;庄园里又来了个名梅森的陌生人，当晚他被三楼的神秘女人咬伤了，简帮罗切斯特把他秘密送走。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十一章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十一章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十一章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;不久，里德太太派人来找简，说她病危要见简一面。回到舅母家中，里德太太给她一封信，这封信是三年前简的叔父寄来的，向她打听侄女的消息，并把自己的遗产交给简・爱。里德太太谎称简在孤儿院病死了，直到临终前才良心发现把真相告诉简。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十二章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十二章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十二章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱又回到桑费尔德庄园感觉像回到家一样。人们都在猜测罗切斯特会向布兰奇小姐求婚。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十三章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十三章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十三章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;罗切斯特向简爱求爱，简爱答应了，心里充满了幸福感。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十四章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十四章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十四章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;罗切斯特与简爱筹备婚礼。罗伯斯特很宠简爱，简爱视罗贝斯特为她的整个世界，他是简爱的偶像。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十五章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十五章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十五章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;婚礼前夜，简・爱从梦中惊醒，看到一个身材高大、面目可憎的女人正在戴她的婚纱，然后把婚纱的面罩撕成碎片。罗切斯特告诉她那不过是一个梦，第二天当简醒来时发现婚纱的面罩真的成了碎片。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十六章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十六章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十六章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;婚礼如期举行，一位不速之客闯进了教堂，声称婚礼不能进行，他说罗切斯特 15 年前娶梅森先生的妹妹伯莎・梅森为妻。罗切斯特承认了这一事实，并领人们看被关在三楼的疯女人，那就是他的合法妻子。她有遗传性精神病史，就是她在罗彻斯特的房间放火，也是她撕碎简婚纱的面罩。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十七章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十七章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十七章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱经历一场严峻的考验，法律阻碍了他们的爱情，使两人陷入深深的痛苦之中。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十八章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十八章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十八章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;在一个凄风苦雨之夜，简・爱悲痛欲绝地离开了桑费尔德庄园。她仅有的积蓄花光后风餐露宿，沿途乞讨，历尽磨难，最后晕倒在牧师圣约翰家门前，被圣约翰和他的两个妹妹救了。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第二十九章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第二十九章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第二十九章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱睡了三天三夜，终于清醒了过来，在圣约翰家人的照料下，渐渐恢复体力。简・爱被圣约翰收留并为她谋了一个乡村教师的职位。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;第三十章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#第三十章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;第三十章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱渐渐熟悉了这里的一切。不久，简得知叔父去世并给她留下一笔遗产，同时还发现圣・约翰是她的表兄，简决定将财产平分。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十一章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十一章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十一章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;一座山村农舍成了简的家，她有二十名学生，其中能识字的只有三个，能写和算的一个也没有。简的责任就是要培育这种萌芽。黄昏时，简边望着日落的景象，一边自我安慰，这时候，圣约翰・里弗斯来了，询问简对第一天工作的感觉。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十二章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十二章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十二章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简爱全心全意忠实地做乡村女教师的工作，渐渐成了那一带乡亲们喜欢的人，那段日子，简爱表面上很平静，但常常在梦中遇到罗伯斯特先生，心里焦躁不安。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十三章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十三章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十三章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;圣约翰是个狂热的教徒，准备去印度传教，临行前向简・爱求婚，但他坦率地告诉她，他要娶她并不是因为爱她，而是他需要一个很有教养的助手。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十四章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十四章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十四章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简・爱觉得应该报答他的恩情，但迟迟不肯答应他。当夜，圣约翰在荒原上等待简・爱的答复，就在简・爱要作出决定的时候，她仿佛听到罗彻斯特在遥远的地方呼喊她的名字......&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十五章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十五章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十五章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;圣约翰非常自信简爱会追随他，并不断地做出各种努力帮助简爱尽快下定决心与他结婚。简爱在圣师的感召下差点失去了抗争的勇气，在那一刻，简爱又感受到内心有一种声音在不断地呼唤她，使简爱无法抗拒，简爱明白自己应该如何选择了。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十六章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十六章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十六章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;心灵有所感应的简爱赶回到桑菲尔德庄园，那座宅子已成废墟，得知疯女人放火后坠楼身亡，罗切斯特也受伤致残，孤独地生活在几英里外的一个农场里。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十七章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十七章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十七章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;简・爱终于找到了罗伯斯特先生并大受震动，和他结了婚，得到了自己理想的幸福生活。&lt;/strong&gt;&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;三十八章&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三十八章&#34;&gt;#&lt;/a&gt; &lt;strong&gt;三十八章：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;两年之后，罗切斯特治好了一只眼睛，他看到了简・爱为他生的第一个孩子。&lt;/strong&gt;&lt;/p&gt;
&lt;h1 id=&#34;赏析&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#赏析&#34;&gt;#&lt;/a&gt; &lt;strong&gt;赏析：&lt;/strong&gt;&lt;/h1&gt;
&lt;p&gt;&lt;strong&gt;这是一部以爱情为主题的小说，主人公简・爱是一个心地善良，善于思考的女性，她生活在社会的最低层，受尽磨难。她的生活草鱼令人同情，但她那倔强的性格和勇于追求平等幸福的精神更令人人们所赞赏。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;在里德太太家，10 岁的简面对舅母，表兄的歧视和虐待，已经表现出强烈的反抗情绪。在她的表兄殴打她的时候，她勇于回击，当舅母叫自己的孩子远离她的时候，她个、高喊 “他们不配和我在一起”，当她被囚禁在空房中的时候，想到自己所受的虐待，从内心发出了 “不公正” 的呐喊。在孤儿院，简的反抗性格更为鲜明，这和她的朋友海伦・朋斯忍耐顺从的性格形成了鲜明的对比。海伦・朋斯虽然遭受迫害却信奉 “爱你的仇人”，在宗教的麻痹下，没有仇恨，只有逆来顺受。而简对冷酷的校长和摧残她们的教师深恶痛绝。她对海伦说：“如果她用那根条子打我，我要从她手中夺过来，并且当面折断它。” 这充分表露了她的不甘和不向命运妥协的倔强性格。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;小说主要描写了简・爱与罗契斯特的爱情。简・爱的爱情观更加深化了她的个性。他认为爱情应该建立在平等基础上，而不应该取决于社会地位，财富和外貌上。只有男女相方能彼此相爱，这样才能得到真正的爱情。在追求个人的幸福时，简・爱表现出了异乎寻常的纯真，朴实的思想感情和一往无前的勇气。她并没有因为自己的仆人地位而放弃对幸福的追求，她的爱情是纯洁高尚的，她对罗契斯特的财富不屑一顾。她之所以钟情于他，只是因为他能平等待人。把她视为朋友，与她坦诚相见。对罗契斯特来说，简・爱犹如一股清新的风，使他精神为之一振。罗契斯特过去看惯了上层社会的冷酷和虚伪，简・爱的纯朴，善良和独立的个性重新唤起他对生活的追求和向往。因而他能真诚地在简面前表达他的善良的愿望和改过的决心。简爱是一部具有浓厚浪漫现实主义小说，整部作品以自叙形式写成。大量运用了心理描写是小说的一大特色。全书构思精巧，情节波澜起伏，给读者制造出一种阴森恐怖的气氛，而又不脱离一个中产阶级家庭的背景。作者还以行情的笔法描写了主人公之间的真挚爱情和自然风情，感情色彩丰富而强烈。这部优美，动人并带有神秘色彩的小说，至今仍保持着它独特的艺术魅力。&lt;/strong&gt;&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="概括" scheme="https://jdjwzx233.cn/tags/%E6%A6%82%E6%8B%AC/" />
        <category term="名著" scheme="https://jdjwzx233.cn/tags/%E5%90%8D%E8%91%97/" />
        <category term="简爱" scheme="https://jdjwzx233.cn/tags/%E7%AE%80%E7%88%B1/" />
        <category term="《简爱》" scheme="https://jdjwzx233.cn/tags/%E3%80%8A%E7%AE%80%E7%88%B1%E3%80%8B/" />
        <updated>2022-12-19T21:00:56.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/09/21/%E5%88%9D%E4%B8%AD%E5%8E%86%E5%8F%B2%E7%BA%AA%E5%B9%B4%E8%A1%A8(%E8%B6%85%E7%BA%A7%E5%AE%8C%E6%95%B4)/</id>
        <title>初中历史纪年表(超级完整)</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/09/21/%E5%88%9D%E4%B8%AD%E5%8E%86%E5%8F%B2%E7%BA%AA%E5%B9%B4%E8%A1%A8(%E8%B6%85%E7%BA%A7%E5%AE%8C%E6%95%B4)/"/>
        <content type="html">&lt;p&gt;&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_1.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_1&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_2.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_2&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_3.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_3&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_4.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_4&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_5.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_5&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_6.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_6&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_7.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_7&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_8.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_8&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Junior_High_School_History_Chronology/Junior_High_School_History_Chronology_9.jpeg&#34; alt=&#34;Junior_High_School_History_Chronology_9&#34; /&gt;&lt;br /&gt;
&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;a href=&#34;/download/Junior High School History Chronology.zip&#34; class=&#34;image&#34; data-background-image=&#34;/image/other/62fe0d5d77bf2.png&#34;&gt;&lt;/a&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;a href=&#34;/download/Junior High School History Chronology.zip&#34; class=&#34;title&#34;&gt;一键下载所有图片(ZIP)&lt;/a&gt;
          &lt;p class=&#34;desc&#34;&gt;一键下载所有图片(ZIP)&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;图片转载于&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cuZG9jaW4uY29tL3AtNjY5OTA5NDY4Lmh0bWw/ZG9jZnJvbT1ycmVsYQ==&#34;&gt;初中历史大事年表 - 豆丁网 (docin.com)&lt;/span&gt;，侵删。&lt;/p&gt;
&lt;/div&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="社会" scheme="https://jdjwzx233.cn/categories/%E7%A4%BE%E4%BC%9A/" />
        <category term="历史" scheme="https://jdjwzx233.cn/categories/%E5%8E%86%E5%8F%B2/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="社会" scheme="https://jdjwzx233.cn/tags/%E7%A4%BE%E4%BC%9A/" />
        <category term="历史" scheme="https://jdjwzx233.cn/tags/%E5%8E%86%E5%8F%B2/" />
        <category term="纪年表" scheme="https://jdjwzx233.cn/tags/%E7%BA%AA%E5%B9%B4%E8%A1%A8/" />
        <category term="初中" scheme="https://jdjwzx233.cn/tags/%E5%88%9D%E4%B8%AD/" />
        <updated>2022-09-21T22:41:08.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/09/21/%E5%88%9D%E4%B8%AD%E4%B8%96%E7%95%8C%E5%8E%86%E5%8F%B2%E5%B9%B4%E4%BB%A3%E5%B0%BA(%E5%A4%A7%E4%BA%8B%E5%B9%B4%E8%A1%A8)/</id>
        <title>初中世界历史年代尺(大事年表)</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/09/21/%E5%88%9D%E4%B8%AD%E4%B8%96%E7%95%8C%E5%8E%86%E5%8F%B2%E5%B9%B4%E4%BB%A3%E5%B0%BA(%E5%A4%A7%E4%BA%8B%E5%B9%B4%E8%A1%A8)/"/>
        <content type="html">&lt;p&gt;&lt;img data-src=&#34;/image/chronology_of_major_events/chronology_of_major_events_1.jpeg&#34; alt=&#34;chronology_of_major_events_1&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/chronology_of_major_events/chronology_of_major_events_2.jpeg&#34; alt=&#34;chronology_of_major_events_2&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/chronology_of_major_events/chronology_of_major_events_3.jpeg&#34; alt=&#34;chronology_of_major_events_3&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/chronology_of_major_events/chronology_of_major_events_4.jpeg&#34; alt=&#34;chronology_of_major_events_4&#34; /&gt;&lt;br /&gt;
&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;a href=&#34;/download/Junior high school world history chronology (chronology of major events).zip&#34; class=&#34;image&#34; data-background-image=&#34;/image/other/62fe0d5d77bf2.png&#34;&gt;&lt;/a&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;a href=&#34;/download/Junior high school world history chronology (chronology of major events).zip&#34; class=&#34;title&#34;&gt;一键下载所有图片(7Z)&lt;/a&gt;
          &lt;p class=&#34;desc&#34;&gt;一键下载所有图片(7Z)&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;图片转载于&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cuZG9jaW4uY29tL3AtMjY2NjU4Nzc3Ni5odG1s&#34;&gt; (完整版) 初中世界历史年代尺 (大事年表) - 豆丁网 (docin.com)&lt;/span&gt;，侵删。&lt;/p&gt;
&lt;/div&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="社会" scheme="https://jdjwzx233.cn/categories/%E7%A4%BE%E4%BC%9A/" />
        <category term="历史" scheme="https://jdjwzx233.cn/categories/%E5%8E%86%E5%8F%B2/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="社会" scheme="https://jdjwzx233.cn/tags/%E7%A4%BE%E4%BC%9A/" />
        <category term="历史" scheme="https://jdjwzx233.cn/tags/%E5%8E%86%E5%8F%B2/" />
        <category term="初中" scheme="https://jdjwzx233.cn/tags/%E5%88%9D%E4%B8%AD/" />
        <category term="年代尺" scheme="https://jdjwzx233.cn/tags/%E5%B9%B4%E4%BB%A3%E5%B0%BA/" />
        <updated>2022-09-21T22:16:28.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/08/23/%E8%81%8A%E6%96%8B%E7%BF%BB%E8%AF%91/</id>
        <title>《聊斋志异》译文与赏析</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/08/23/%E8%81%8A%E6%96%8B%E7%BF%BB%E8%AF%91/"/>
        <content type="html">&lt;h1 id=&#34;卷一&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#卷一&#34;&gt;#&lt;/a&gt; 卷一&lt;/h1&gt;
&lt;h2 id=&#34;瞳人语&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#瞳人语&#34;&gt;#&lt;/a&gt; 瞳人语&lt;/h2&gt;
&lt;h3 id=&#34;译文转自-瞳人语_百度百科-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#译文转自-瞳人语_百度百科-baiducom&#34;&gt;#&lt;/a&gt; 译文 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTclOUUlQjMlRTQlQkElQkElRTglQUYlQUQvNjQwMDc3Mg==&#34;&gt; 瞳人语_百度百科 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;书生方栋，在长安城里很有点名气，但他为人很轻佻，不守礼节。每在郊外遇到游玩的女子，就很不礼貌地尾随在后头。&lt;/p&gt;
&lt;p&gt;清明节的前一天，他偶然到城郊游玩，见到一辆小车子，挂着朱红色的穸帘，周着绣花簇锦的车帷，几位女婢骑着马跟在车后。其中一个婢女，骑着匹小马，容貌美丽极了。方栋稍向前凑近，偷眼一看，见车的帷幔拉开着，车里坐着一位十五六岁的女郎，她妆梳非常艳丽，真是生平从未见到过。方栋目光缭乱，神志昏昏，跟在车的前前后后，舍不得离开，这样跟着走了好几里。忽听车中女郎把婢女叫到车边，说：“给我把帘子放下来。哪里来的这么一个狂妄书生，频频地来偷看。” 婢女把穸帘放下，回过头愤怒地看着方栋说：“这是芙蓉城里七郎的新娘回娘家，不是一个乡下女子，随便让秀才偷看的。” 说完，就从车道上抓起一把土，朝着方栋扬去。&lt;/p&gt;
&lt;p&gt;方栋眯眼睁不开，刚刚用手擦试眼睛，女郎的车马已经远去了。他惊恐疑惑地回到家里，总觉得眼睛里不舒服。请人扒开眼睑一看，眼球上生出了一层薄膜。过了一宿，越发严重，眼泪不止地簌簌流下来。白色的翳膜渐渐大起来，又过了几天，就像个铜钱那么厚。右边的那个眼球上，起了如同螺旋状的厚翳膜，用各种药物医治，都不见效。这时，方栋心中懊悔极了，很愧悔自己作法不当。他听说佛家的《光明经》能消除灾难，就手拿一卷，请别人教诵。最初，读时心情很烦躁，时间久了，渐渐地就习惯了。一天早晚无别的事可作，只盘腿坐着捻珠诵经。就这样他持续了一年，什么杂乱的念头也没有了。忽然，听到左边眼睛中，有如小蝇的声音，说：“黑如漆，真难受死了。” 右边眼睛中应声说：“可以一同出去游玩一会儿，出出这口闷气。” 方栋渐渐觉得两鼻孔中，蠕蠕动弹，很痒，好像有东西从鼻孔里面爬出来。过了一段时间，又返回来，又从鼻孔进到眼眶里。它们又说：“好长时间没能看看园中的亭台了，那珍珠兰快要枯死了。”&lt;/p&gt;
&lt;p&gt;方栋生平很喜欢兰花，园中种植了许多兰花，以前自己常去灌水，自从两眼失明，长久没再过问。忽然听到这话，急忙问他的妻子：“兰花怎么弄得快干死了？” 妻子问方栋怎么知道的，方栋就把实情告诉妻子。妻子到花园中一看，果然兰花枯萎了。妻子感到惊异，静静躲在屋里看个究竟，见有小人从方栋的鼻子中出来，大小不如一粒豆子，转转悠悠地竟到门外去了，越走越远，接着就看不清了。一会儿，两个小人又挎着胳膊回来，飞到方栋的脸上，好像蜜蜂和蚂蚁回窝一样。就这样倒腾了二三天。&lt;/p&gt;
&lt;p&gt;方栋又听左眼中小人说：“这条隧道弯弯曲曲，来来去去很是不方便，还不如自己另开一个门。” 右眼睛中小人说：“我这里的洞壁太厚，要开门不太容易。” 左边的说：“我来试试看，若能开开，咱俩就住到一块算了。” 方栋接着感到左眼眶内隐隐地痛似抓裂一样。一会，睁开眼一看，突然屋里的桌椅等物看得很清楚。方栋很高兴地告诉妻子。妻子仔细查看，左眼中那层小脂膜破开一个小孔，露出亮晶晶的黑色眼球，才有半个胡椒粒那么大。过了一宿，那层翳膜全消退了。细细一看，竟然是两个瞳人。而右眼厚厚的翳膜，仍是老样子，这才知两个瞳人合居在一个眼眶里了。方栋虽然瞎了一只眼睛，但比以前两个眼睛时看东西更清楚。自这以后，他对自己的行为，就更检点约束了，乡亲们都称赞他的品德好。&lt;/p&gt;
&lt;p&gt;异史氏说：乡里有个士人，和两个朋友一起出去，途中看见一个少妇骑着毛驴出现 在他前头。戏谑的说道：“有美人啊！” 回头看了看两个朋友说：“追她！” 三人于是笑着跟从。等到追上一看，是他的儿媳。心里很羞愧丧气，不再说话。朋友假装不知道，评头论足十分猥亵。士人很尴尬忸怩，支支吾吾的说：“这是我长子媳妇啊！” 于是各自偷笑而止。轻薄的人往往自取其辱，真是很可笑啊！至于双眼被迷失明，又是鬼神的惨痛报应啊。芙蓉城主，不知道是何处神祇，难道不是菩萨现身吗？眼睛里的小瞳人，应是劈开一个小门，犯了错误，鬼神纵然凶恶，又何尝不允许别人改过自新呢！&lt;/p&gt;
&lt;h3 id=&#34;解析转自-聊聊斋谈谈心-之瞳人语-简书-jianshucom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#解析转自-聊聊斋谈谈心-之瞳人语-简书-jianshucom&#34;&gt;#&lt;/a&gt; 解析 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cuamlhbnNodS5jb20vcC9hMjY3ZTZhYWEyN2M=&#34;&gt; 聊聊斋，谈谈心 之《瞳人语》 - 简书 (jianshu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;这个故事大概说的是方栋这个浪子生性喜欢调戏美人，本来窈窕淑女，君子好逑嘛，但是在清明前一天却调戏错了对象，调戏了芙蓉城七郎子新妇，被惩罚了双眼生翳，右眼还起旋螺瞎了，而左眼成了双瞳。从此方栋浪子回头，变老实了，不再玩火，不再好色了。&lt;/p&gt;
&lt;p&gt;中国封建时期，等级制度特别讲究三纲五常，而三纲是指 “君为臣纲”、“父为子纲”、“夫为妻纲”。侍君如侍父，同样弑君如弑父，古时会经常称地方官为父母官，这就意味着君与臣、官与民之间是存在和父与子之间的一样的乱伦禁忌。就像文中那婢说 “此芙蓉城七郎子新妇归宁，非同田舍娘子，放教秀才胡觑！（这是芙蓉城主七儿子新娶的老婆回娘家，不是普通的村姑，你这穷秀才瞅啥！）”。且不说芙蓉城主是何方神仙，城主本来就是一城的父母官，父母官的儿媳妇当然是不能乱瞅的，不像村姑那样可以随便被调戏。方栋要受到的惩戒不是一般的长针眼，而要长翳，甚至起旋螺瞎了。但这也幸亏方栋只是用眼来 “欣赏”，没有上升到言语上的挑逗，才不会在清明时节丢了性命到地狱里受罚。&lt;/p&gt;
&lt;p&gt;古时的男性在俄底浦斯期都很难过得好，因为古时男性在俄期要处理的依然是二元关系，只是从之前的母子关系转移到了父子关系，而不是真正处理孩子、爸爸、妈妈的三元关系，这就会造成了古时男性面对女性时，总是在有着面对自己对妈妈的渴望，只要敢有任何猥琐的想法，内心会受到无意识中的古时乱伦禁忌惩罚。就好像文中方栋敢去窥视城主的儿媳妇，受到的惩罚是眼睛不能乱瞅，在方栋痛定思痛之后，左眼在意象中是象征着和爸爸的关系，变成了双瞳，意味着更加看清楚和遵守父性的权威，整个人变得更老实了，而右眼在意象中会是象征和妈妈的关系，起旋螺，变瞎了，意味着自己内心对于妈妈的任何企图都只能放在心深处，把兴趣转移到了自己的 “后花园”—— 妻子身上。&lt;/p&gt;
&lt;p&gt;不过，古人还是知道事情不能做得太绝了，老爸不能去抢儿子女人，一来显得太低能了，要去和儿子抢吃的，二来免得把儿子逼上绝路，儿子会造反的，就像文后的士人看到美人是自己的 “长男妇”，就变得垂头丧气。同时古时男性特别是有些文化的人，其实是有一定身份的人了，会在外面表现出风流成性，放荡不羁是时尚，他们是可以去调戏一下村姑或者青楼女子，满足或者发泄自己内心的性冲动，但却不敢真正去追求女性，更别说敢去接触父母官家里的女人，而婚姻永远是 “父母之命，媒妁之言”，自己能拥有的老婆只能是父母认可的。&lt;/p&gt;
&lt;p&gt;在精神分析当中会称乱伦禁忌或者冲动为俄底浦斯情结，翻译成大白话就是儿子要把爸爸干掉，就是为了抢老爸的女人，也就是妈妈来满足自己需求。当然这事情往往是不能成功的，儿子最终只能清醒地意识到，妈妈永远只能是爸爸的女人，是自己的妈妈，自己可以拥有真正属于自己的女人是需要在外面找，从而把自己的目光转移到了别的女人身上来满足自己性需求或者自己战胜了爸爸的幻想。&lt;/p&gt;
&lt;p&gt;但如果妈妈和儿子的连接太紧密的话，也就是儿子太过粘妈妈的话，儿子在俄期发现自己无法和爸爸抗衡后只是从这竞争关系中表面地撤退，但不代表儿子会放弃妈妈可以是自己女人的想法。儿子会无意识地不断去寻找不同女性，或者在别的女人身上寻找妈妈的影子，把别的女人当成自己妈妈来对待要求，或者用各种各样的方式继续待在妈妈身边和妈妈保持连接比如长大了依然待在家里啃老之类，这样只会对孩子的成长带来不利的影响，一直陷在了过去情结当中，无法走出来拥有自己的真正人生。&lt;/p&gt;
&lt;h2 id=&#34;王六郎&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#王六郎&#34;&gt;#&lt;/a&gt; 王六郎&lt;/h2&gt;
&lt;h3 id=&#34;译文转自-王六郎清代蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#译文转自-王六郎清代蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;#&lt;/a&gt; 译文 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTclOEUlOEIlRTUlODUlQUQlRTklODMlOEUvNjM5ODY3OQ==&#34;&gt; 王六郎（清代蒲松龄创作的文言短篇小说）_百度百科 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;有个姓许的，家住淄川县城北，以打鱼为生。他每天傍晚总要带酒到河边去，边喝酒边打鱼。而喝酒前，又总是先斟上一盅祭奠一下，并祷告说：“河中的溺鬼，请来喝酒吧！” 这样便习以为常。其他人往往打鱼很少，而他每天都打满筐的鱼。一天傍晚，许某刚刚独自饮酒，见一少年走来，在他身边转来转去。许某让他同饮，少年也不推辞，二人便对饮起来。这一夜竟连一条鱼也未能打到，许某很有些丧气。少年起立躬身说：“我到下游为你赶鱼。” 说罢，朝下游飘然走去。一会儿，少年回来说：“大群鱼来了！” 果然听到有许多鱼吞吃饵食的声音。许某便撒网，一网捕了十数尾尺把长的大鱼。他非常高兴，对少年深表感谢。少年欲走，许送鱼给他，少年不要，并说：“屡次喝你的好酒，这点小事怎能提到感谢呢？如您不嫌麻烦，我将常来找您。” 许某说：“才相见一晚，怎说多次？你如愿来相助，我是求之不得，可我怎样报答你的情意呢？” 于是便问少年姓名。少年说：“我姓王，没有名字，你见面就叫我王六郎吧。” 说罢，便告辞而去。次日，许某将鱼卖掉，顺便多买了些酒。当晚，许某来到河边时，六郎早已先在等候，二人便开怀畅饮。饮几杯后，六郎便为许某赶鱼。&lt;/p&gt;
&lt;p&gt;就这样半年过去了。一天，六郎忽然对许说：“你我相识，情同手足，可是，咱们马上就要分别了。” 说得很是悲伤。许某甚为诧异，问六郎为何这样，六郎考虑再三，才说：“你我既然亲如兄弟，我说了你也不必惊讶。如今将要分别，无妨如实告知：我实际是一鬼，只因生前饮酒过量，醉后溺水而死，已经好几年了。以前你之所以捕到比别人更多的鱼，都是我暗中帮你驱赶，以此来酬谢奠酒之情。明 日我的期限已满，将有人来代替我，我将要投生于人间，你我相聚只有今晚了，所以我不能平静。” 许某听了起初十分害怕，然而，因为长期相处，不再恐怖，反而难过起来。于是，他满满斟了一杯酒捧在手中说：“六郎，我敬你这杯酒！望你饮了不要难过。你我从此不能相见，虽很伤心，但你由此解脱灾难，我应该祝贺你。不要悲伤，应该高兴才是！” 于是，二人继续畅饮。许问六郎：“何人来相替？” 六郎说：“兄长明 日可在河边阴处等候，正当午时，有一女子渡河，溺水而死，即是替我之人。” 二人听到村鸡鸣叫，方洒泪而别。次日，许在河边暗暗观看，会发生什么事情。中午时，果有一怀抱婴儿的妇女，到河边便坠入水中。婴儿被抛在岸上，举手蹬脚地啼哭。妇女几次浮上沉下，后竟又水淋淋地爬上河岸，坐在地上稍稍休息后，抱起婴儿走了。当许某看到妇女掉入水中时，很不忍心，想去相救，但一想这是六郎的替身，才打消救人的念头。当又看到妇人未溺死，心中怀疑六郎所言有些荒唐。当晚，许某仍到原地去打鱼，而六郎早已在那里，说：“如今又相聚了，可暂先不说分别的事。” 许某问六郎白天的事，六郎说：“本来那女子是替我的，但我怜她怀中婴儿，不忍心为了自己一人而伤两个人的性命。因此，我决定舍弃这个机会，但又不知何时再有替死的人。也许是你我缘分未尽啊。” 许某慨叹地说：“你这种仁慈之心，总可感动玉帝的。” 从此，二人一如既往，饮酒捕鱼。过了几天，六郎又来向许某告别，许以为又有替六郎之人。六郎说：“不是的，我前次之好心果然感动了玉帝，因而招我为招远县邬镇的土地神。明日要去赴任，如你不忘咱俩的交情，不要嫌路远，去招远看我。” 许某祝贺说：“贤弟行为正直而做了神，我感到十分欣慰。但人和神之间相隔遥远，即使我不怕路远，又怎样才能见到你呢？” 六郎说：“只管前往，不要顾虑。” 再三嘱咐而去。&lt;/p&gt;
&lt;p&gt;许某回到家，便要置办行装东下招远。他妻子笑着说：“这一去几百里路，即使有这个地方，恐怕和一个泥塑偶像也无法交谈。” 许某不听，终究去了招远。问当地居民，果然有个邬镇。他找到了邬镇，便住进一个客店，向主人打听土地祠在什么地方。主人惊异地说：“客人莫非姓许？” 许某说：“是的，但是您怎么知道？” 店主人又问：“客人莫非是淄川人？” 许某说：“是的，然则您又是怎么知道的？” 店主人并不回答，很快地走出去。过了一会，只见丈夫抱着小儿，大姑娘小媳妇在门外偷看，村里人纷纷到来，围看许某，如四面围墙一般。许某更为惊异。大家告诉他说：“前几夜，梦见神人来告知：有一个淄川姓许的人将来此地，可以给些资助。因而在此等候多时。” 许某甚为奇怪，便到土地祠祭祀六郎，祷告说：“自从与你分别后，睡梦中都铭记在心，为此远道而来赴昔日之约。又蒙你托梦告知村里人，心中十分感谢。很惭愧我没有厚礼可赠，只有一杯薄酒，如不嫌弃，当如过去在河边那样对饮一番。” 祷告毕，又烧了些纸钱。顷刻见到一阵旋风起于神座之后，旋转许久才散去。当夜，许某梦到六郎来到，衣冠楚楚的，与过去大不相同。六郎致谢道：“有劳你远道而来看望我，使我又欢喜又悲伤。但我如今有职务在身，不便与你相会，近在咫尺，却如远隔山河，心中十分凄怆。村中人有微薄的礼物相赠，就算代我酬谢一下旧日的好友。当你回去的时候，我必来相送。” 许某住了几天，打算回家，大家殷勤挽留，每天早晚都轮流作东道主为许某饯行。许坚决告辞，村中人争着送来许多礼物，为他充实行装。不到一天，送的礼物装满行囊，男女老少都聚集来送许出村。忽然刮起一阵旋风，跟随许某十馀里路。许对着旋风再拜说：“六郎珍重，不要远送了。你心怀仁爱，自然能为一方百姓造福，无需老朋友嘱咐了。” 旋风又盘旋许久，才离去。村中的人也都嗟叹着返回了。许某回到家里，家境稍稍宽裕些，便不再打鱼了。后来见到招远的人，向他们打听土地的情况，据说灵验得像传说的那样，远近闻名。&lt;/p&gt;
&lt;p&gt;异史氏说：“王六郎身在青云之中当神，还不忘记贫贱时的朋友，这就是他所以神异的原因。今 日坐在车里面的显贵，难道还认识那个戴着斗笠的人吗？我的乡里有一个退休了的人，家里非常贫穷。他有一个年小的时候就交往的朋友，如今做了显贵。他想要是投奔他去一定会得到周济照顾。于是竭尽全力置办行装，奔波了上千里路，结果非常失望的回来；他花光了行囊里所有的钱财并卖掉了坐骑，才能够回来。他的族弟是个很诙谐的人，作了一首《月令》来嘲讽这件事说：‘这个月，哥哥回来了，貂皮帽子也解下来了，车马伞盖也没有张开来，马也变成驴了，靴子这才没了声音。’念一下这个可以笑一笑。”&lt;/p&gt;
&lt;h3 id=&#34;解析转自-王六郎人物分析主题现实意义高中语文聊斋_百度知道-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#解析转自-王六郎人物分析主题现实意义高中语文聊斋_百度知道-baiducom&#34;&gt;#&lt;/a&gt; 解析 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly96aGlkYW8uYmFpZHUuY29tL3F1ZXN0aW9uLzUzMTE1OTQyMi5odG1s&#34;&gt; 王六郎人物分析，主题，现实意义，高中语文，聊斋_百度知道 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;h4 id=&#34;人物分析&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#人物分析&#34;&gt;#&lt;/a&gt; 人物分析：&lt;/h4&gt;
&lt;p&gt;因为渔夫经常 “饮则酹地”。所以王六郎要报答渔夫，使得 “他人渔，迄无所获，而许独满筐”。表现了他的知恩图报，重情义的性格特点。&lt;/p&gt;
&lt;p&gt;集中体现在王六郎放弃妇人代死这一部分。“果有妇人抱婴儿来，及河而堕。儿抛岸上，扬手掷足而啼。妇沉浮者屡矣，忽淋淋攀岸以出，藉地少息，抱儿径去。”&lt;/p&gt;
&lt;p&gt;在亭午时分，一名妇人怀抱婴儿前来，行至河畔，旋即失足坠入河中，在该妇人载沉载浮的奋力挣扎中，伴随着河岸幼儿扬手掷足的高声哭啼。结果是妇人没有沉下去，而是 “忽淋淋攀岸以出”，抱着儿子回去了。&lt;/p&gt;
&lt;p&gt;当晚，二人照常来到河边聚会。渔夫向他询问了这件怪事。王六郎回答说：“女子已相代矣；仆怜其抱中儿，代弟一人遂残二命，故舍之。” 作为一个溺死鬼，当有人做替身时，自己本可以投胎复生，重新做人，然而在这 “生死攸关”，他却甘愿放弃这个机会，而是把机会让给更需要生命的人 —— 手抱婴儿的妇女。这个故事的寓意是：人和鬼之间，只要讲诚信，也可以成为知己；&lt;/p&gt;
&lt;h4 id=&#34;主题&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#主题&#34;&gt;#&lt;/a&gt; 主题：&lt;/h4&gt;
&lt;h5 id=&#34;知恩图报有情有义&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#知恩图报有情有义&#34;&gt;#&lt;/a&gt; 知恩图报，有情有义。&lt;/h5&gt;
&lt;h5 id=&#34;舍己救人-善良高尚&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#舍己救人-善良高尚&#34;&gt;#&lt;/a&gt; 舍己救人、善良高尚。&lt;/h5&gt;
&lt;h4 id=&#34;现实意义&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#现实意义&#34;&gt;#&lt;/a&gt; 现实意义：&lt;/h4&gt;
&lt;p&gt;人和人之间，也应该注重诚信。&lt;/p&gt;
&lt;h2 id=&#34;种梨&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#种梨&#34;&gt;#&lt;/a&gt; 种梨&lt;/h2&gt;
&lt;h3 id=&#34;译文转自-种梨清代小说家蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#译文转自-种梨清代小说家蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;#&lt;/a&gt; 译文 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTclQTclOEQlRTYlQTIlQTgvNzY1NjM2MQ==&#34;&gt; 种梨（清代小说家蒲松龄创作的文言短篇小说）_百度百科 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;有个乡下人，在集市上卖梨。梨的味道非常香甜，但价钱很贵。有个道士，戴着破道士帽，穿着破烂道袍，在车前伸手向乡下人乞讨。乡下人呵斥他，他也不走。乡下人生气了，大声地辱骂起来。道士说：“你这一车梨有好几百个，贫道只讨你一个，对你来说没多大损失，为什么还要发这么大的脾气呢？” 观看的人劝乡下人拿一个不好的梨给老道士，打发他走算了，乡下人坚决不肯。&lt;/p&gt;
&lt;p&gt;路旁店铺里的一个伙计，见他们吵得不成样子，就拿出钱买了一个梨，给了道士。道士拜谢，然后对着众人说：“出家人不知道吝惜东西。我有好梨，请大家品尝。” 有人问：“你既然有梨，为什么不吃自己的？” 道士说：“我是需要这个梨核做种子。” 于是捧着梨大口大口地吃了起来。道士吃完梨，把核放在手里，取下背在肩上的小铁铲，在地上挖了个几寸深的坑，然后放进梨核，盖上土，向旁边的人要点热水浇灌。有好事的人便到路边店铺中提来一壶滚开的水，道士接过开水浇进了坑里。大家都瞪着眼看着，见一棵嫩芽儿冒了出来，并渐渐长大，一会儿就长成了一棵枝繁叶茂的大树；转眼间开花、结果，又大又香的梨子挂满了枝头。道士从树上摘下梨子，分给围观的人吃，一会儿功夫就吃光了。然后，道士就用铁铲砍树，叮叮当当地砍了好长时间方才砍断。道士把满带枝叶的梨树扛在肩上，不慌不忙地走了。&lt;/p&gt;
&lt;p&gt;一开始，道士做戏法时，那个乡下人也杂在人群中，伸着脖子瞪着眼看，竟忘记了自己的营生。道士走了以后，他才回来去看顾他车上的梨，却已经一个也没有了。他这才恍然大悟，道士刚才分的梨子都是他的；再细细一看，一根车把没有了，碴口是新砍断的。乡下人心里非常气愤，急忙去追赶道士。转过一个墙角，见砍断的车把扔在墙角下，这才知道道士刚才砍的那棵梨树，就是他的车把，而道士却已经不知去向了。满集市上的人都笑得合不上嘴。&lt;/p&gt;
&lt;p&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTUlQkMlODIlRTUlOEYlQjIlRTYlQjAlOEYvNTAzNDg0Ng==&#34;&gt;异史氏&lt;/span&gt;评论：“乡人烦闷昏庸的样子，憨状可掬，十分痴傻，他受市人嘲笑，也是有道理的。我每每见到乡中富人，至亲好友向他乞米求助，就表现出一副气愤的样子，就计较说：‘（这）是好几天的物资开支了。’ 如果劝他救济危难的人，给孤独无靠的人饭吃，则又忿然，又计较说：‘这是十个人、五个人的饭量。’ 甚至连父子兄弟，也极微细的钱财也要彻底计较。（但是）一旦关乎荒淫烂赌，则整个囊袋家产也不吝啬；刀锯架在头颈上，连赎命也来不及。诸如此类的事，正是说之不尽；而（相对而言）愚蠢的乡下人的做法，又有什么值得奇怪的呢？”&lt;/p&gt;
&lt;h3 id=&#34;赏析转自-种梨清代小说家蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#赏析转自-种梨清代小说家蒲松龄创作的文言短篇小说_百度百科-baiducom&#34;&gt;#&lt;/a&gt; 赏析 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTclQTclOEQlRTYlQTIlQTgvNzY1NjM2MQ==&#34;&gt; 种梨（清代小说家蒲松龄创作的文言短篇小说）_百度百科 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;《种梨》所讲的故事只是一个风趣剧，轻松而幽默。说的是一个村夫在集市上卖梨，而一个道人万端乞讨而不得。其间一个伙计实在看不下去了，就买了一个送给道人，没想到道人吃毕，把核种于地下，霎时间便生芽、发展、开花、结果，于是道人遍送观者。而村夫待道人走后发现本身的一车梨已经子虚乌有，才突然觉悟大悟。然而，蒲松龄先生却在评价中说道：&amp;quot;良友…… 父子兄弟，较尽锱铢。及至淫博迷心，则顷囊不吝；刀锯临颈，则赎命不遑。诸如此类，正不胜道……&amp;quot; 其极重繁重和愤慨，使人足见先生对吝啬者之恨了。&lt;/p&gt;
&lt;h2 id=&#34;劳山道士&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#劳山道士&#34;&gt;#&lt;/a&gt; 劳山道士&lt;/h2&gt;
&lt;h3 id=&#34;译文转自-崂山道士聊斋志异篇目_百度百科-baiducom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#译文转自-崂山道士聊斋志异篇目_百度百科-baiducom&#34;&gt;#&lt;/a&gt; 译文 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTUlQjQlODIlRTUlQjElQjElRTklODElOTMlRTUlQTMlQUIvMTYyNDg=&#34;&gt; 崂山道士（《聊斋志异》篇目）_百度百科 (baidu.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;县里有个姓王的书生，排行第七，是官宦之家的子弟，从小就羡慕道术。他听说崂山上仙人很多，就背上行李，前去寻仙访道。他登上一座山顶，看见一所道观，环境非常幽静。有一个&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTklODElOTMlRTUlQTMlQUIvMTU4MzM3NjE=&#34;&gt;道士&lt;/span&gt;坐在蒲团上，白头发垂到脖颈上，神情相貌清爽高超。王生上前见过礼并与他交谈起来，觉得道士讲的道理非常玄妙。便请求道士收他为徒，&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTklODElOTMlRTUlQTMlQUIvMTU4MzM3NjE=&#34;&gt;道士&lt;/span&gt;说：“恐怕你娇气懒惰惯了，不能吃苦。” 王生回答说：“我能吃苦。” 道士的徒弟很多，傍晚的时候都集拢来了。王生一一向他们行过见面礼，就留在道观中。&lt;/p&gt;
&lt;p&gt;第二天凌晨，&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9iYWlrZS5iYWlkdS5jb20vaXRlbS8lRTklODElOTMlRTUlQTMlQUIvMTU4MzM3NjE=&#34;&gt;道士&lt;/span&gt;把王生叫去，交给他一把斧头，让他随众道徒一起去砍柴。王生恭恭敬敬地答应了。过了一个月，王生的手脚都磨出了厚厚的老茧，他再也忍受不了这样的苦累，暗暗产生了回家的念头。&lt;/p&gt;
&lt;p&gt;有一天傍晚，他回到观里，看见两个客人与师傅共坐饮酒。天已经晚了，还没有点上蜡烛。师傅就剪了一张像镜子形状的纸，贴在墙上。一会儿，那纸变成一轮明月照亮室内，光芒四射。各位弟子都在周围奔走侍候一个客人说：“良宵美景，其乐无穷，不能不共同享受。” 于是，从桌上拿起酒壶，把酒分赏给众弟子，并且嘱咐可以尽情地畅饮。王生心里想，七八个人，一壶酒怎么能够喝？于是，各人寻杯觅碗，争先抢喝，惟恐壶里的酒干了。然而众人往来不断地倒，那壶里的酒竟一点儿也不少。王生心里非常纳闷。过了一会儿，一个客人说：“承蒙赐给我们月光来照明，但这样饮酒还是有些寂寞，为什么不叫嫦娥来呢？” 于是就把筷子向月亮中扔去。只见一个美女，从月光中飘出，起初不到一尺，等落到地上，便和平常人一样了。她扭动纤细的腰身、秀美的颈项，翩翩地跳起 “霓裳舞”。接着唱道：“神仙啊，你回到人间，而为什么把我幽禁在广寒宫！” 那歌声清脆悠扬，美妙如同吹奏箫管。唱完歌后，盘旋着飘然而起，跳到了桌子上，大家惊奇地观望之间，已还原为筷子。师傅与两位客人开怀大笑。又一位客人说：“今晚最高兴了，然而我已经快喝醉了，二位陪伴我到月宫里喝杯饯行酒好吗？” 于是三人移动席位，渐渐进入月宫中。众弟子仰望三个人，坐在月宫中饮酒，胡须眉毛全都看得清清楚楚，就像人照在镜子里的影子一样。过了一会儿，月亮的光渐渐暗淡下来，弟子点上蜡烛来，只见道士独自坐在那里，而客人已不知去向。桌子上菜肴果核还残存在那里。那墙上的月亮，只不过是一张像镜子一样的圆的纸罢了。道士问众弟子：“喝够了吗？” 大家回答说：“够了。” 道士说：“喝够了就早去睡觉，不要耽误了明天打柴。” 众弟子答应着退了出去。王生心里惊喜羡慕，回家的念头随即打消了。&lt;/p&gt;
&lt;p&gt;又过了一个月，王生实在忍受不了这种苦累，而道士还是连一个法术也不传授，他心里实在憋不住，就向道士辞行说：“弟子不远数百里来拜仙师学习，即使不能得到长生不老的法术，若能学习点小法术，也可安慰我求教的心情。如今过了两三个月，不过早上出去打柴，晚上回来睡觉。弟子在家中，从没吃过这种苦。” 道士笑着说：“我本来就说你不能吃苦，现果然如此。明天早晨就送你回去。” 王生说：“弟子在这里劳作了多日，请师傅稍微教我一点儿小法术，我这次来也算没白跑一趟。” 道士问：“你要求学点什么法术？王生说：“平常我见师傅所到之处，墙壁也不能阻挡，只要能学到这个法术，我就知足了。” 道士笑着答应了。于是就传授他秘诀，让他自己念完了，道士大声说：“进墙去！王生面对着墙不敢进去。道士又说：“你试着往里走。” 王生就从容地向前走，到了墙跟前，被墙挡住。道士说：“低头猛进，不要犹豫！” 王生果然离开墙数步，奔跑着冲过去，过墙时，像空虚无物；回头一看，身子果然在墙外了。王生非常高兴，回去拜谢了师傅。道士说：“回去后要洁持自爱，否则法术就不灵验。” 于是就给他些路费，打发他回去了。&lt;/p&gt;
&lt;p&gt;王生回到家里，自己夸耀遇到了仙道，坚固的墙壁也不能阻挡他。他的妻子不相信。王生便仿效起那天的一举一动，离墙数尺，奔跑着冲去，头撞到坚硬的墙上，猛然跌倒在地。妻子扶起他来一看，额头上鼓起大包，像个大鸡蛋一样。妻子讥笑他，王生又惭愧又气愤，骂老道士没安好心。&lt;/p&gt;
&lt;p&gt;异史氏说：听说王生这个故事的人没有不大笑的，殊不知世上的 “王生” 还真不少。现在有那么一个匹夫，喜欢别人阿谀奉承不喜欢忠言劝谏，于是那些阿谀迎奉的小人就呈上那些可以逞威扬暴的伎俩，来迎合他，并骗他说：靠着这个本事，就可以横行无阻了。一开始试验都小有灵验，于是就说天下之大，都可以像这样横行，真是一个不碰南墙不回头的人啊！&lt;/p&gt;
&lt;h3 id=&#34;赏析转自-小说-戏剧崂山道士原文与赏析-中外经典-品诗文网-pinshiwencom&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#赏析转自-小说-戏剧崂山道士原文与赏析-中外经典-品诗文网-pinshiwencom&#34;&gt;#&lt;/a&gt; 赏析 (转自 ---&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cucGluc2hpd2VuLmNvbS93YWl3ZW4vendqZC8yMDE5MDcyMDE1NDYyOS5odG1s&#34;&gt;《小说、戏剧・崂山道士》原文与赏析 - 中外经典 - 品诗文网 (pinshiwen.com)&lt;/span&gt;)&lt;/h3&gt;
&lt;p&gt;这篇小说以简洁轻快的笔调刻画出一位畏难怕苦，不求真知；浅尝辄止，轻浮健忘，学到一点皮毛就自炫自夸的王生。其结果只落得头撞南墙，一事无成，唯有头上的肿疱而已。王生的形象愈鲜明逼真，作品的讽刺意味也愈隽永深长。从而使形象的生动性和主题的深刻性，得到和谐的统一。&lt;/p&gt;
&lt;p&gt;《崂山道士》喜趣横生，极富艺术魅力，其成功的艺术经验有四：其一，从发展中显现人物自身的矛盾。凡古今引人入胜，而耐人寻味的佳作，几乎无例外地都是再现矛盾的艺术。可以说，艺术的魅力首先是矛盾的魅力，蒲松龄的高明在于他正是矛盾的发现者、把握者和再现者。《崂山道士》情节的喜剧性来自人物的悲剧性格。王生既想学道，又不肯吃苦；既想虔诚敬道，又不肯接道长的要求去做；既想炫耀自己，又无真本事；既想讨妻子的赞赏，又无自知之明。这样小说便从王生的主观意愿和实际能力大相径庭的矛盾中，透过一定事件的考验展现出人物的个性特征，使人物形象立体化，更加有血有肉。由此可见，审美对象也包括丑，它一经审美主体的把握，例如这篇讽刺小说对于客观存在的丑的把握，也就创造了对丑的反映的艺术美。&lt;/p&gt;
&lt;p&gt;其二，小说委婉有致地写出人物在不同情境下的各种心态。因王生自幼慕道，所以他赴数百里之外求师学道。当他刚到劳山时，见观宇 “甚幽”，道士 “神光爽迈”，便毅然拜师学道。但他从来未想过学道要付出艰辛的代价，足见王生无知。仅一个多月早出晚归的劳作他便打熬不住转念回家了，王生的心志不坚，自然不言而喻。一旦目睹了道士的真本领又想留下来，恨不得一吃成胖子，其好高鹜远的虚荣心又得以充分展现。再过上一个多月的劳苦生活，旧态复萌，又不想干了，临走前道士教以小技便心满意足了，只要装点、不求真知的浅薄心理昭然若揭。回家后，面对不懂道术的妻子，又是自我吹嘘，又是急不可待地当场表演，欺世盗名的心态和盘托出。如此，层次井然地揭示出王生在不同情境中的内在丑，从而使人物个性渐趋鲜明，作品的立意也愈加深刻。&lt;/p&gt;
&lt;p&gt;其三，巧用漫画式的夸张手法。作者准确地把握了王生在妻子面前表演时踌躇满志的心态，神形兼备地予以适度的夸张，王生碰壁后额上 “巨卵” 格外醒目，寥寥数笔极尽揶揄嘲讽之能事，不但渲染了喜剧气氛，而且使这位玩弄小术的王生自食其果。作品的讽刺效果也就自然而微妙地得以发挥，这正是作者炉火纯青的艺术功力所致。&lt;/p&gt;
&lt;p&gt;其四，寓深刻的哲理性于轻松的笑声之中。《崂山道士》既是讽刺小说，也是寓言故事。它具有亦庄亦谐，寓庄于谐的特点，饶有丰富的哲理性内蕴。王生既是一个具有独特性格的艺术形象，又是生活中随处可见的众生相，他那种自我吹嘘而又不自量的性格特征，必然导致碰壁的悲剧，正像篇末异史氏所言，“闻此事未有不笑者，而不知世之王生者正复不少。” 作者旨在借王生嘲讽世上所有王生的同类。古罗马贺拉修斯在他的名著 《诗艺》中说得好： “寓教于乐，既劝谕读者，又使他喜爱。”“教” 也就是某种哲理，其所以引起快感，启迪智慧，给人益处和乐趣，同时又对生活有帮助，正因为美是一种善。&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="概括" scheme="https://jdjwzx233.cn/tags/%E6%A6%82%E6%8B%AC/" />
        <category term="名著" scheme="https://jdjwzx233.cn/tags/%E5%90%8D%E8%91%97/" />
        <category term="聊斋志异" scheme="https://jdjwzx233.cn/tags/%E8%81%8A%E6%96%8B%E5%BF%97%E5%BC%82/" />
        <updated>2022-08-23T22:11:22.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/08/18/%E8%81%8A%E6%96%8B%E5%BF%97%E5%BC%82%E6%A6%82%E6%8B%AC/</id>
        <title>《聊斋志异》简介及读后感</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/08/18/%E8%81%8A%E6%96%8B%E5%BF%97%E5%BC%82%E6%A6%82%E6%8B%AC/"/>
        <content type="html">&lt;h1 id=&#34;聊斋志异简介及读后感&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#聊斋志异简介及读后感&#34;&gt;#&lt;/a&gt; 《聊斋志异》简介及读后感&lt;/h1&gt;
&lt;h2 id=&#34;一-聊斋志异简介&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#一-聊斋志异简介&#34;&gt;#&lt;/a&gt; &lt;strong&gt;一、《聊斋志异》简介&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;《聊斋志异》是蒲松龄的代表作，在他 40 岁左右已基本完成，此后不断有所增补和修改。&amp;quot;聊斋&amp;quot; 是他的书屋名称，&amp;quot;志&amp;quot; 是记述的意思，&amp;quot;异&amp;quot; 指奇异的故事。全书有短篇小说 491 篇。题材非常广泛，内容极其丰富。多数作品通过谈狐说鬼的手法，对当时社会的腐败、黑暗进行了有力批判，在一定程度上揭露了社会矛盾，表达了人民的愿望。但其中也夹杂着一些封建伦理观念和因果报应的宿命论思想。《聊斋志异》的艺术成就很高。它成功的塑造了众多的艺术典型，人物形象鲜明生动，故事情节曲折离奇，结构布局严谨巧妙，文笔简练，描写细腻，堪称中国古典短篇小说的高峰。&lt;/p&gt;
&lt;p&gt;《聊斋志异》，是一部文言短篇小说集。有传奇、志怪、轶事等，诸体兼备，为中国文言小说集大成之作。内容十分广泛，多谈狐、魔、花、妖，以此来概括当时的社会关系，反映了 17 世纪中国的社会面貌。书中写的是一个花妖鬼狐的世界，既有对如漆墨黑的社会现实的不满，又有对怀才不遇、仕途难攀的不平；既有对贪宫污吏狼狈为奸的鞭笞，又有对勇于反抗，敢于复仇的平民的称赞；而数量最多、质量上乘、写得最美最动人的是那些人与狐妖、人与鬼神以及人与人之间的纯真爱情的篇章。&lt;/p&gt;
&lt;p&gt;《聊斋志异》是一部具有独特思想风貌和艺术风貌的文言短篇小说集。多数小说是通过幻想的形式谈狐说鬼，但内容却深深地扎根于现实生活的土壤之中，曲折地反映了蒲松龄所生活的时代的社会矛盾和人民的思想愿望，熔铸进了作家对生活的独特的感受和认识。&lt;/p&gt;
&lt;h2 id=&#34;二-从题材内容来看聊斋志异中的作品大致可分为以下五类&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#二-从题材内容来看聊斋志异中的作品大致可分为以下五类&#34;&gt;#&lt;/a&gt; &lt;strong&gt;二、从题材内容来看《聊斋志异》中的作品大致可分为以下五类：&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;第一类，是反映社会黑暗，揭露和抨击封建统治阶级压迫、残害人民罪行的作品，如《促织》、《红玉》、《梦狼》、《梅女》、《续黄粱》、《窦氏》等；&lt;br /&gt;
第二类，是反对封建婚姻，批判封建礼教，歌颂青年男女纯真的爱情和争取自由幸福而斗争的作品，如《婴宁》、《青凤》、《阿绣》、《连城》、《青娥》、《鸦头》、《瑞云》等；&lt;br /&gt;
第三类，是揭露和批判科举考试制度的腐败和种种弊端的作品，如《叶生》、《于去恶》、《考弊司》、《贾奉雉》、《司文郎》、《王子安》、《三生》等；&lt;br /&gt;
第四类，是歌颂被压迫人民反抗斗争精神的作品，如《商三官》、《席方平》、《向杲》等；第五类，总结生活中的经验教训，教育人要诚实、乐于助人、吃苦耐劳、知过能改等等，带有道德训诫意义的作品，如《种梨》、《画皮》、《劳山道士》、《瞳人语》、《狼》三则等。&lt;/p&gt;
&lt;p&gt;《聊斋志异》在进步的思想内容中也夹杂着一些落后的成分，如封建伦理道德观念，鬼神迷信和因果报应思想，追求功名利禄的庸俗倾向等，是我们阅读时应注意分析批判的。&lt;/p&gt;
&lt;p&gt;郭沫若评价说：&amp;quot;写鬼写妖高人一筹，刺贫刺虐入木三分&amp;quot;&lt;/p&gt;
&lt;h2 id=&#34;三-聊斋中的女性大致可分为四类&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#三-聊斋中的女性大致可分为四类&#34;&gt;#&lt;/a&gt; 三、 &lt;strong&gt;《聊斋》中的女性大致可分为四类&lt;/strong&gt;&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;第一类，是为数最多的勇于追求爱情，对爱情忠贞不渝的忠女，烈女，豪放女们&lt;/strong&gt; 。&lt;/p&gt;
&lt;p&gt;如《青凤》，《婴宁》、《莲香》，《聂小倩》等。&lt;/p&gt;
&lt;p&gt;《青凤》：女主人公青凤是一狐女，如其他聊斋女性一样 &amp;quot;世间无其丽&amp;quot;，在与耿生相恋之初，她谨听叔训，&amp;quot;不敢奉命&amp;quot;。经过几番挣扎和几年痛苦的思念，在与耿生的一次意外相遇中，毅然决定离开家人的束缚与耿生共结连理。&lt;br /&gt;
&lt;strong&gt;第二类，利用智慧战胜邪恶，为家人报仇，为民除害的复仇女神。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;如《商三官》，《庚娘》，《云翠仙》等。&lt;/p&gt;
&lt;p&gt;《商三官》商三官是一个聪明美丽、有见识的女孩子。她的父亲商士禹因得罪地主史葵，被活活打死。三官立志替父报仇，于是改名换姓去戏班学戏，几年后随班子回到家乡，设法留在史家，当晚刺死了史葵。待风浪平息后，三官平安地回到家里。&lt;br /&gt;
&lt;strong&gt;第三类，是拥有远见卓识，打破封建重农抑商思想的枷锁，成为商界的女强人。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;如《黄英》，《小二》等。&lt;/p&gt;
&lt;p&gt;《小二》中 &amp;quot;绝贤美&amp;quot; 的女子赵小二就经营这样的手工作坊。她开的是琉璃厂，生产的灯样式新颖，其价格虽高，生意却出奇的好，而且她管治有方，赏罚分明，工人没有一个不服她的，丈夫只是一个工作上的帮手而已她已真正的独立不依的女人，不再是男性的附庸。&lt;br /&gt;
&lt;strong&gt;第四类，是少数几位不堪封建制度重压走向极端的泼妇。&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;如《马介甫》中的尹氏。&lt;/p&gt;
&lt;p&gt;尹氏把丈夫管教得服服贴贴，无论她做什么事丈夫都是大气不敢出一口。她不仅虐待自己的丈夫，还逼得公爹出家当道士，还得弟死，侄儿差点丧命，丈夫的小妾怀孕，她动手打得 &amp;quot;崩注胎堕&amp;quot;。她固然心狠手辣，却从侧面反映男尊女卑社会对女性的摧残。&lt;/p&gt;
&lt;h2 id=&#34;四-聊斋志异几大名篇的内容梗概&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#四-聊斋志异几大名篇的内容梗概&#34;&gt;#&lt;/a&gt; &lt;strong&gt;四、《聊斋志异》几大名篇的内容梗概&lt;/strong&gt;&lt;/h2&gt;
&lt;h3 id=&#34;画皮太原士子王生在一次早晨出行的道上遇到一个抱着包袱独自行走的女子-一问那女子自称是不堪大妇虐待而出逃的大家小妾-王生贪恋其姿色便将她带回家里安置在书斋中与其同居-妻子陈氏让他打发此女离开王生不听一日王生到了集市上一个道士吃惊地说他身上有邪气萦绕一定是遇到了妖邪-王生不信反以为道士是想借此混饭吃-他回到家欲进书斋不料门被堵上隔着窗缝往里一看只见一个青面狞鬼正在描画一张人皮随后将人皮穿在身上又化作美女-王生非常害怕找着道士求他相救-道士给他一个蝇拂让他挂在门外-王生回到家与妻子陈氏住在一处-一更时那化作美女的厉鬼将蝇拂弄碎径直到床前将王生的心摘去吃了-王生之弟二郎找来道士将化作老妇的厉鬼治死-陈氏听从道士的指点向一个疯癫的乞丐求救终于将王生救活&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#画皮太原士子王生在一次早晨出行的道上遇到一个抱着包袱独自行走的女子-一问那女子自称是不堪大妇虐待而出逃的大家小妾-王生贪恋其姿色便将她带回家里安置在书斋中与其同居-妻子陈氏让他打发此女离开王生不听一日王生到了集市上一个道士吃惊地说他身上有邪气萦绕一定是遇到了妖邪-王生不信反以为道士是想借此混饭吃-他回到家欲进书斋不料门被堵上隔着窗缝往里一看只见一个青面狞鬼正在描画一张人皮随后将人皮穿在身上又化作美女-王生非常害怕找着道士求他相救-道士给他一个蝇拂让他挂在门外-王生回到家与妻子陈氏住在一处-一更时那化作美女的厉鬼将蝇拂弄碎径直到床前将王生的心摘去吃了-王生之弟二郎找来道士将化作老妇的厉鬼治死-陈氏听从道士的指点向一个疯癫的乞丐求救终于将王生救活&#34;&gt;#&lt;/a&gt; 《画皮》：太原士子王生，在一次早晨出行的道上，遇到一个抱着包袱独自行走的女子。一问，那女子自称是不堪大妇虐待而出逃的大家小妾。王生贪恋其姿色，便将她带回家里，安置在书斋中，与其同居。妻子陈氏让他打发此女离开，王生不听，一日，王生到了集市上，一个道士吃惊地说他身上有邪气萦绕，一定是遇到了妖邪。王生不信，反以为道士是想借此混饭吃。他回到家，欲进书斋，不料门被堵上，隔着窗缝往里一看，只见一个青面狞鬼，正在描画一张人皮，随后将人皮穿在身上，又化作美女。王生非常害怕，找着道士，求他相救。道士给他一个蝇拂，让他挂在门外。王生回到家，与妻子陈氏住在一处。一更时，那化作美女的厉鬼将蝇拂弄碎，径直到床前，将王生的心摘去吃了。王生之弟二郎找来道士，将化作老妇的厉鬼治死。陈氏听从道士的指点，向一个疯癫的乞丐求救，终于将王生救活。&lt;/h3&gt;
&lt;h3 id=&#34;小翠浙江人王太常小时候一个比猫大的动物在雷鸣电闪时钻到他的身下-后来王太常中了进士并做了侍御-他膝下只有一子但是个傻子-一日一位妇人到他家并将自己的女儿小翠留给他做儿媳-小翠聪慧过人深得公婆喜爱但就是整日里和健儿子疯闹-有一个官员王给谏想诬告王侍御小翠扮成宰相亲临王侍御家让王给谏看到从此收起了诬告王侍御的恶念-一次王给谏到了王侍御家看到傻儿子扮成皇帝模样王给谏到了朝上告了王侍御谋反之罪-皇上验明不过是疯儿傻媳的玩闹后反倒将王给谏发配充军-王侍御觉出小翠不是寻常之人-一日傻公子洗澡小翠趁势捂死了他-等公子又活过来后傻病全好了-过了一年王侍御被王给谏的同党参奏被罢了官-他准备拿一只玉瓶送给朝廷的人好给自己找路子-谁知玉瓶被小翠打碎了公婆二人将小翠一顿大骂-小翠不堪忍受公婆的辱骂决定离开王侍御家-临走时告诉丈夫说自己是狐狸母亲因避雷灾曾受过王侍御的庇护送自己来报恩-小翠走后公子痛哭欲死王公夫妇也知自己铸成大错追悔莫及-两年后公子偶然又遇到小翠-但小翠不愿再回他的家-和公子在外国生活了一段时间后小翠的模样渐渐变了-小翠为公子找了个于家姑娘为妻自己便消失了-婚后公子发现于家女儿就是小翠的模样方才知道小翠模样变化的原因-她将自己变成于家姑娘的模样为的是公子见到于家女儿就像见到她以解公子对她的思念之情&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#小翠浙江人王太常小时候一个比猫大的动物在雷鸣电闪时钻到他的身下-后来王太常中了进士并做了侍御-他膝下只有一子但是个傻子-一日一位妇人到他家并将自己的女儿小翠留给他做儿媳-小翠聪慧过人深得公婆喜爱但就是整日里和健儿子疯闹-有一个官员王给谏想诬告王侍御小翠扮成宰相亲临王侍御家让王给谏看到从此收起了诬告王侍御的恶念-一次王给谏到了王侍御家看到傻儿子扮成皇帝模样王给谏到了朝上告了王侍御谋反之罪-皇上验明不过是疯儿傻媳的玩闹后反倒将王给谏发配充军-王侍御觉出小翠不是寻常之人-一日傻公子洗澡小翠趁势捂死了他-等公子又活过来后傻病全好了-过了一年王侍御被王给谏的同党参奏被罢了官-他准备拿一只玉瓶送给朝廷的人好给自己找路子-谁知玉瓶被小翠打碎了公婆二人将小翠一顿大骂-小翠不堪忍受公婆的辱骂决定离开王侍御家-临走时告诉丈夫说自己是狐狸母亲因避雷灾曾受过王侍御的庇护送自己来报恩-小翠走后公子痛哭欲死王公夫妇也知自己铸成大错追悔莫及-两年后公子偶然又遇到小翠-但小翠不愿再回他的家-和公子在外国生活了一段时间后小翠的模样渐渐变了-小翠为公子找了个于家姑娘为妻自己便消失了-婚后公子发现于家女儿就是小翠的模样方才知道小翠模样变化的原因-她将自己变成于家姑娘的模样为的是公子见到于家女儿就像见到她以解公子对她的思念之情&#34;&gt;#&lt;/a&gt; 《小翠》：浙江人王太常小时候，一个比猫大的动物在雷鸣电闪时钻到他的身下。后来王太常中了进士，并做了侍御。他膝下只有一子，但是个傻子。一日一位妇人到他家，并将自己的女儿小翠留给他做儿媳。小翠聪慧过人，深得公婆喜爱，但就是整日里和健儿子疯闹。有一个官员王给谏想诬告王侍御，小翠扮成宰相亲临王侍御家，让王给谏看到，从此收起了诬告王侍御的恶念。一次王给谏到了王侍御家，看到傻儿子扮成皇帝模样，王给谏到了朝上告了王侍御谋反之罪。皇上验明不过是疯儿傻媳的玩闹后，反倒将王给谏发配充军。王侍御觉出小翠不是寻常之人。一日傻公子洗澡，小翠趁势捂死了他。等公子又活过来后，傻病全好了。过了一年，王侍御被王给谏的同党参奏被罢了官。他准备拿一只玉瓶送给朝廷的人，好给自己找路子。谁知玉瓶被小翠打碎了，公婆二人将小翠一顿大骂。小翠不堪忍受公婆的辱骂，决定离开王侍御家。临走时告诉丈夫，说自己是狐狸，母亲因避雷灾曾受过王侍御的庇护，送自己来报恩。小翠走后公子痛哭欲死，王公夫妇也知自己铸成大错，追悔莫及。两年后公子偶然又遇到小翠。但小翠不愿再回他的家。和公子在外国生活了一段时间后，小翠的模样渐渐变了。小翠为公子找了个于家姑娘为妻，自己便消失了。婚后公子发现于家女儿就是小翠的模样，方才知道小翠模样变化的原因。她将自己变成于家姑娘的模样，为的是公子见到于家女儿就像见到她，以解公子对她的思念之情。&lt;/h3&gt;
&lt;h3 id=&#34;青凤故事的发展大约可以分为四个阶段-首先是耿去病初会青凤一见钟情第二次夜相见互诉衷情不料被青凤的叔叔撞破不欢而散第三层写第二年清明耿去病上坟得一狐提抱以归则青凤也于是同居生活得很幸福-最后写两年以后青凤的叔叔遭横难耿去病挺身救之由此如家人父子无复猜忌矣-故事首尾完具曲尽其妙-在封建社会里像这样曾经遭到家长反对后来终于得到谅解的恋爱和婚姻有是有的比较少见但有狐狸精的介入事情就好办一些了&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#青凤故事的发展大约可以分为四个阶段-首先是耿去病初会青凤一见钟情第二次夜相见互诉衷情不料被青凤的叔叔撞破不欢而散第三层写第二年清明耿去病上坟得一狐提抱以归则青凤也于是同居生活得很幸福-最后写两年以后青凤的叔叔遭横难耿去病挺身救之由此如家人父子无复猜忌矣-故事首尾完具曲尽其妙-在封建社会里像这样曾经遭到家长反对后来终于得到谅解的恋爱和婚姻有是有的比较少见但有狐狸精的介入事情就好办一些了&#34;&gt;#&lt;/a&gt; 《青凤》：故事的发展大约可以分为四个阶段。首先是耿去病初会青凤，一见钟情；第二，次夜相见，互诉衷情，不料被青凤的叔叔撞破，不欢而散；第三层写第二年清明耿去病上坟，得一狐，提抱以归，则青凤也，于是同居，生活得很幸福。最后写两年以后青凤的叔叔遭横难，耿去病挺身救之，&amp;quot;由此如家人父子，无复猜忌矣&amp;quot;。故事首尾完具，曲尽其妙。在封建社会里，像这样曾经遭到家长反对后来终于得到谅解的恋爱和婚姻，有是有的，比较少见，但有狐狸精的介入，事情就好办一些了。&lt;/h3&gt;
&lt;h3 id=&#34;促织国内风行都促织皇帝也喜欢于是官府把上交促织作为任务摊派下去-成名主人公也被摊派-官府要求的促织规定很高成名一时做不到合乎规格的促织非常着急-于是他老婆就去一个巫神那里问卜-巫神给了她一幅画上面画的野外的一座荒房什么的-成名觉得是指点捕捉促织的地点就按图索骥结果抓到一只非常好的促织他很高兴就把促织放起来准备第二天交上去-结果他的小儿子偷偷拿这只促织和别的小孩去玩让促织跑了-儿子知道这只促织对父亲的意义所以非常害怕就跳井自杀了-被人们就上来后没有死掉在昏迷中儿子就变成一只小小的促织-虽然这只促织很小但也没有办法成名也还是把它交了上去-谁知道这只小促织凶猛异常胜过了所有的优等促织甚至还咬破了公鸡的鸡冠-完成任务后儿子也醒了过来&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#促织国内风行都促织皇帝也喜欢于是官府把上交促织作为任务摊派下去-成名主人公也被摊派-官府要求的促织规定很高成名一时做不到合乎规格的促织非常着急-于是他老婆就去一个巫神那里问卜-巫神给了她一幅画上面画的野外的一座荒房什么的-成名觉得是指点捕捉促织的地点就按图索骥结果抓到一只非常好的促织他很高兴就把促织放起来准备第二天交上去-结果他的小儿子偷偷拿这只促织和别的小孩去玩让促织跑了-儿子知道这只促织对父亲的意义所以非常害怕就跳井自杀了-被人们就上来后没有死掉在昏迷中儿子就变成一只小小的促织-虽然这只促织很小但也没有办法成名也还是把它交了上去-谁知道这只小促织凶猛异常胜过了所有的优等促织甚至还咬破了公鸡的鸡冠-完成任务后儿子也醒了过来&#34;&gt;#&lt;/a&gt; 《促织》：国内风行都促织，皇帝也喜欢，于是官府把上交促织作为任务摊派下去。成名（主人公）也被摊派。官府要求的促织规定很高，成名一时做不到合乎规格的促织，非常着急。于是他老婆就去一个巫神那里问卜。巫神给了她一幅画，上面画的野外的一座荒房什么的。成名觉得是指点捕捉促织的地点，就按图索骥，结果抓到一只非常好的促织，他很高兴，就把促织放起来，准备第二天交上去。结果他的小儿子，偷偷拿这只促织和别的小孩去玩，让促织跑了。儿子知道这只促织对父亲的意义，所以非常害怕，就跳井自杀了。被人们就上来后，没有死掉，在昏迷中，儿子就变成一只小小的促织。虽然这只促织很小，但也没有办法，成名也还是把它交了上去。谁知道，这只小促织凶猛异常，胜过了所有的优等促织，甚至还咬破了公鸡的鸡冠。完成任务后，儿子也醒了过来。&lt;/h3&gt;
&lt;h3 id=&#34;席方平明朝末年河南监察御史席廉赈灾济民遭贪官秦士禄诬陷被朝廷斩首-其子席方平在古庙内为父亲守灵时半夜看到一妙龄少女出现在他面前-原来此女名小谢出身于书香门第被洛阳知府看中要纳为小妾她万般无奈只得以死抗争化作冤魂在她欲向巡抚秦士禄申冤时却看到秦正在徇私枉法贿赂钦差-而这正是陷害席方平之父的一幕-小谢得知席方平的遭遇同病相怜决心帮助他为父申冤-她带着席方平到阴曹地府去击鼓鸣冤不料判官-城隍-冥王等都是收到贿赂的贪官他们不问青红皂白对席方平施以火床烙身-利锯锯身等酷刑施刑的鬼役同情席方平手下留情没有锯到他的心脏才使他免于一死-气愤之中小谢带他到天庭告状仙界二郎神深受感动为他主持正义使大明皇帝了解了事实真相惩治了贪官污吏-席方平终于为父申冤昭雪-在这生死磨练中席方平与小谢两人产生了爱慕之情小谢也得以借尸还魂与席方平结成眷属&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#席方平明朝末年河南监察御史席廉赈灾济民遭贪官秦士禄诬陷被朝廷斩首-其子席方平在古庙内为父亲守灵时半夜看到一妙龄少女出现在他面前-原来此女名小谢出身于书香门第被洛阳知府看中要纳为小妾她万般无奈只得以死抗争化作冤魂在她欲向巡抚秦士禄申冤时却看到秦正在徇私枉法贿赂钦差-而这正是陷害席方平之父的一幕-小谢得知席方平的遭遇同病相怜决心帮助他为父申冤-她带着席方平到阴曹地府去击鼓鸣冤不料判官-城隍-冥王等都是收到贿赂的贪官他们不问青红皂白对席方平施以火床烙身-利锯锯身等酷刑施刑的鬼役同情席方平手下留情没有锯到他的心脏才使他免于一死-气愤之中小谢带他到天庭告状仙界二郎神深受感动为他主持正义使大明皇帝了解了事实真相惩治了贪官污吏-席方平终于为父申冤昭雪-在这生死磨练中席方平与小谢两人产生了爱慕之情小谢也得以借尸还魂与席方平结成眷属&#34;&gt;#&lt;/a&gt; 《席方平》：明朝末年，河南监察御史席廉赈灾济民，遭贪官秦士禄诬陷，被朝廷斩首。其子席方平在古庙内为父亲守灵时，半夜看到一妙龄少女出现在他面前。原来，此女名小谢，出身于书香门第，被洛阳知府看中要纳为小妾，她万般无奈只得以死抗争，化作冤魂，在她欲向巡抚秦士禄申冤时，却看到秦正在徇私枉法，贿赂钦差。而这正是陷害席方平之父的一幕。小谢得知席方平的遭遇，同病相怜，决心帮助他为父申冤。她带着席方平到阴曹地府去击鼓鸣冤，不料，判官、城隍、冥王等都是收到贿赂的贪官，他们不问青红皂白，对席方平施以火床烙身、利锯锯身等酷刑，施刑的鬼役同情席方平，手下留情，没有锯到他的心脏，才使他免于一死。气愤之中，小谢带他到天庭告状，仙界二郎神深受感动，为他主持正义，使大明皇帝了解了事实真相，惩治了贪官污吏。席方平终于为父申冤昭雪。在这生死磨练中，席方平与小谢两人产生了爱慕之情，小谢也得以借尸还魂，与席方平结成眷属。&lt;/h3&gt;
&lt;h3 id=&#34;梦狼官虎吏狼&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#梦狼官虎吏狼&#34;&gt;#&lt;/a&gt; 《梦狼》&amp;quot;官虎吏狼&amp;quot;&lt;/h3&gt;
&lt;p&gt;白甲在外边做官，他的父亲白翁（白老头）挂念他。丁某，也就是能在阳间阴间来回走的人，带了白翁到白甲官衙，白翁先看到官衙门口有一头巨大的狼看门，吓得不敢进，丁某硬把他拉进去，白翁又看到官衙里到处都是狼，官衙的白骨已经堆成山。白甲看到父亲来了，很高兴，下令备饭，马上，有一头巨狼叼了一个人来。白翁吓得浑身发抖，问：这是做什么呀？白甲平淡地回答 &amp;quot;用来当饭吃。&amp;quot; 白翁很害怕，辞别了儿子就走，一群狼却挡住他不让走。&lt;/p&gt;
&lt;p&gt;白翁正在进退两难时，突然来了两个怒目圆睁的金甲猛士，金甲猛士捉住白甲，白甲扑地化成了巨齿獠牙的猛虎。一个金甲猛士要砍掉白甲的脑袋，另一个说，不着急，这是明年的事，先把他的牙敲了。白翁醒后写了封信，劝导白甲要廉政爱民，派小儿子到白甲那儿看看。小儿子到了白甲的官衙，发现哥哥的门牙全掉了，问：怎么回事？白甲说骑马摔的。再问，什么时间摔的？恰好是白翁做梦的那天。小儿子把父亲的信拿出来给白甲看，苦口婆心地劝告他。白甲不听。&lt;/p&gt;
&lt;p&gt;弟弟在官衙住了几天，发现行贿的人络绎不绝。官衙的人都在搜刮民脂民膏。弟弟流着眼泪劝告哥哥不要这样，要爱护老百姓，白甲不以为然地说：&amp;quot;你是个乡下人，不知道做官有做官的妙诀，一个人能不能提拔，不决定于老百姓，而决定于上司。&amp;quot; 没过多久，白甲升了大官，可是在他赴任的路上，一群老百姓把他杀了。过了一会，有人把白甲救起，说这个人是白老头的儿子，老头还不坏，不应该让他看到这惨状，把这人的脑袋给接上。但是把脑袋反着安上。&lt;/p&gt;
&lt;p&gt;白甲复活后，脑袋朝后，眼睛能看到自己的背，大家都不把他当人看待。让人自顾其后，是个意味深长的细节。&lt;/p&gt;
&lt;h3 id=&#34;梦狼是带象征意味的小说县令化成吃人猛虎衙役是一群恶狼官衙以人为食吃得白骨如山比喻官场对百姓敲骨吸髓-官虎吏狼成为揭露封建社会黑暗现实的经典性概括&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#梦狼是带象征意味的小说县令化成吃人猛虎衙役是一群恶狼官衙以人为食吃得白骨如山比喻官场对百姓敲骨吸髓-官虎吏狼成为揭露封建社会黑暗现实的经典性概括&#34;&gt;#&lt;/a&gt; 《梦狼》是带象征意味的小说，县令化成吃人猛虎，衙役是一群恶狼，官衙以人为食，吃得白骨如山，比喻官场对百姓敲骨吸髓。&amp;quot;官虎吏狼&amp;quot; 成为揭露封建社会黑暗现实的经典性概括。&lt;/h3&gt;
&lt;h3 id=&#34;武技幼得名师指点学成一身武技自诩天下难对的武生想不到败在一卖艺女尼的五指之下股骨差点被削断&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#武技幼得名师指点学成一身武技自诩天下难对的武生想不到败在一卖艺女尼的五指之下股骨差点被削断&#34;&gt;#&lt;/a&gt; 《武技》：幼得名师指点，学成一身武技，自诩天下难对的武生，想不到败在一卖艺女尼的五指之下，股骨差点被削断。&lt;/h3&gt;
&lt;h3 id=&#34;胭脂说的是一个怀春美人胭脂在女友王氏怂恿下意图与意中人鄂生幽会-却想不到王氏之情人宿介早已垂涎胭脂夜晚竟冒充鄂生赴约幸胭脂不愿苟合宿介只抢得胭脂一只绣鞋就又到王氏住处可不料想鞋子竟掉在女友家窗外恰巧被屠户毛大拣去-毛大在窗下偷听了宿介自述的经过几天后翻墙入胭脂家但由于门户不熟悉误入胭脂父亲房间胭脂父亲发现后持刀来捉却反而被毛大杀死毛大在慌忙逃脱时将鞋子遗留在现场-这样胭脂认为是鄂生杀了父亲告到官府官府昏庸以鞋为证将鄂生抓来并屈打成招定成死罪-后来上级复案时调看犯人觉得鄂生不像杀人犯起疑便追问胭脂女友王氏才追出宿介曾冒充前来就抓来宿介又屈打成招定成死罪人们也称赞这位上司神明-可是宿介虽然放荡但颇有文才就向省府学官自己老师写了封申诉信-学官看了觉得确有疑点就请示主管重审又追查鞋子问题认定拾鞋人最可疑于是设谋定计捉到毛大案情才真相大白-真凶伏法鄂生-胭脂也终成眷属&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#胭脂说的是一个怀春美人胭脂在女友王氏怂恿下意图与意中人鄂生幽会-却想不到王氏之情人宿介早已垂涎胭脂夜晚竟冒充鄂生赴约幸胭脂不愿苟合宿介只抢得胭脂一只绣鞋就又到王氏住处可不料想鞋子竟掉在女友家窗外恰巧被屠户毛大拣去-毛大在窗下偷听了宿介自述的经过几天后翻墙入胭脂家但由于门户不熟悉误入胭脂父亲房间胭脂父亲发现后持刀来捉却反而被毛大杀死毛大在慌忙逃脱时将鞋子遗留在现场-这样胭脂认为是鄂生杀了父亲告到官府官府昏庸以鞋为证将鄂生抓来并屈打成招定成死罪-后来上级复案时调看犯人觉得鄂生不像杀人犯起疑便追问胭脂女友王氏才追出宿介曾冒充前来就抓来宿介又屈打成招定成死罪人们也称赞这位上司神明-可是宿介虽然放荡但颇有文才就向省府学官自己老师写了封申诉信-学官看了觉得确有疑点就请示主管重审又追查鞋子问题认定拾鞋人最可疑于是设谋定计捉到毛大案情才真相大白-真凶伏法鄂生-胭脂也终成眷属&#34;&gt;#&lt;/a&gt; 《胭脂》说的是一个怀春美人胭脂，在女友王氏怂恿下，意图与意中人鄂生幽会。却想不到王氏之情人宿介早已垂涎胭脂，夜晚竟冒充鄂生赴约，幸胭脂不愿苟合，宿介只抢得胭脂一只绣鞋就又到王氏住处，可不料想鞋子竟掉在女友家窗外，恰巧被屠户毛大拣去。毛大在窗下偷听了宿介自述的经过，几天后，翻墙入胭脂家，但由于门户不熟悉，误入胭脂父亲房间，胭脂父亲发现后持刀来捉却反而被毛大杀死，毛大在慌忙逃脱时将鞋子遗留在现场。这样胭脂认为是鄂生杀了父亲，告到官府，官府昏庸，以鞋为证，将鄂生抓来并屈打成招，定成死罪。后来上级复案时，调看犯人，觉得鄂生不像杀人犯，起疑，便追问胭脂女友 —— 王氏，才追出宿介曾冒充前来，就抓来宿介，又屈打成招，定成死罪，人们也称赞这位上司神明。可是宿介虽然放荡，但颇有文才，就向省府学官（自己老师）写了封申诉信。学官看了觉得确有疑点，就请示主管重审，又追查鞋子问题，认定拾鞋人最可疑，于是设谋定计，捉到毛大，案情才真相大白。真凶伏法，鄂生、胭脂也终成眷属。&lt;/h3&gt;
&lt;h3 id=&#34;田七郎说一位豪爽乡绅结交了很多朋友一天夜里梦见有人对他说你现在这些朋友都不理想只有-田七郎-才值得你交-他醒来就寻找田七郎知道七郎是个穷猎人-多次登门拜访为田母斥责不愿他俩亲近-后来田七郎为猎豹与人发生争执失手杀了人被抓进监狱这乡绅花了很多钱救出了田七郎以后交往田母也不再阻拦-一天乡绅家佣人调戏主人儿媳后逃到乡绅仇人家并造谣说儿媳与之私通-乡绅气极但无奈想找田七郎商议田七郎也不见了乡绅很奇怪-可是不久听说那坏佣人被人杀了抛尸荒野-乡绅估计是田七郎干的派人到家找他也找不到-乡绅仇人勾结官吏抓了乡绅而此时乡绅的朋友都散了谁也不来帮忙伸冤-一天县官正在和乡绅的仇人一起谈事突然来了个担柴人冲上大堂抽刀杀了乡绅仇人-县官乱中躲开了这人找不到县官就自刎而死-可是当县官出来验看凶手尸体时这尸体突然跳起一刀砍下县官的头这才又倒下了-这杀人者正是田七郎杀人以尸真是从古未见&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#田七郎说一位豪爽乡绅结交了很多朋友一天夜里梦见有人对他说你现在这些朋友都不理想只有-田七郎-才值得你交-他醒来就寻找田七郎知道七郎是个穷猎人-多次登门拜访为田母斥责不愿他俩亲近-后来田七郎为猎豹与人发生争执失手杀了人被抓进监狱这乡绅花了很多钱救出了田七郎以后交往田母也不再阻拦-一天乡绅家佣人调戏主人儿媳后逃到乡绅仇人家并造谣说儿媳与之私通-乡绅气极但无奈想找田七郎商议田七郎也不见了乡绅很奇怪-可是不久听说那坏佣人被人杀了抛尸荒野-乡绅估计是田七郎干的派人到家找他也找不到-乡绅仇人勾结官吏抓了乡绅而此时乡绅的朋友都散了谁也不来帮忙伸冤-一天县官正在和乡绅的仇人一起谈事突然来了个担柴人冲上大堂抽刀杀了乡绅仇人-县官乱中躲开了这人找不到县官就自刎而死-可是当县官出来验看凶手尸体时这尸体突然跳起一刀砍下县官的头这才又倒下了-这杀人者正是田七郎杀人以尸真是从古未见&#34;&gt;#&lt;/a&gt; 《田七郎》，说一位豪爽乡绅结交了很多朋友，一天夜里，梦见有人对他说：你现在这些朋友，都不理想，只有 &lt;strong&gt;田七郎&lt;/strong&gt; 才值得你交。他醒来就寻找田七郎，知道七郎是个穷猎人。多次登门拜访，为田母斥责，不愿他俩亲近。后来田七郎为猎豹与人发生争执，失手杀了人，被抓进监狱，这乡绅花了很多钱救出了田七郎，以后交往，田母也不再阻拦。一天乡绅家佣人调戏主人儿媳后逃到乡绅仇人家，并造谣说儿媳与之私通。乡绅气极，但无奈，想找田七郎商议，田七郎也不见了，乡绅很奇怪。可是不久，听说那坏佣人被人杀了，抛尸荒野。乡绅估计是田七郎干的，派人到家找他也找不到。乡绅仇人勾结官吏，抓了乡绅，而此时乡绅的朋友都散了，谁也不来帮忙伸冤。一天县官正在和乡绅的仇人一起谈事，突然来了个担柴人冲上大堂，抽刀杀了乡绅仇人。县官乱中躲开了，这人找不到县官就自刎而死。可是当县官出来验看凶手尸体时，这尸体突然跳起，一刀砍下县官的头，这才又倒下了。这杀人者正是田七郎，&amp;quot;杀人以尸&amp;quot;，真是从古未见。&lt;/h3&gt;
&lt;h3 id=&#34;劳山道士则说的是一心术不正的-王生-想跟劳山道士学穿房过墙一无阻拦的法术-法师教他念好咒语后猛然向墙撞去就行了-王生学会后道士又说归宜洁持否则不验-王生下山回家后向妻子夸耀他学到过墙的本领了妻子让他试一下他念好咒语一头向墙撞去结果咚的一下倒在地上头上撞了个大包妻儿笑他他气得大骂法师没有良心&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#劳山道士则说的是一心术不正的-王生-想跟劳山道士学穿房过墙一无阻拦的法术-法师教他念好咒语后猛然向墙撞去就行了-王生学会后道士又说归宜洁持否则不验-王生下山回家后向妻子夸耀他学到过墙的本领了妻子让他试一下他念好咒语一头向墙撞去结果咚的一下倒在地上头上撞了个大包妻儿笑他他气得大骂法师没有良心&#34;&gt;#&lt;/a&gt; 《劳山道士》则说的是一心术不正的 &lt;strong&gt;王生&lt;/strong&gt; 想跟劳山道士学穿房过墙一无阻拦的法术。法师教他念好咒语后，猛然向墙撞去就行了。王生学会后，道士又说：&amp;quot;归宜洁持，否则不验。&amp;quot; 王生下山回家后，向妻子夸耀他学到过墙的本领了，妻子让他试一下，他念好咒语，一头向墙撞去，结果咚的一下，倒在地上，头上撞了个大包，妻儿笑他，他气得大骂法师没有良心。&lt;/h3&gt;
&lt;h3 id=&#34;陆判说的是一位士子交上一个鬼判这鬼判为他妻子换了个美人头为他换了个聪明心&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#陆判说的是一位士子交上一个鬼判这鬼判为他妻子换了个美人头为他换了个聪明心&#34;&gt;#&lt;/a&gt; 《陆判》说的是一位士子交上一个鬼判，这鬼判为他妻子换了个美人头，为他换了个聪明心。&lt;/h3&gt;
&lt;h3 id=&#34;叶生写书生-叶生文章词赋冠绝当时可是时数限人文章憎命每次都考不中-幸而还有个做官的好友推荐但仍是考不中-而这位好友又要到别处为官想带他去一边教自己的孩子一边让叶生再考但叶生此时却生病了难以随行-眼看良机靠山皆要消失就焦虑而死可是魂灵却和这位好友一齐走了好友也不知是魂灵-又是几年好友儿子在良师叶生指导下考中了当了大官就帮助自己老师鬼魂也考中了又劝他衣锦还乡-叶生至家惊呆了妻儿又看到自己的棺材灵牌才知道自己已死随即扑地而灭-这个魂从知己不觉已死生不能中死才能中而中了后却又灭了-这些情节比范进中举还要丰富&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#叶生写书生-叶生文章词赋冠绝当时可是时数限人文章憎命每次都考不中-幸而还有个做官的好友推荐但仍是考不中-而这位好友又要到别处为官想带他去一边教自己的孩子一边让叶生再考但叶生此时却生病了难以随行-眼看良机靠山皆要消失就焦虑而死可是魂灵却和这位好友一齐走了好友也不知是魂灵-又是几年好友儿子在良师叶生指导下考中了当了大官就帮助自己老师鬼魂也考中了又劝他衣锦还乡-叶生至家惊呆了妻儿又看到自己的棺材灵牌才知道自己已死随即扑地而灭-这个魂从知己不觉已死生不能中死才能中而中了后却又灭了-这些情节比范进中举还要丰富&#34;&gt;#&lt;/a&gt; 《叶生》，写书生 &lt;strong&gt;叶生&lt;/strong&gt; &amp;quot;文章词赋，冠绝当时&amp;quot;，可是 &amp;quot;时数限人，文章憎命&amp;quot;，每次都考不中。幸而还有个做官的好友推荐，但仍是考不中。而这位好友，又要到别处为官，想带他去，一边教自己的孩子，一边让叶生再考，但叶生此时却生病了，难以随行。眼看良机靠山皆要消失，就焦虑而死，可是魂灵却和这位好友一齐走了，好友也不知是魂灵。又是几年，好友儿子在良师 &amp;quot;叶生&amp;quot; 指导下，考中了，当了大官，就帮助自己老师（鬼魂）也考中了，又劝他衣锦还乡。&amp;quot;叶生&amp;quot; 至家，惊呆了妻儿，又看到自己的棺材灵牌，才知道自己已死，随即扑地而灭。这个 &amp;quot;魂从知己&amp;quot; 不觉已死，生不能中，死才能中，而中了后，却又 &amp;quot;灭&amp;quot; 了。这些情节比《范进中举》还要丰富。&lt;/h3&gt;
&lt;h3 id=&#34;红玉先写-红玉与冯生-燕好似乎可以结束了但为冯父发觉极力反对冯生只好遵父命决裂-而红玉却又另觅替身卫氏并极力促成冯卫结婚生子福儿琴瑟和谐似又可结束却又想不到一士豪要来夺妻逼得冯生父死妻亡只能抱儿外逃-家破人亡之际不想来一侠客杀了仇家官府抓了冯生指为杀人犯后又得侠客救助才被释放-到家时大仇虽报而只剩孤身何等凄凉想不到红玉又带着丢失的儿子来了又是破镜重圆-真是一会儿花好月圆一会儿花残月落一会乐上天堂一会悲入地狱-大起大落难有其匹&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#红玉先写-红玉与冯生-燕好似乎可以结束了但为冯父发觉极力反对冯生只好遵父命决裂-而红玉却又另觅替身卫氏并极力促成冯卫结婚生子福儿琴瑟和谐似又可结束却又想不到一士豪要来夺妻逼得冯生父死妻亡只能抱儿外逃-家破人亡之际不想来一侠客杀了仇家官府抓了冯生指为杀人犯后又得侠客救助才被释放-到家时大仇虽报而只剩孤身何等凄凉想不到红玉又带着丢失的儿子来了又是破镜重圆-真是一会儿花好月圆一会儿花残月落一会乐上天堂一会悲入地狱-大起大落难有其匹&#34;&gt;#&lt;/a&gt; 《红玉》先写 &lt;strong&gt;红玉与冯生&lt;/strong&gt; 燕好，似乎可以结束了，但为冯父发觉，极力反对，冯生只好遵父命决裂。而红玉却又另觅替身卫氏，并极力促成冯卫结婚，生子福儿，琴瑟和谐，似又可结束，却又想不到一士豪要来夺妻，逼得冯生父死妻亡，只能抱儿外逃。家破人亡之际不想来一侠客，杀了仇家，官府抓了冯生，指为杀人犯，后又得侠客救助，才被释放。到家时，大仇虽报，而只剩孤身，何等凄凉，想不到，红玉又带着丢失的儿子来了，又是破镜重圆。真是一会儿花好月圆，一会儿花残月落；一会乐上天堂，一会悲入地狱。大起大落，难有其匹。&lt;/h3&gt;
&lt;h3 id=&#34;翩翩中讲了一个-浪子-离家出走喝吃嫖赌招摇弄得一身浓疮行乞回乡里为人不齿不敢回家-就凭这一点知耻之心得到仙女翩翩的救护帮他治好了病给他穿上了仙衣并和他结了婚生了孩子生活安定-回到故乡的家后再找翩翩找不到了&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#翩翩中讲了一个-浪子-离家出走喝吃嫖赌招摇弄得一身浓疮行乞回乡里为人不齿不敢回家-就凭这一点知耻之心得到仙女翩翩的救护帮他治好了病给他穿上了仙衣并和他结了婚生了孩子生活安定-回到故乡的家后再找翩翩找不到了&#34;&gt;#&lt;/a&gt; 《翩翩》中讲了一个 &lt;strong&gt;浪子&lt;/strong&gt; ，离家出走，喝吃嫖赌招摇，弄得一身浓疮，行乞回乡里，为人不齿，不敢回家。就凭这一点 &amp;quot;知耻之心&amp;quot;，得到仙女翩翩的救护，帮他治好了病，给他穿上了 &amp;quot;仙衣&amp;quot;，并和他结了婚，生了孩子，生活安定。回到故乡的家后，再找翩翩，找不到了。&lt;/h3&gt;
&lt;h2 id=&#34;五-聊斋志异七大情事&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#五-聊斋志异七大情事&#34;&gt;#&lt;/a&gt; &lt;strong&gt;五、《聊斋志异》七大情事&lt;/strong&gt;&lt;/h2&gt;
&lt;h3 id=&#34;婴宁&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#婴宁&#34;&gt;#&lt;/a&gt; 《婴宁》&lt;/h3&gt;
&lt;p&gt;书生 &lt;strong&gt;王子服&lt;/strong&gt; 在元宵灯会偶遇佳人，他捡起姑娘丢落的梅花，相思成疾。表兄吴生诳他说女子是他的表妹，在西南三十里的山里。王子服一人入山寻找，见到佳人，不想竟是自己的姨妹，叫婴宁。婴宁本为狐产女子且随鬼母长大，全然不知道人间的礼数，憨纯无比。当子服向她求寝时，她竟然以 &amp;quot;不惯与生人睡&amp;quot; 相答，并将此事告诉鬼母。&lt;/p&gt;
&lt;p&gt;后来，婴宁和子服一起归家。王母和吴生都疑心是鬼，但见她成日爱花爱笑，不避太阳，就让她和子服结为夫妻。婚后还惩治了邻家的浪荡子。一天夜里，婴宁告诉子服她的生事，并求他迁其鬼母的坟与自己的生母和葬。&lt;/p&gt;
&lt;p&gt;又过了一年，婴宁生下一子。在娘怀里就不怕生人，和婴宁一样。&lt;/p&gt;
&lt;h3 id=&#34;聂小倩&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#聂小倩&#34;&gt;#&lt;/a&gt; 《聂小倩》&lt;/h3&gt;
&lt;p&gt;书生 &lt;strong&gt;宁采臣&lt;/strong&gt; 为人豪爽，洁身自爱。&lt;/p&gt;
&lt;p&gt;一次他坐在金华一座庙里，同坐的还有一个叫燕赤霞的书生，有奇异的收妖的本领。一女鬼夜里前来勾引宁采臣，被他严词拒绝。第二天，有两个兰溪的过路人在隔壁离奇死了。当晚，女鬼又来，告诉他自己叫聂小倩，被恶鬼胁迫，求他帮助自己脱离苦海。宁采臣按小倩说的把她的尸骨迁到了里自家不远处。小倩随他回到家中。宁采臣妻死后，宁采臣娶小倩为妻。&lt;/p&gt;
&lt;p&gt;一天，小倩告诉宁采臣说金华的妖怪就要来寻仇了。于是，宁采臣拿出燕赤霞给他的辟邪的牛皮袋挂在床前。这时小倩已经有了人气，不再害怕辟邪的东西了。第二天晚上，妖怪果然来到，被收服在牛皮袋里化作了数斗清水。&lt;/p&gt;
&lt;p&gt;后聂小倩为宁采臣生得二子，皆有功名。&lt;/p&gt;
&lt;h3 id=&#34;辛十四娘&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#辛十四娘&#34;&gt;#&lt;/a&gt; 《辛十四娘》&lt;/h3&gt;
&lt;p&gt;明朝正德年间，一姓冯的书生清晨遇一娇艳动人的美人，傍晚时分见美人从一座破庙里出来又回去。于是冯生进去一探究竟，对一老头说明自己爱慕女子之心，并硬闯闺房被赶出。在回家的路上，又误入自己祖母的弟弟的鬼宅。鬼宅的老太太答应为外甥提亲。&lt;/p&gt;
&lt;p&gt;果然， &lt;strong&gt;冯生&lt;/strong&gt; 和 &lt;strong&gt;十四娘&lt;/strong&gt; 结成秦晋之好。&lt;/p&gt;
&lt;p&gt;后冯生几番得罪楚银台的公子被害下狱，在辛十四娘的努力下才得以脱险。但经此事后，十四娘对冯生很失望，看透尘缘。第二天容光大变，日渐衰老，半年后像一个八十岁的老太婆了。尽管冯生照顾的很好，还是一病不起，溘然逝去。留下丫头做了冯生的妻子。&lt;/p&gt;
&lt;p&gt;后来，老仆人在太华山见到辛十四娘骑着一头青骡子，对老仆人说 &amp;quot;冯郎还好吗？回去告诉他，我已名列仙藉了。&amp;quot;&lt;/p&gt;
&lt;h3 id=&#34;香玉&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#香玉&#34;&gt;#&lt;/a&gt; 《香玉》&lt;/h3&gt;
&lt;p&gt;一个姓 &lt;strong&gt;黄的书生&lt;/strong&gt; 坐在崂山下清宫里读书。院里有几棵耐冬和几株牡丹。一天，黄生看见一穿白衣的女子在花丛中忽隐忽现，后来又看见一个穿红衣的。他对白衣姑娘顿生爱慕之心，写诗想念，不想，竟感化女郎成其好事。女郎告诉他自己叫香玉，红衣的叫绛雪。直到园里的一株牡丹被买走，才知香玉是花精。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;黄生&lt;/strong&gt; 得知牡丹枯萎死去，就作了 50 首情诗悼念香玉。&lt;/p&gt;
&lt;p&gt;终于感动花神，让香玉重生。在香玉柔弱生长的时候，绛雪就陪黄生读书。后来，香玉完全恢复，和黄生过上了夫妻一样的生活。&lt;/p&gt;
&lt;p&gt;10 年后，黄生死去。他死前说 &amp;quot;我死了会变成牡丹花下的一株红色花芽，长五瓣叶子。&amp;quot; 果然如他所说。&lt;/p&gt;
&lt;p&gt;3 年后，道士的徒弟把黄生化身的牡丹砍掉，随后，园里的耐冬和牡丹相继徇情而死。&lt;/p&gt;
&lt;h3 id=&#34;公孙九娘&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#公孙九娘&#34;&gt;#&lt;/a&gt; 《公孙九娘》&lt;/h3&gt;
&lt;p&gt;顺治年间，莱阳的书生到济南去祭拜自己的亲友，遇见死去的同县的朱生央求他给自己做媒，把同样是鬼的莱阳生的侄女嫁给他。 &lt;strong&gt;莱阳生&lt;/strong&gt; 同意后，在侄女家，他邂逅了天仙一般的公孙九娘。由朱生牵红线，人鬼结合。&lt;/p&gt;
&lt;p&gt;一天，九娘哭着要求莱阳生把自己的尸骨重新迁到母亲的坟旁，并告诉他，人鬼殊途，不宜久留，别了送给他一双罗袜。&lt;/p&gt;
&lt;p&gt;但终因她死后埋在乱葬岗中而使莱阳生无法寻找，终于导致二人爱情失败。&lt;/p&gt;
&lt;p&gt;过了半年，莱阳生又去济南，天色暗下，只见一地鬼火，旧地重游，无限惆怅。隐约中看见公孙九娘在坟岗之间，莱阳生连连呼唤：&amp;quot;九娘，九娘……&amp;quot; 却始终不见公孙九娘回答。&lt;/p&gt;
&lt;h3 id=&#34;白秋练&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#白秋练&#34;&gt;#&lt;/a&gt; 《白秋练》&lt;/h3&gt;
&lt;p&gt;书生 &lt;strong&gt;慕蟾宫&lt;/strong&gt; 和父亲到湖北一带跑船做买卖。无事便在船上读诗。不久，被一个叫白秋练的女子仰慕，使其害病。天黑后，女子的母亲和一婢女领白秋练到船上，慕生念情诗将其病治好，见她美貌，便和她共床枕一晚。&lt;/p&gt;
&lt;p&gt;后来随父亲回家后，思念成疾，其父只好带他又来到湖北慕生和白秋练相遇的地方。当晚，白秋练来到船上，这次换了是她给慕生念情诗，将其救活。两人由此结合，过了三年生了一个小孩。&lt;/p&gt;
&lt;p&gt;一天，白秋练告诉他自己是一条鲤鱼精，现在龙王要招她为妃，并恳求慕生救自己的母亲和让她免于被龙王占有。在白秋练的指点下，慕生遇一道士，得以救回白秋练。&lt;/p&gt;
&lt;p&gt;后来慕生的父亲死后，一家人搬到湖北，再也没有回故乡。&lt;/p&gt;
&lt;h3 id=&#34;娇娜&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#娇娜&#34;&gt;#&lt;/a&gt; 《娇娜》&lt;/h3&gt;
&lt;p&gt;一个叫 &lt;strong&gt;孔雪笠&lt;/strong&gt; 的书生，性情文雅仁厚，善作诗。一次路过一家大门，被请进去做客，还做了这家公子的老师。过了半年，正当夏天，孔雪笠的胸口上长了一个碗大的脓疮。公子让表妹娇娜前来医治。娇娜美貌的面容让孔雪笠惊为天人，一时竟忘了疼痛。经过娇娜的医治，孔雪笠的病也日渐好转，而孔雪笠也对娇娜暗生情素。孔雪笠对娇娜思念之情渐渐难以抑制。&lt;/p&gt;
&lt;p&gt;公子不知道孔生中意娇娜，却将另一个表妹阿松嫁给了孔生。而不久，娇娜也嫁与吴郎。两人本以萌发的爱情升华为友情。&lt;/p&gt;
&lt;p&gt;一天，公子告知孔生他和娇娜，阿松都是狐狸，恳求孔生帮他们避开雷击。结果，孔生冒着被雷击的危险救下娇娜，而娇娜为救孔生两人肌肤相亲，接吻送丸，让孔生起死回生。也是这一天，娇娜的丈夫吴郎一家没有避过劫难。&lt;/p&gt;
&lt;p&gt;娇娜只好和表哥一起前去孔生家。&lt;/p&gt;
&lt;p&gt;孔生有空就去陪他们兄妹下棋，饮酒。两人再没有谈及儿女私情，终究有缘无份。&lt;/p&gt;
&lt;h2 id=&#34;六-读后感&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#六-读后感&#34;&gt;#&lt;/a&gt; 六、读后感&lt;/h2&gt;
&lt;p&gt;对于聊斋志异里的故事，我觉得说作者写他的目的是例如什么反封建一类的，是对他的一种亵渎，这里面的故事，实际上就是作者听到的传说或是自己编的故事，只是在一个大的时代背景下，作者通过一些离奇的故事，写出自己的看法、期望与现象。有一定时代的烙印，在客观上折射社会现实，但不等同于主这些这部作品的目的是批判现实的黑暗。故事中有相当的一部分是用来描述人与鬼之间纯洁、真挚、相互扶携的情感。这说明，作者对于当时的时代，是有幻想的。&lt;/p&gt;
&lt;p&gt;聊斋倒是说了一个事，那就是到多数的妖精本性也都是善良的。而对于现在的社会，人们时常抱怨世风日下，人们没有了过去的那种淳朴，变得自我、骄横、自私、势力，然而，不变的却仍是，在世上，好人永远比坏人多。我们可以用一个放大镜去观察我们的生活，但观察身边令我们感动的事，还是专门关心社会中不和谐的声音，取决于拿着放大镜的我们。我并不是说睁一只眼闭一只眼，对社会上不公正的事视而不见、置若罔闻，而是用一个理性、客观的角度分析，以求解决矛盾。一个义愤填膺的人，体现的是谁会的正义感，但一群义愤填膺的认为在一起，只顾 &amp;quot;正义&amp;quot; 地指责，将会带来非常不好的谁会影响，使一件本身并不是多么严重的问题，带上各种高帽子，随便是谁，都凑上来发表几句无关痛痒的评论和指责，接着就又有 &amp;quot;世道变了，人心不古&amp;quot; 的感叹，然而这样真的可以解决问题么？与其这样，我们不如利用正义的事，来感化不和谐的声音，这么说或许有一些太过于理想化，但是，至少可以有一个积极的社会氛围，而不是怨声载道。&lt;/p&gt;
&lt;p&gt;聊斋告诉我们，妖精也可以与人类和谐相处，那我们又为什么要带上有色眼镜看这样一群人？生活中会有一些人给人的印象就是 &amp;quot;不是好人&amp;quot;，但永远不要在不了解一个人之前，给他戴上任何帽子。有的人看上去和颜悦色，但实际上笑里藏刀；有的人看上去总黑着脸，但总会给你最给力的支持。聊斋这些故事，也告诉我要学会了解一个人的本质，不要以貌取人。&lt;br /&gt;
&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;span class=&#34;exturl image&#34; data-url=&#34;aHR0cHM6Ly9jZG4uamRqd3p4YXBpLmZ1bi/jgIrogYrmlovlv5flvILjgIvnroDku4vlj4ror7vlkI7mhJ8uZG9jeA==&#34; data-background-image=&#34;https://bu.dusays.com/2022/08/18/62fe0d5d77bf2.png&#34;&gt;&lt;/span&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;span class=&#34;exturl title&#34; data-url=&#34;aHR0cHM6Ly9jZG4uamRqd3p4YXBpLmZ1bi/jgIrogYrmlovlv5flvILjgIvnroDku4vlj4ror7vlkI7mhJ8uZG9jeA==&#34;&gt;下载文档(docx)&lt;/span&gt;
          &lt;p class=&#34;desc&#34;&gt;下载文档(docx)&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;文章转载于夸克文档，侵删。&lt;/p&gt;
&lt;/div&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="概括" scheme="https://jdjwzx233.cn/tags/%E6%A6%82%E6%8B%AC/" />
        <category term="名著" scheme="https://jdjwzx233.cn/tags/%E5%90%8D%E8%91%97/" />
        <category term="聊斋志异" scheme="https://jdjwzx233.cn/tags/%E8%81%8A%E6%96%8B%E5%BF%97%E5%BC%82/" />
        <updated>2022-08-18T18:46:24.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/08/14/%E6%B0%B4%E6%B5%92%E4%BC%A0%E6%A6%82%E6%8B%AC/</id>
        <title>《水浒传》每章概括</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/08/14/%E6%B0%B4%E6%B5%92%E4%BC%A0%E6%A6%82%E6%8B%AC/"/>
        <content type="html">&lt;p&gt;&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_1.jpg&#34; alt=&#34;Water_Margin_summary_1&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_2.jpg&#34; alt=&#34;Water_Margin_summary_2&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_3.jpg&#34; alt=&#34;Water_Margin_summary_3&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_4.jpg&#34; alt=&#34;Water_Margin_summary_4&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_5.jpg&#34; alt=&#34;Water_Margin_summary_5&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_6.jpg&#34; alt=&#34;Water_Margin_summary_6&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_7.jpg&#34; alt=&#34;Water_Margin_summary_7&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_8.jpg&#34; alt=&#34;Water_Margin_summary_8&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_9.jpg&#34; alt=&#34;Water_Margin_summary_9&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_10.jpg&#34; alt=&#34;Water_Margin_summary_10&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_11.jpg&#34; alt=&#34;Water_Margin_summary_11&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_12.jpg&#34; alt=&#34;Water_Margin_summary_12&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_13.jpg&#34; alt=&#34;Water_Margin_summary_13&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_14.jpg&#34; alt=&#34;Water_Margin_summary_14&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_15.jpg&#34; alt=&#34;Water_Margin_summary_15&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_16.jpg&#34; alt=&#34;Water_Margin_summary_16&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_17.jpg&#34; alt=&#34;Water_Margin_summary_17&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_18.jpg&#34; alt=&#34;Water_Margin_summary_18&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_19.jpg&#34; alt=&#34;Water_Margin_summary_19&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_20.jpg&#34; alt=&#34;Water_Margin_summary_20&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_21.jpg&#34; alt=&#34;Water_Margin_summary_21&#34; /&gt;&lt;br /&gt;
&lt;img data-src=&#34;/image/Water_Margin_summary/Water_Margin_summary_22.jpg&#34; alt=&#34;Water_Margin_summary_22&#34; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;a href=&#34;/download/Water%20Margin%20summary_jdjwzx233%20crack_20220814.7z&#34; class=&#34;image&#34; data-background-image=&#34;/image/other/62fe0d5d77bf2.png&#34;&gt;&lt;/a&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;a href=&#34;/download/Water%20Margin%20summary_jdjwzx233%20crack_20220814.7z&#34; class=&#34;title&#34;&gt;一键下载所有图片(7Z)&lt;/a&gt;
          &lt;p class=&#34;desc&#34;&gt;一键下载所有图片(7Z)&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;div class=&#34;note warning&#34;&gt;
&lt;p&gt;图片转载于夸克文档 ---《水浒传每回内容梗概_完整版》（&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly92dC5xdWFyay5jbi9ibG0vcXVhcmstZG9jLXNzci0yOTMvcHJldmlldz9hcHBOYW1lPTEmYW1wO2JpPTM1ODI1JmFtcDtjaD1rayU0MHN0b3JlJmFtcDtkZT1BQU96d0VYSDhvSG1xM2FkTU15UW1md210b1IzQmt5d0VqSmFKYjlza1ZMQWJnJTI1M0QlMjUzRCZhbXA7ZG49NTY3NzY0ODkzMjQtMGM0YWVjMWMmYW1wO2RzPUFBTlAyaFNBcDhNJTJCcVlOV0VKaTklMkZnaSUyQm9oeGpNYjFaaE5WYUxhTGJHR3F0NGclM0QlM0QmYW1wO2VpPWJUa3dCQVh6OEwlMkZ6YTJRUXhFdFIyd085VHklMkJIOVZjTnRRJTNEJTNEJmFtcDtmcF9mcm9tPXZpZXdzcGFnZSZhbXA7ZnI9YW5kcm9pZCZhbXA7ZnJvbT0mYW1wO2dpPWJUa3dCTkJhdXNUNnBWSVQ4ZFVUM1BCa0lCVjIlMjUyRjVySnd0NHpKdTF6aTFVWURsbyUyNTNEJmFtcDtpZD0yNTA1QzFENkNGNUM3QUU1ODVBM0ZBOEJCODcwOTlDNSZhbXA7a3A9QUFUaGtXRFUxMyUyQmphajJLMnI5eHhzSGhwYUZFRGhkSkI2dzFuenNFTFNwTVhNcGtmS2ZLOHVUTDZHWjMzV08lMkZuMVJSQkN1bnJhZ2wwdmNONUg0SWdSMjVFT2Z4YjQyMUE3Qk5xJTJGU1RtNVNTZUElM0QlM0QmYW1wO250PTUmYW1wO253PTAmYW1wO3BmPTMzMDAmYW1wO3ByPXVjcHJvJmFtcDtzaWQ9MTYwODFlNmNmODQxNTcxMDgwNWUwOTkwYzVjZTA2NjUmYW1wO3N2PXJlbGVhc2UmYW1wO3VjX2Jpel9zdHI9T1BUJTNBQkFDS19CVE5fU1RZTEUlNDAwJTdDT1BUJTNBVE9PTEJBUl9TVFlMRSU0MDAlN0NPUFQlM0FTX0JBUl9CR19DT0xPUiU0MGZmZmZmZiZhbXA7dWNfcGFyYW1fc3RyPWRubnRud3ZlcGZmcmdpYmlqYnByc3ZwaWRpY2hlaXV0ZHNrcCZhbXA7dXQ9QUFOUDJoU0FwOE0lMkJxWU5XRUppOSUyRmdpJTJCb2h4ak1iMVpoTlZhTGFMYkdHcXQ0ZyUzRCUzRCZhbXA7dmU9NS40LjUuMTk4JmFtcDtwcmV2aWV3U2hhcmU9cHJldmlld1NoYXJl&#34;&gt;点我前往&lt;/span&gt;）（&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9vY2suY24vaXIwcHU=&#34;&gt;打不开点我&lt;/span&gt;），侵删。&lt;/p&gt;
&lt;/div&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/categories/%E8%AF%AD%E6%96%87/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="语文" scheme="https://jdjwzx233.cn/tags/%E8%AF%AD%E6%96%87/" />
        <category term="概括" scheme="https://jdjwzx233.cn/tags/%E6%A6%82%E6%8B%AC/" />
        <category term="名著" scheme="https://jdjwzx233.cn/tags/%E5%90%8D%E8%91%97/" />
        <category term="水浒传" scheme="https://jdjwzx233.cn/tags/%E6%B0%B4%E6%B5%92%E4%BC%A0/" />
        <updated>2022-08-14T15:52:41.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/08/02/git/</id>
        <title>Git 常用命令</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/08/02/git/"/>
        <content type="html">&lt;h1 id=&#34;git-常用命令&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#git-常用命令&#34;&gt;#&lt;/a&gt; Git 常用命令&lt;/h1&gt;
&lt;h2 id=&#34;初始化仓库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#初始化仓库&#34;&gt;#&lt;/a&gt; 初始化仓库&lt;/h2&gt;
&lt;p&gt;git init&lt;/p&gt;
&lt;h2 id=&#34;添加所有文件&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#添加所有文件&#34;&gt;#&lt;/a&gt; 添加所有文件&lt;/h2&gt;
&lt;p&gt;git add .&lt;/p&gt;
&lt;h2 id=&#34;添加提交注释&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#添加提交注释&#34;&gt;#&lt;/a&gt; 添加提交注释&lt;/h2&gt;
&lt;p&gt;git commit -m &amp;quot;xxx&amp;quot;&lt;/p&gt;
&lt;h2 id=&#34;本地代码推送到远程仓库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#本地代码推送到远程仓库&#34;&gt;#&lt;/a&gt; 本地代码推送到远程仓库&lt;/h2&gt;
&lt;p&gt;git push origin master&lt;/p&gt;
&lt;h2 id=&#34;拉取远程分支代码到本地&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#拉取远程分支代码到本地&#34;&gt;#&lt;/a&gt; 拉取远程分支代码到本地&lt;/h2&gt;
&lt;p&gt;git pull origin master&lt;/p&gt;
&lt;h2 id=&#34;创建本地分支-a&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#创建本地分支-a&#34;&gt;#&lt;/a&gt; 创建本地分支 A&lt;/h2&gt;
&lt;p&gt;git branch A&lt;/p&gt;
&lt;h2 id=&#34;切换到分支-a&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#切换到分支-a&#34;&gt;#&lt;/a&gt; 切换到分支 A&lt;/h2&gt;
&lt;p&gt;git checkout A&lt;/p&gt;
&lt;h2 id=&#34;创建并切换到本地分支-a&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#创建并切换到本地分支-a&#34;&gt;#&lt;/a&gt; 创建并切换到本地分支 A&lt;/h2&gt;
&lt;p&gt;git checkout -b A&lt;/p&gt;
&lt;h2 id=&#34;将分支-a-代码合并到当前分支&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#将分支-a-代码合并到当前分支&#34;&gt;#&lt;/a&gt; 将分支 A 代码合并到当前分支&lt;/h2&gt;
&lt;p&gt;git merge A&lt;/p&gt;
&lt;h2 id=&#34;将当前分支的-head-指向-a-分支&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#将当前分支的-head-指向-a-分支&#34;&gt;#&lt;/a&gt; 将当前分支的 HEAD 指向 A 分支&lt;/h2&gt;
&lt;p&gt;git rebase A&lt;/p&gt;
&lt;h2 id=&#34;删除本地分支&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#删除本地分支&#34;&gt;#&lt;/a&gt; 删除本地分支&lt;/h2&gt;
&lt;p&gt;git branch -d xxx&lt;/p&gt;
&lt;h2 id=&#34;删除远程分支&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#删除远程分支&#34;&gt;#&lt;/a&gt; 删除远程分支&lt;/h2&gt;
&lt;p&gt;git push origin -d xxx&lt;/p&gt;
&lt;h2 id=&#34;查看所有分支&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#查看所有分支&#34;&gt;#&lt;/a&gt; 查看所有分支&lt;/h2&gt;
&lt;p&gt;git branch -a&lt;/p&gt;
&lt;h2 id=&#34;重命名当前分支名称&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#重命名当前分支名称&#34;&gt;#&lt;/a&gt; 重命名当前分支名称&lt;/h2&gt;
&lt;p&gt;git branch -m new_branch&lt;/p&gt;
&lt;h2 id=&#34;重命名指定分支名称&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#重命名指定分支名称&#34;&gt;#&lt;/a&gt; 重命名指定分支名称&lt;/h2&gt;
&lt;p&gt;git branch -m old_branch new_branch&lt;/p&gt;
&lt;h2 id=&#34;修改最近一次-commit-信息&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#修改最近一次-commit-信息&#34;&gt;#&lt;/a&gt; 修改最近一次 commit 信息&lt;/h2&gt;
&lt;p&gt;git commit --amend&lt;br /&gt;
 按 i 进入编辑模式&lt;br /&gt;
修改完成后，按 Esc 退出编辑模式&lt;br /&gt;
输入:wq，按回车键保存并退出&lt;br /&gt;
重新 git push 代码到远程仓库&lt;/p&gt;
&lt;h2 id=&#34;清空-commit-信息&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#清空-commit-信息&#34;&gt;#&lt;/a&gt; 清空 commit 信息&lt;/h2&gt;
&lt;p&gt;git checkout --orphan  new_branch&lt;br /&gt;
git add .&lt;br /&gt;
git commit -m &amp;quot;xxx&amp;quot;&lt;br /&gt;
git branch -D master // 删除 master 分支&lt;br /&gt;
 git branch -m master // 修改当前分支名称为 master&lt;/p&gt;
&lt;h2 id=&#34;删除本地项目的远程仓库连接&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#删除本地项目的远程仓库连接&#34;&gt;#&lt;/a&gt; 删除本地项目的远程仓库连接&lt;/h2&gt;
&lt;p&gt;git remote rm origin&lt;/p&gt;
&lt;h2 id=&#34;查看当前远程仓库&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#查看当前远程仓库&#34;&gt;#&lt;/a&gt; 查看当前远程仓库&lt;/h2&gt;
&lt;p&gt;git remote -v&lt;/p&gt;
&lt;h2 id=&#34;新项目第一次与远程仓库建立连接&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#新项目第一次与远程仓库建立连接&#34;&gt;#&lt;/a&gt; 新项目第一次与远程仓库建立连接&lt;/h2&gt;
&lt;p&gt;git remote add origin &lt;span class=&#34;exturl&#34; data-url=&#34;bWFpbHRvOmdpdEBnaXRodWIuY29t&#34;&gt;git@github.com&lt;/span&gt;:leexiang59/l-helpers.git&lt;br /&gt;
git push -u origin master&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="Git" scheme="https://jdjwzx233.cn/categories/Git/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="教程" scheme="https://jdjwzx233.cn/tags/%E6%95%99%E7%A8%8B/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="Git" scheme="https://jdjwzx233.cn/tags/Git/" />
        <updated>2022-08-02T22:13:37.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/07/29/%E8%81%94%E6%83%B3%E5%B0%8F%E6%96%B0%E4%B8%BA%E7%A1%AC%E4%BB%B6%E4%BF%9D%E7%95%992G%E5%86%85%E5%AD%98%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%B3%95/</id>
        <title>联想小新为硬件保留2G内存的解决方法</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/07/29/%E8%81%94%E6%83%B3%E5%B0%8F%E6%96%B0%E4%B8%BA%E7%A1%AC%E4%BB%B6%E4%BF%9D%E7%95%992G%E5%86%85%E5%AD%98%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%B3%95/"/>
        <content type="html">&lt;h1 id=&#34;联想小新为硬件保留2g内存的解决方法&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#联想小新为硬件保留2g内存的解决方法&#34;&gt;#&lt;/a&gt; 联想小新为硬件保留 2G 内存的解决方法&lt;/h1&gt;
&lt;p&gt;如下图，我们可以看到，系统为硬件保留了 2.1G 内存，实际可用内存减小&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/30/852d4683ffa44b4d88c40983ec224e8e_888d00b6a16a5d798dc962771fc34303.png&#34; alt=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/30/852d4683ffa44b4d88c40983ec224e8e_888d00b6a16a5d798dc962771fc34303.png&#34; /&gt;&lt;/p&gt;
&lt;p&gt;在任务管理器中查看 GPU 的占用可以看到，保留内存是被核心显卡共享走了，你电脑的集显需要显存，而他自带的集显是没有显存的，所以会使用你的内存来当显存。这就是为什么会出现为硬件保留 2G 多的原因。&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/30/6b493dd1d9eb41c7801cabdd73d29a2a_6c44c16d08f4df59c9eee04c7ec95fbc.png&#34; alt=&#34;https://images.jdjwzx233.cn/upload/Qexo/2023/6/30/6b493dd1d9eb41c7801cabdd73d29a2a_6c44c16d08f4df59c9eee04c7ec95fbc.png&#34; /&gt;&lt;/p&gt;
&lt;h2 id=&#34;方法一&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法一&#34;&gt;#&lt;/a&gt; 方法一:&lt;/h2&gt;
&lt;p&gt;我们可以将电脑重启，狂按 F2 进入 BOIS (其他品牌的自行百度)&lt;/p&gt;
&lt;p&gt;&lt;em&gt;默认是英文，如果看不懂可以先调成中文再继续&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;找到系统设置 -&amp;gt; 共享显存&lt;/p&gt;
&lt;p&gt;然后可以根据自己的需求更改共享显存大小&lt;/p&gt;
&lt;h2 id=&#34;方法二&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法二&#34;&gt;#&lt;/a&gt; 方法二:&lt;/h2&gt;
&lt;p&gt;如果你的电脑有独显的话，可以将显卡切换为独显，独显自身有专用内存，一般不会占用电脑的内存，如果可以的话，可以自行百度，将显卡切换为独显，集显就别管它了。&lt;/p&gt;
&lt;h2 id=&#34;方法三部分设备不行&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#方法三部分设备不行&#34;&gt;#&lt;/a&gt; 方法三 (部分设备不行):&lt;/h2&gt;
&lt;p&gt;win+r 打开 msconfig 高级选项 最大内存勾上 点确定应用后重启 开机再到这个位置，勾选然后出现数字后再取消勾选（这时里面有灰色数字里面的数字不用更改），点确定应用。&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="Windows" scheme="https://jdjwzx233.cn/categories/Windows/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="Windows" scheme="https://jdjwzx233.cn/tags/Windows/" />
        <category term="联想" scheme="https://jdjwzx233.cn/tags/%E8%81%94%E6%83%B3/" />
        <category term="笔记本" scheme="https://jdjwzx233.cn/tags/%E7%AC%94%E8%AE%B0%E6%9C%AC/" />
        <category term="小新" scheme="https://jdjwzx233.cn/tags/%E5%B0%8F%E6%96%B0/" />
        <category term="内存" scheme="https://jdjwzx233.cn/tags/%E5%86%85%E5%AD%98/" />
        <updated>2022-07-29T15:39:02.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/07/21/%E5%8D%9A%E5%AE%A2%E6%89%A9%E5%B1%95%E5%8A%9F%E8%83%BD/</id>
        <title>博客扩展功能</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/07/21/%E5%8D%9A%E5%AE%A2%E6%89%A9%E5%B1%95%E5%8A%9F%E8%83%BD/"/>
        <content type="html">&lt;p&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9zaG9rYS5sb3N0eXUubWUvY29tcHV0ZXItc2NpZW5jZS9ub3RlL3RoZW1lLXNob2thLWRvYy9zcGVjaWFsLw==&#34;&gt;想看原文请点我！&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;img data-src=&#34;/image/other/21-7-2022_13058_shoka.lostyu.me.jpeg&#34; alt=&#34;21-7-2022_13058_shoka.lostyu.me.jpeg&#34; /&gt;&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="教程" scheme="https://jdjwzx233.cn/tags/%E6%95%99%E7%A8%8B/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <updated>2022-07-21T14:32:57.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/07/21/%E6%B5%8B%E8%AF%952/</id>
        <title>VS2022 VC++程序如何生成安装程序</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/07/21/%E6%B5%8B%E8%AF%952/"/>
        <content type="html">&lt;div class=&#34;hbe hbe-container&#34; id=&#34;hexo-blog-encrypt&#34; data-wpm=&#34;抱歉, 这个密码看着不太对, 请再试试.&#34; data-whm=&#34;抱歉, 这个文章不能被校验, 不过您还是能看看解密后的内容.&#34;&gt;
  &lt;script id=&#34;hbeData&#34; type=&#34;hbeData&#34; data-hmacdigest=&#34;cb611f57611848108754dcf4986ea21a79c0d4154e8779ed658163a9fbef3d69&#34;&gt;3537d6572f3f0fd5c50ac184a2626861a3cba29c48961332d79e0a844d6ae77dab5195ae09dbf1f6f99213f682ef162fb2ed79c27f8957824e60b871e5072f7ef5df518a665e82ecf207c72a11b92b6fc18370063491488e762a5309ece0cd60fbe2eed2c1dbcc97899419a130f8fb4a3305381147aa806dffc3953b5d73610d00cc2aaa611217e7449448e047c0a3e178a766be4f7426b7b807a2840bcabb260a865274845280b4878ae43a59801578ef2eb45f42f684bdd53cb968305ea36355af14fa668291d56b192f70718bdb6c685a7b0a8f2fa53922f45d82025e4556cda95ec7647c002e6cea33dd53c2aaa3ec82843e409ab886eea3f4559391f1fd4fa086fa660ac28ca9df3c7777840eef398044f8dd01c1d39c3c1f980eb9a6b93b67e11a88f7d9b88d58c530bd7ab417e5ffe20af96fd76408934a7abf7df8c6e555fe2e793a80c980211a22779a32bf5fe2b9fb3cb1d8bedf264b6c7b29adbdc1214043a84f3c3439199b541d1b67f896cf5ff92090fee543d8dc3291f8c1767f4a54eb2a73cfbe37b5aac08e4f744912e66ffb37539d35d43ad4554829a47cf1238840718676fcb3699ff8d8926d58f353399f4af59728e9397972ad4e85b998cbabf4118d6ce3de3bdd73272e235fe83227e5a14d8bdb97ec9af180c7db24de0e9f152dece449458acafb34e4cf3c55c5fa6f9e0638b4c397ab22a52da9283da71144efafd7015ba6ea70e641c225c25ac8851dfd561a70cae95877c42593ca8cab615a65bff9adfbae36f8da17463005dec0865dae51d35ea6bfad79da02fc144bf187578c02a211833fddc14f595fd926afbc923ad42c1938c3903380212a5f11702afb1bcad814fe946cb9df232a5ae9b2e56fa2573e033390ebd4b6f0b7d3770834db57f6986528c18ca5c95b9e9dfecc328860f94cd47d2c21a048193aecceafe93a1053b846342f429fb5b89e0f9ceedd686f72e80d150fd6e3f336129c75f6076878f71444db8f33f04b851e691a7472fec94fa05ec1a17f9c8c5d92c823dabb84ed9ccd07a66f5e19cf059a32eb52490bf4152da27ff6ff0ee7b8036dc68ce159315cdbf8949790626ff05f973c1d400882ff734095b435e85cdc8fa1c18439fd314fcad54bc1fcfba0ed8d5bf7dd2e5eb47d4b467e6316037bc5141629cd16530530f1aebf05e9f0ccbb0728c3b74ada3a32fd9989a9a2419955ddd03e0147428f3b7a963229bead7f6175f9545304063c1668dd91ce8886d0ba3011a6b20392ac5d7b746afdc00e5b72b4f37b13916537f1865e7651af63f5fc7630aafa785617494b86d4c317c0d51da27785c4bff29904bd806ce46cb44747e37c1acb4d5bb9fe49c278d223b57d1101c199c9ee52319ea19156f1ee9e179a0a1485c839009ed186efa30b685acbf5fb8c08a84fe1e2a7cb25b299252885655d4d79f430decdd3a6b91f515d8fcf7f4becf9a1ff629f4a0bae4209e3ceb2d6d50fc23b16ceda12b5c51f725bc6da9fae2d693fcd8721b89612e21d5b5bb391c2bf630b8ee7a20744e3c7fc6d4a7c5c0f7b9b41c7aa42a49a6e3dd90633f0e59448940f888b1f209c641e506f7591c0935bc1486ad8d60a6f91904430f76611a0b4759bc249f340e8511cda223c046a251890b83874f7770defbdfdca5377a076d77d799ae970c39d3e504c044ce43d14620aee30ab498c0a9499d010a3921ecf981b6901f245410ababad84ff119d6eca3da394dd2fedeecfff6434dbfcf3ab349a4589bf7724bde97ae230daa8aba9ba5d2426913bc4a858881c3d3b321df937fa32611433b798782d229cff02e71320093c39a3618ba8fae22a4d791ba093891baffedab6013550619dde61f5c34fa5e7c9ceb003ec5790a2f415918008af77adcc83eecb0097a43fd42398a32b5acac5335c476c5e0747c025700131166414b6af6bd1eba92a0c3390146d11fc4373d619e6a3149515490afa170748a9b52022bd85a8b4b332a35d75185d656c83360340b769121221e093691a6f96fc64ef3724906d5a668d1627b8d840f9ec24140b54d6ccf5c6d0ffa4021b24320a86cf8f714e873cfbed04ebd13cf5e56904d8de2a9f6ec1dceb3ba878cd4c8e1410214f5c4311b78f281a6ac17116ab6e77be484194d7b62cdd9a56893119f11ac7201c5cd60e4167d11f5252e94ae18cd7b91134be659620f3c04b62b0e674d77ed69479342f7f664fb36a91a97a5ebe306968dd459b6b3bba9b0f530dd16ccb8b13893974ec9f5a1a6d725e28d4cc6d161a4387e2c5fbcc96b9291c0f1593268217c4feb13641eff40c390dce1d3a22ebc0cddd8ada1c1470fc9ff686768921edfe0c32f19d5aa0959cfc8ea32710bf6cbddb0151489f2b580bdc62a1bf8b8125be10a6614483be4bbad543fbaca69cc21bb86079df2b60608df5badcf95cb6fb093ff89d11f34d93475dd87a1c2c7540e3a603698e3b547dd2255fb5ec4fb84733c0a15fd3b5f350acc97aea88d963b648e54720cb73fc898b2171fd864d9e925081f7dff5dd96c77390edda003fba06b16fdc843f7ddc520f448b6369b3e8cd1619cc556f2a176aa78b2c7cdbbc1aa7f1718f2cc25ff8f026f7a424665ea6cc60e7a45839a2c3eb20d30813c0125ee06a744c9e87b44214c3c7ef71634bb5e7a70f3a6913b659eb71b390a24b15655ab314f909aa90f8f413f4bb7ef70d9ac3767459bb3205009691fe17abd809b91cb211ad6dbc217dd11d34093726e0345fe53def625d035ad86a58c13efa852da7cbc552dbe0de2e76f4a6fed3e9b0dffdabea90e467fd1fc8e4dc76cddc10106093375ed48db79f5d4420a518823c6b419c78be4fe7ecb75b0a92b8cc289549db7a921c3c217ac1a8eeb707455ca3d95abe2c47b01772735b51108ed466cc0fb1b49a50375d73bc0c82991363b81bf577942203cf4686dbd53e6075444ec1a640fe3d84b25a435cf641cdfdadd75b0887466d344034712e5a301ec767495f45f5223bc13a78b9f58bff5b8f950167a987b31910a9c69ef0168075074cb1667fab7d34a1543bcaff448883a45c37aea25dece520b95d00e68e5f0bf4ce6e3c365ecea2d7a5a876ddfdded12c67b955baa3fa5d261afa70654bdbc54852a54975aa2ac347b2edeb4550ca82576bb8747288d8ebafe5394ffa8002cd9594ad85eb676ef1eb8e663ab120ebbf190885c581c6286cb108827ec1e5de8a463656b03d4929931ec6e8572f15dca0cfffcf35a173c678473dce34735e7b2b68376c3dbc2a0eb476164792b8dfe7eafb14c545462b835f33f335c4c48b0710e99437cd1da0fc522d63689597b62725d8c2ac589a576028a0a680cff276ad3f6a85d2b693970882f7f53dd9ff15cfc8d97293ef226982c8c34079c94a0ba6addf17a24b17d96308abd5191798c33acdec7b9ef21c3a511defa9c3805594f0d305034c4b157560880b9ffb679590c992771e4fb0cb91089e17160b8089e836a0bb074fc38bff37e0397eb12d4e3bdae6505b863fa2e727f1bc645f59edb65edec72d2fff7a855f0f8be611b16477943fdcbac89d14204841f8f7b95a900490d93f7ab1507363830100a842f2c8e938ec679356541c5408b925f080a5b9a1e9032b17f58bd18fc59653e1a92d24a81f62f2a60b927d29271db00c7a0c604f45cc23200e78f86f090c98ecf436ee26c89cd98746e624d6c982bb6a0bbf760d72ff37256a5bebe61f4ab08371771001aa701c8c5084e50fa127c5886bb7a49b0394f131b64e5b4784a974f8109276f2aa13a0269185eff02c74b9bbc5e75f8f79ae6e5f0e163c7b9191c69b3c2fc64f3e395299b71d7bc0f54ef125735ba4b9109563cc4405e49f9051b97a349d6569bc8879f314b4df9a8383c5475b57498e37636267b3d393d1a85a479b0249ffcd36b33f3e86f8db34fe0c3ac7833b1fcd807b84e2efa28905892e838f693b861ba5054782c3673d22c4f71f594ab633a14bfe54f75dab333c747523bbaf66df0a791e438c538914e443e9bb9bcc61518ebfa25a83ba93a6ab88fb8480b6c94e7323b6847be5acd672255e32c5d01f3daf7526a3f803d8c9a4c223ee441c62daf05562a277bb086e7193f12d4b75ec947734cb9f5b34d178f17be154bf3d032080767e1dff337db1745c22bc6cd0a01f136b613e5583771df5b97c7e92aa23c05122126671e36c3407f1d9c07396926a9ab9c4edfb649041aefdda780d0c7bd0ea57b9341102bac3fe7a4c7f18f03155108d2d6f536b789b8ae714453f1ece2e2bf40a4c7f0eaf4200c115084675de3344f9cfc6b2b9e8958e93fc03a4a7a65ed23616e8a158e5af45ac08a49cd5e721724ba0a6764df240392ab00ab276d38a18efdcc6c0fea781352334b854bbf4412c9184ea9eb2d120001d53d6a8d15f60852c5db5cc36fc2baf37275e26d1fa9639c9adb93461de07931cda741275caacf224f5a2a4c49364526a601fd8ee3326b2c91cff96f053d76e238120458a59bdd9869d1fec9584bb22c62eebee28a1bae47a92afc35ec2f9f24fb30ea4e1327b3912ea33424b9c827702abd08dcc8a7f861d1d7d47979bab1127bde4791ba9eba1a6dfd7d6219e3e8300d471398dc21590c3e357d674e33f523ddc471a7623273323b96ce8ed8162a2e5468c18e2744d1f21180e1650a202960faefb86df250356051b5e1b6db401bc779ad23bb58037e14e1b57eb556f4503351863532ed06eb6aedbdb8d3c0ea7979c815a2038cda90ff8fc4414d22665c99ede9747dce8821ef0b3355883ffaef89992d84f3b70d9ad53b7d92990aa39b0c75f6e2dc44ff7c82ecb8532ed9aeca5cd0f504a431ea0c406f859f6ff8ed6ec68dc0d754174e1cd3044c3743b0357bae4f41b8e5e6cde7ed6b5ea6f7a5cf6e98c166797bde9f4e536c64e234251ebbe9db1a117791f510b12523fd68c7ac4ab9a9d721090a3759d7eb3bf38ecb7435398b9d68cf53d554f5ae76abf85488d2471c4a601e52ba2c79d5e6c5e2187c26e8f0bda1df0113119afa4c4931ee565a47913a6530c8c0f010e043694ac6656e7ed2297af571cb58692596f49e28c6da647c553bd5d17c3cc857b6b77ef7731ec95e0cfd471cf6f4ccec7ee469f9a31760610c472958fb27a93beda3a78ecc3881429803bacefe9ff40f121c1b92ca061d2eba6c646bcc457fce4790bde0856935579b4d9a9a9809bbc91d6748afff7f142c1708776245db7ee5c57297c8a543dad66c2f79f5cc6412cb3615e78f126c937d632ef4261de6577c50a5b2a40194390b637f17c602580ca9ec027975de296b6b81b212a0813dc6507bba88257645ae523e68cfb741c5b8702cfde9ef2bc9e39eb77223bed92959ca833b2d5c60c480d25b97324d7c1eb6061d2fe95dd96cacb7f9faa21bea6971f5127c0cd6f0e685e22e69b564029d45ab7c60af777277d88862919c70e350e4d0b1591590a95af04b879e77f2855f779f42f137418d67324d938979f4b2f1054e2c135a549ea614992154c08d04e0203951bfa8ae3ff281b5064b8f191a2f6522a773bd2fb4d0545c8b148886b7281b30547c1978516341851d7d182f04179a5f32e05a258cfc553251c9aa2e5c2df14a3eea67f9120fe32cc053d95785c10ca1ffbb5b94e7796e2552bcc21bf8e6ca645ac0095ed37eac89420522b6cf8a7b801c4d366a1f200afbe5e7c11088cc85136596d512fc2492f84bab2238266fac0623ad8b40527f68030b01fd0fdb4c06f28dd1aa2cf0254e2b6a3ac75460b30707207044ddcac69cea129b3a7e211d656b56b248b7bc7922e31c620581761306b0c5829e7def3e994a5dbb9a0ea912a21c9e01b8566e3c9029b959a7c625a0568a9965a02e7c1b2704a4d6e0e633b8fd0400a3104b1ef7c9a4e88e602630d75003c412a7c7430dfe9146da02b1cdd84cf40764b9594062772a4ff6e4a7ee8f2c9306fc57255e4c5449e5bd3f502fb4f18299ee20bc03a9664f8f4d0da8600086d9eebe2f2d97abc810532396f63bb0f8816a2d09f28be2dc9afb575fe30e891ae13b414efa2acb6965299dafaa015186271885ba1ac3a15f8a92a024006bc8cec227e21251f534e23d5e2fee84ecf67fbc0fea1686833765f6064861b122046bf9d34c1c7ca610d3a829822aaa331796d0191c4020b3d3a70bfc69409d9a9678da75384f7a40d50d3628c61fbfbdc7688c0852ef3921d824d1e7e5b37bf241a75fe1a0f5f34ac6f68d010564ea22b2cf5b2cac2aa92ae52320c7d1e97ca69da86dd7ec2505daaf49964aed2b0a25a4977ea0fdc91de51271b52c5583657cf5f188ec62e241100f93d6ba3fd52d280e9d37e1cc5bea24bce7cb5f919fd980728dc8c34c2aa0306c053f91f42d33ab8ed23eb891943b75943fcb7fca7d4cd952fda38a682ccf03a8878c8e6d064c6948743093ccea974d0dbad6c196af05dac0336aed477afe484d03e19a1590785ddeef1057e8d564664d8781da54d8e302f970745d4f5705a00bbfd990c04c46f3201efd6f2b879185cde0ebc753dedf78c93cddf25c4925c7c67c3a21423e0aeaecafd2beb19b1678db30420c4d5f75550dce58ddfb129e473c591a198c5042736be92685f2e83f1649eb2288ba8a9bb7c60db26f366fca1efbaa53ed8b99588983b2b3d07132319f5dbafd7af052e812a4a9a979b32e1b246b974cd002699536bc9474cab8eb5df6dc3d0e11cd77acc5af6fbc40d71dbab7e126b76c99b59c8091fa5b67cf5d77e6992d07f52b41ac47f19d339b4d56f82c039b9a1f36d569cbeeba0859e2e395e65401be15e0ecf29f39f6366801f5d528034ae20db402f902fd5a792e57e98314f7f7f620e61394ddc4391619161ea4078e201fce66b9f66446b002887326cb6f36d22e055f4765a4ffd9dedf13a22a6ea0&lt;/script&gt;
  &lt;div class=&#34;hbe hbe-content&#34;&gt;
    &lt;div class=&#34;hbe hbe-input hbe-input-wave&#34;&gt;
      &lt;input class=&#34;hbe hbe-input-field hbe-input-field-wave&#34; type=&#34;password&#34; id=&#34;hbePass&#34;&gt;
      &lt;label class=&#34;hbe hbe-input-label hbe-input-label-wave&#34; for=&#34;hbePass&#34;&gt;
        &lt;span class=&#34;hbe hbe-input-label-content hbe-input-label-content-wave&#34;&gt;您好, 这里需要密码.&lt;/span&gt;
      &lt;/label&gt;
      &lt;svg class=&#34;hbe hbe-graphic hbe-graphic-wave&#34; width=&#34;300%&#34; height=&#34;100%&#34; viewBox=&#34;0 0 1200 60&#34; preserveAspectRatio=&#34;none&#34;&gt;
        &lt;path d=&#34;M0,56.5c0,0,298.666,0,399.333,0C448.336,56.5,513.994,46,597,46c77.327,0,135,10.5,200.999,10.5c95.996,0,402.001,0,402.001,0&#34;&gt;&lt;/path&gt;
      &lt;/svg&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;script data-pjax src=&#34;/lib/hbe.js&#34;&gt;&lt;/script&gt;&lt;link href=&#34;/css/hbe.style.css&#34; rel=&#34;stylesheet&#34; type=&#34;text/css&#34;&gt;</content>
        <category term="text" scheme="https://jdjwzx233.cn/tags/text/" />
        <category term="测试" scheme="https://jdjwzx233.cn/tags/%E6%B5%8B%E8%AF%95/" />
        <category term="jdjwzx233P" scheme="https://jdjwzx233.cn/tags/jdjwzx233P/" />
        <updated>2022-07-21T10:21:46.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/07/20/Markdown%E8%B6%85%E5%85%A8%E6%95%99%E7%A8%8B/</id>
        <title>Markdown超全教程</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/07/20/Markdown%E8%B6%85%E5%85%A8%E6%95%99%E7%A8%8B/"/>
        <content type="html">&lt;p&gt;[TOC]&lt;/p&gt;
&lt;h1 id=&#34;markdowntyporavscode-超全教程-给大一新生安利的文本神器&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#markdowntyporavscode-超全教程-给大一新生安利的文本神器&#34;&gt;#&lt;/a&gt; [Markdown+Typora/VSCode 超全教程] 给大一新生安利的文本神器&lt;/h1&gt;
&lt;p&gt;Sakiyary 2022/7/16&lt;/p&gt;
&lt;h2 id=&#34;简要介绍&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#简要介绍&#34;&gt;#&lt;/a&gt; 😂 简要介绍&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;Markdown&lt;/strong&gt; 是一种轻量型标记语言，是一种语法。以  &lt;code&gt;.md&lt;/code&gt;  结尾的文本文件就是 Markdown 文件。相较于 &lt;strong&gt;Word&lt;/strong&gt;, 它更加像是 &lt;strong&gt;HTML&lt;/strong&gt; 语言或是 &lt;span class=&#34;katex&#34;&gt;&lt;span class=&#34;katex-mathml&#34;&gt;&lt;math xmlns=&#34;http://www.w3.org/1998/Math/MathML&#34;&gt;&lt;semantics&gt;&lt;mrow&gt;&lt;mtext&gt;LaTeX&lt;/mtext&gt;&lt;/mrow&gt;&lt;annotation encoding=&#34;application/x-tex&#34;&gt;\LaTeX&lt;/annotation&gt;&lt;/semantics&gt;&lt;/math&gt;&lt;/span&gt;&lt;span class=&#34;katex-html&#34; aria-hidden=&#34;true&#34;&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.89883em;vertical-align:-0.2155em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;L&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.36em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.68333em;&#34;&gt;&lt;span style=&#34;top:-2.904999em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm mtight sizing reset-size6 size3&#34;&gt;A&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.15em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.1667em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t vlist-t2&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.46782999999999997em;&#34;&gt;&lt;span style=&#34;top:-2.7845em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:3em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;E&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-s&#34;&gt;​&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.2155em;&#34;&gt;&lt;span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.125em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord textrm&#34;&gt;X&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;, 并不是最淳朴的那种 &amp;quot;所见即所得&amp;quot;. 它处处透露着一种极简主义。高效简洁清晰的同时，又很简单。看起来舒服，语法简单，尤其在处理纯文本上有很大的优势.&lt;/p&gt;
&lt;p&gt;它相较于 &lt;strong&gt;Word&lt;/strong&gt;, 兼容性非常高，可以跨平台使用，不用担心奇奇怪怪的版本兼容问题。同时，有许多网站都支持或正在使用 &lt;strong&gt;Markdown&lt;/strong&gt; 语法。如 &lt;strong&gt;Github&lt;/strong&gt; (等一系列代码托管平台), StackOverflow (等答疑平台), 简书，语雀 (等一系列笔记平台).&lt;/p&gt;
&lt;h2 id=&#34;实际应用&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#实际应用&#34;&gt;#&lt;/a&gt; 📐 实际应用&lt;/h2&gt;
&lt;p&gt;所有要写文本的时候都可以用上 &lt;strong&gt;Markdown&lt;/strong&gt;!&lt;/p&gt;
&lt;p&gt;它可以让你不再纠结什么字体，什么样式，什么排版。而且逻辑清晰，层次分明.&lt;/p&gt;
&lt;p&gt;像我大一的时候就用 Markdown 来写各种笔记，演讲稿，课程论文，实验报告，代码的  &lt;code&gt;README.md&lt;/code&gt;  ... 包括本教程文档.&lt;/p&gt;
&lt;h2 id=&#34;工具&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#工具&#34;&gt;#&lt;/a&gt; 🍴 工具&lt;/h2&gt;
&lt;p&gt;Markdown 只是一种语法。那么用来写 Markdown 的文本编辑器呢？我推荐的是 &lt;strong&gt;Typora&lt;/strong&gt; 或者 &lt;strong&gt;VS Code&lt;/strong&gt;&lt;/p&gt;
&lt;h3 id=&#34;typora&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#typora&#34;&gt;#&lt;/a&gt; Typora&lt;/h3&gt;
&lt;p&gt;Typora 应该是被广泛用于写 Markdown 的文本软件，就和 Markdown 语法一样高效。而且它还有很实用的扩展语法与自定义样式的功能。其能将  &lt;code&gt;.md&lt;/code&gt;  导出成多种文件，如  &lt;code&gt;.pdf&lt;/code&gt; ,  &lt;code&gt;.html&lt;/code&gt; ,  &lt;code&gt;.docx&lt;/code&gt;  (没想到吧，能导出到 Word)&lt;/p&gt;
&lt;p&gt;但是现在 Typora 已经发布正式版并且变为收费软件。中文官网在此 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly90eXBvcmFpby5jbi8=&#34;&gt;Typora 官方中文站 &lt;/span&gt;.&lt;/p&gt;
&lt;p&gt;我当然是推荐大家都用正版啦。不过价格是永久版￥89, 好在可以用在 3 台设备上。如果和你的两位同学 / 舍友均摊一下，每人就只要￥30, 和一张游戏月卡差不多.&lt;/p&gt;
&lt;p&gt;至于盗版以及破解方法&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cub25seTQud29yay9ibG9nLz9pZD0zNzk=&#34;&gt;在此随便找一种改注册表时间方法的&lt;/span&gt;&lt;s&gt;不介绍 (还挺多的其实)&lt;/s&gt;.&lt;/p&gt;
&lt;p&gt;&lt;s&gt;还有一种免费白嫖的方法就是安装测试版 / Beta 版。官网有历史版本的下载链接 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly90eXBvcmFpby5jbi93aW5kb3dzL2Rldl9yZWxlYXNlLmh0bWw=&#34;&gt;Typora 历史版本下载页&lt;/span&gt;&lt;/s&gt;&lt;/p&gt;
&lt;p&gt;白嫖 Beta 版已经寄了，要么支持正版要么去学习一下破解方法吧 (还是忍不住啦，看上面的链接👆)&lt;/p&gt;
&lt;h3 id=&#34;vs-code&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#vs-code&#34;&gt;#&lt;/a&gt; VS Code&lt;/h3&gt;
&lt;p&gt;这是微软家的开源文本编辑器，理论上来说所有代码，语言，都可以用 VS Code 来写，同样是非常的简洁好用。在下载插件 &lt;strong&gt;Markdown All in One&lt;/strong&gt; 后对 Markdown 的基础支持也是非常的好。若在 VS Code 下载 Markdown 各种附加扩展，就能获得比 Typora 更加丰富的扩展语法与操作.&lt;/p&gt;
&lt;h3 id=&#34;其他&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#其他&#34;&gt;#&lt;/a&gt; 其他&lt;/h3&gt;
&lt;p&gt;大部分 IDE, 像 Jetbrain 的全家桶里应该每一款，都支持 Markdown 语法，在此不多赘述.&lt;/p&gt;
&lt;p&gt;本文档主要使用 Typora 进行演示，同时会介绍许多 Typora 所包含的扩展语法.&lt;/p&gt;
&lt;h2 id=&#34;基础教程&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#基础教程&#34;&gt;#&lt;/a&gt; 🍭 基础教程&lt;/h2&gt;
&lt;p&gt;当有多种标记方法时我会倾向其中一种.&lt;/p&gt;
&lt;p&gt;标题有  &lt;code&gt;*&lt;/code&gt;  表示该为扩展语法，仅在 Typora 或 添加了扩展的 VS Code &lt;strong&gt;本地生效&lt;/strong&gt;，在大多数平台上&lt;strong&gt;并不认可&lt;/strong&gt;.&lt;/p&gt;
&lt;h3 id=&#34;0-写-markdown-的第零步&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#0-写-markdown-的第零步&#34;&gt;#&lt;/a&gt; 0. 写 Markdown 的第零步&lt;/h3&gt;
&lt;p&gt;我们写文本的时候大多写的是中文，可是输入法在输中文时使用的标点为全角标点，如  &lt;code&gt;，。？！（）【】：；“”&lt;/code&gt; . 这些标点是不被 Markdown 所认可的，也是无法转义的.&lt;/p&gt;
&lt;p&gt;我建议大家写 Markdown 的时候都用半角标点，即英文标点，如  &lt;code&gt;,.?!()[]:;&amp;quot;&amp;quot;&lt;/code&gt; . 且每个半角标点在文本使用时加上后置空格，符合英文标点的书写规范，也更加美观.&lt;/p&gt;
&lt;p&gt;以微软自带输入法举例，在使用中文输入法时按下  &lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;.(这是个句号)&lt;/code&gt; , 切换标点的全角与半角。这样即可中文输入 + 半角标点.&lt;/p&gt;
&lt;h3 id=&#34;1-标题-数个-空格-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-标题-数个-空格-前置&#34;&gt;#&lt;/a&gt; 1. 标题 [数个 &amp;quot;#&amp;quot; + 空格 前置]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;# 一级标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;## 二级标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;### 三级标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;#### 四级标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;##### 五级标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;###### 六级标题&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;标题会在目录与大纲分级显示，可以跳转.&lt;/p&gt;
&lt;p&gt;在 Typora 中建议开启  &lt;code&gt;严格模式&lt;/code&gt; ，即不应为  &lt;code&gt;#标题&lt;/code&gt; ，应为  &lt;code&gt;# 标题&lt;/code&gt; .&lt;/p&gt;
&lt;p&gt;应该要手动补上空格，使得 Markdown 语法在其他文本编辑器上兼容.&lt;/p&gt;
&lt;h3 id=&#34;2-强调-用-或-__-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2-强调-用-或-__-包围&#34;&gt;#&lt;/a&gt; 2. 强调 [用 &amp;quot;**&amp;quot; 或 &amp;quot;__&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;**欢迎报考南京大学!** (我喜欢用这种)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;__欢迎报考南京大学!__&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;或者选中想要强调的文字按下  &lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;B&lt;/code&gt; .&lt;/p&gt;
&lt;p&gt;E.G.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;欢迎报考南京大学！&lt;/strong&gt;&lt;/p&gt;
&lt;h3 id=&#34;3-斜体-用-或-_-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#3-斜体-用-或-_-包围&#34;&gt;#&lt;/a&gt; 3. 斜体 [用 &amp;quot;*&amp;quot; 或 &amp;quot;_&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;*欢迎大佬来浇浇我各种知识* (我喜欢用这种)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;_欢迎大佬来浇浇我各种知识_&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;或者选中想要强调的文字按下  &lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;I&lt;/code&gt; .&lt;/p&gt;
&lt;p&gt;E.G.&lt;/p&gt;
&lt;p&gt;&lt;em&gt;欢迎大佬来浇浇我各种知识&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;(P.S. &lt;em&gt;&lt;strong&gt;斜体并强调&lt;/strong&gt;&lt;/em&gt; [用 &amp;quot;***&amp;quot; 或 &amp;quot;___&amp;quot; 包围])&lt;/p&gt;
&lt;h3 id=&#34;4-删除线-用-~~-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#4-删除线-用-~~-包围&#34;&gt;#&lt;/a&gt; 4. 删除线 [用 &amp;quot;~~&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;~~我宣布个事儿, 我是Sabiyary!~~&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
E.G.&lt;br /&gt;
&lt;s&gt; 我宣布个事儿，我是 Sabiyary!&lt;/s&gt;&lt;/p&gt;
&lt;h3 id=&#34;5-高亮-用-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#5-高亮-用-包围&#34;&gt;#&lt;/a&gt; 5. * 高亮 [用 &amp;quot;==&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：此为扩展语法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;==我喜欢黄色, 也喜欢绿色==&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
E.G.&lt;br /&gt;
&lt;mark&gt; 我喜欢黄色，也喜欢绿色&lt;/mark&gt;&lt;/p&gt;
&lt;h3 id=&#34;6-代码-用-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#6-代码-用-包围&#34;&gt;#&lt;/a&gt; 6. 代码 [用 &amp;quot;`&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;`sudo rm -rf /*`&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
E.G.&lt;br /&gt;
 &lt;code&gt;sudo rm -rf /*&lt;/code&gt;  (没事别乱敲这个！)&lt;br /&gt;
&lt;s&gt;&amp;quot;请输入管理员密码: (闪烁的光标)&amp;quot;&lt;/s&gt;&lt;/p&gt;
&lt;h3 id=&#34;7-代码块-按三个-并敲回车&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#7-代码块-按三个-并敲回车&#34;&gt;#&lt;/a&gt; 7. 代码块 [按三个 &amp;quot;`&amp;quot; 并敲回车]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight c&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;```&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;comment&#34;&gt;// 这里就可以开始输入你要的代码了&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;meta&#34;&gt;#&lt;span class=&#34;keyword&#34;&gt;include&lt;/span&gt; &lt;span class=&#34;string&#34;&gt;&amp;lt;stdio.h&amp;gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;type&#34;&gt;int&lt;/span&gt; &lt;span class=&#34;title function_&#34;&gt;mian&lt;/span&gt;&lt;span class=&#34;params&#34;&gt;()&lt;/span&gt; &amp;#123;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;    print（“Hello, world!\n&lt;span class=&#34;string&#34;&gt;&amp;quot;）;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;    retrun O;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;&amp;#125;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;string&#34;&gt;``` // (这三个&amp;quot;&lt;/span&gt;`&lt;span class=&#34;string&#34;&gt;&amp;quot;文本编辑器会帮你自动补全 一般不用手动输)&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
(我之前都是用这个来展示各种语法的，应该不用举例了吧)&lt;br /&gt;
 要想显示行数的话，一般要在 Typora 的设置里勾上这个显示行数的选项.&lt;br /&gt;
 代码块里可以选择语言，其会根据语言来自动高亮各个语句。在选择语言后， &lt;code&gt;```&lt;/code&gt;  会变为  &lt;code&gt;````&lt;/code&gt;  +  &lt;code&gt;对应语言&lt;/code&gt; .&lt;/p&gt;
&lt;h3 id=&#34;8-引用-空格-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#8-引用-空格-前置&#34;&gt;#&lt;/a&gt; 8. 引用 [&amp;quot;&amp;gt;&amp;quot; + 空格 前置]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&amp;gt; 24岁, 是学生.&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;gt; &amp;gt; 学生特有的无处不在(恼)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 引用是可以嵌套的！&lt;br /&gt;
E.G.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;24 岁，是学生.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;学生特有的无处不在 (恼)&lt;/p&gt;
&lt;/blockquote&gt;
&lt;/blockquote&gt;
&lt;h3 id=&#34;9-无序列表-或-空格-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#9-无序列表-或-空格-前置&#34;&gt;#&lt;/a&gt; 9. 无序列表 [&amp;quot;-&amp;quot; 或  &amp;quot;+&amp;quot; + 空格 前置]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;- 一颗是枣树 (我喜欢用这种)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;+ 另一颗还是枣树&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;* (其实这种也可以, 不过由于在 Typora 中很难单个输入, 故不常用)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 三种前置符都可以，敲回车会自动补全，可在 Typora 设置中调整补全的符号，敲回车后按下  &lt;code&gt;Tab&lt;/code&gt;  会缩进一级.&lt;br /&gt;
E.G.&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;一颗是枣树&lt;/li&gt;
&lt;li&gt;另一颗还是枣树&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;10-有序列表-数字-空格-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#10-有序列表-数字-空格-前置&#34;&gt;#&lt;/a&gt; 10. 有序列表 [数字 + &amp;quot;.&amp;quot; + 空格 前置]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;我来这里就为了三件事:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;1. 公平&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2. 公平&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3. 还是tm的公平!&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 敲回车会自动补全，敲回车后按下  &lt;code&gt;Tab&lt;/code&gt;  会缩进一级.&lt;br /&gt;
E.G.&lt;br /&gt;
 我来这里就为了三件事:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;公平&lt;/li&gt;
&lt;li&gt;公平&lt;/li&gt;
&lt;li&gt;还是 tm 的公平！&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;11-上标-用-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#11-上标-用-包围&#34;&gt;#&lt;/a&gt; 11. * 上标 [用 &amp;quot;^&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：此为扩展语法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;C语言中int的上限是 2^31^ - 1 = 2147483647&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
E.G.&lt;br /&gt;
C 语言中  &lt;code&gt;int&lt;/code&gt;  的上限是 2&lt;sup&gt;31&lt;/sup&gt; - 1 = 2147483647&lt;/p&gt;
&lt;h3 id=&#34;12-下标-用-~-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#12-下标-用-~-包围&#34;&gt;#&lt;/a&gt; 12. * 下标 [用 &amp;quot;~&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：此为扩展语法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;H~2~O 是剧毒的!&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
E.G.&lt;br /&gt;
H&lt;sub&gt;2&lt;/sub&gt;O 是剧毒的！&lt;/p&gt;
&lt;h3 id=&#34;13-注释-后置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#13-注释-后置&#34;&gt;#&lt;/a&gt; 13. * 注释 [&amp;quot;[^]&amp;quot; 后置]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：此为扩展语法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&amp;gt; 今日我们相聚于此, 是为了学习 Markdown 的使用, 它的教程对于全体「观众」而言, 值得足足两个硬币的支持鼓励![^1]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;[^1]: 沃兹·基·硕德 改编自「公鸡」普契涅拉.&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 需要在文末写上注释对应的内容&lt;br /&gt;
 E.G.&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;今日我们相聚于此，是为了学习 Markdown 的使用，它的教程对于全体「观众」而言，值得足足两个硬币的支持鼓励！[^1]&lt;br /&gt;
[^1]: 沃兹・基・硕德 改编自「公鸡」普契涅拉.&lt;/p&gt;
&lt;/blockquote&gt;
&lt;h3 id=&#34;14-链接-常用-分别包围文本与链接&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#14-链接-常用-分别包围文本与链接&#34;&gt;#&lt;/a&gt; 14. 链接 [常用 &amp;quot;[]&amp;quot; + &amp;quot;( )&amp;quot; 分别包围文本与链接]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：文内跳转为扩展用法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;[来看看我贫瘠的仓库罢](https://github.com/jdjwzxAPI)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;[基础教程: 12. 下标](#12. 下标 [用 &amp;quot;~&amp;quot; 包围])&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 支持网页链接与文内跳转，按住  &lt;code&gt;Ctrl&lt;/code&gt;  并  &lt;code&gt;单击鼠标左键&lt;/code&gt;  即可跳转.&lt;br /&gt;
E.G.&lt;br /&gt;
&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRodWIuY29tL2pkand6eEFQSQ==&#34;&gt; 来看看我贫瘠的仓库罢&lt;/span&gt;&lt;br /&gt;
 [基础教程: 12. 下标](#12. 下标 [用 &amp;quot;~&amp;quot; 包围])&lt;/p&gt;
&lt;h3 id=&#34;15-任务列表-空格-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#15-任务列表-空格-前置&#34;&gt;#&lt;/a&gt; 15. 任务列表 [&amp;quot;- []&amp;quot; + 空格 前置]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;TodoList:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [ ] 刷B站&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [ ] 写代码&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [ ] 起床&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 用  &lt;code&gt;x&lt;/code&gt;  代替  &lt;code&gt;[ ]&lt;/code&gt;  中的空格来勾选任务列表。在 Typora 中可以直接用鼠标左键单击勾选框.&lt;br /&gt;
E.G. TodoList:&lt;/p&gt;
&lt;ul class=&#34;task-list&#34;&gt;
&lt;li class=&#34;task-list-item&#34;&gt;&lt;input type=&#34;checkbox&#34; id=&#34;cbx_0&#34; checked=&#34;true&#34; disabled=&#34;true&#34; /&gt;&lt;label for=&#34;cbx_0&#34;&gt; 刷 B 站&lt;/label&gt;&lt;/li&gt;
&lt;li class=&#34;task-list-item&#34;&gt;&lt;input type=&#34;checkbox&#34; id=&#34;cbx_1&#34; checked=&#34;true&#34; disabled=&#34;true&#34; /&gt;&lt;label for=&#34;cbx_1&#34;&gt; 写代码&lt;/label&gt;&lt;/li&gt;
&lt;li class=&#34;task-list-item&#34;&gt;&lt;input type=&#34;checkbox&#34; id=&#34;cbx_2&#34; checked=&#34;true&#34; disabled=&#34;true&#34; /&gt;&lt;label for=&#34;cbx_2&#34;&gt; 起床&lt;/label&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;16-表格-用-绘制表格边框&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#16-表格-用-绘制表格边框&#34;&gt;#&lt;/a&gt; 16. 表格 [用 &amp;quot;|&amp;quot; 绘制表格边框]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;| 学号 | 姓名  | 年龄 |&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;| :--- | :---: | ---: | (引号的位置代表着 左对齐, 居中, 右对齐)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;|114514|田所|24|&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;|1919810|浩三|25|&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 第一行为表头，并由第二行分割线决定对齐方式与长度，第三行及之后即表格数据&lt;br /&gt;
 E.G.&lt;/p&gt;
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th style=&#34;text-align:left&#34;&gt;学号&lt;/th&gt;
&lt;th style=&#34;text-align:center&#34;&gt;姓名&lt;/th&gt;
&lt;th style=&#34;text-align:right&#34;&gt;年龄&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:left&#34;&gt;114514&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;田所&lt;/td&gt;
&lt;td style=&#34;text-align:right&#34;&gt;24&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:left&#34;&gt;1919810&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;浩三&lt;/td&gt;
&lt;td style=&#34;text-align:right&#34;&gt;25&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;h3 id=&#34;17-图片-直接拖进来或者复制粘贴&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#17-图片-直接拖进来或者复制粘贴&#34;&gt;#&lt;/a&gt; 17. 图片 [直接拖进来或者复制粘贴]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;![图片](图片的位置)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
&lt;img data-src=&#34;https://cdn.jdjwzxapi.fun/4b90f603738da97756eb7745d18e8b1f8418e3fa.jpeg&#34; alt=&#34;欸嘿嘿.jpeg&#34; /&gt;&lt;br /&gt;
 我还是会选择拖进来或者复制粘贴啦～在 Typora 的设置里也可以改图片的储存方式.&lt;/p&gt;
&lt;h3 id=&#34;18-分割线-按三个-或-或-_-并敲回车&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#18-分割线-按三个-或-或-_-并敲回车&#34;&gt;#&lt;/a&gt; 18. 分割线 [按三个 &amp;quot;*&amp;quot; 或 &amp;quot;-&amp;quot; 或 &amp;quot;_&amp;quot; 并敲回车]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;***&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;--- (我喜欢用这种)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;___&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;// (其实按三个及以上都可以)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 由于  &lt;code&gt;*&lt;/code&gt;  与  &lt;code&gt;_&lt;/code&gt;  均会自动补全，所以我觉得  &lt;code&gt;-&lt;/code&gt;  最为方便.&lt;br /&gt;
E.G.&lt;/p&gt;
&lt;hr /&gt;
&lt;hr /&gt;
&lt;hr /&gt;
&lt;h3 id=&#34;19-emoji表情-前置&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#19-emoji表情-前置&#34;&gt;#&lt;/a&gt; 19. Emoji 表情 [&amp;quot;:&amp;quot; 前置]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：英文输入为扩展语法)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;:sweat_smile: &lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;:drooling_face:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;:clown_face:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;// (敲回车或者鼠标点击, 后置的&amp;quot;:&amp;quot;一般不需要手动输)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 这个功能唯一的要求就是英语水平要高，或者大概记得各个 Emoji 的英文名.&lt;br /&gt;
E.G.&lt;br /&gt;
😅&lt;br /&gt;
🤤&lt;br /&gt;
🤡&lt;br /&gt;
对于其余普通的 Markdown 文本编辑器，可以直接将 Emoji 表情复制进来，这是直接&lt;strong&gt;硬编码&lt;/strong&gt;的 (&lt;s&gt;刻进 DNA 里&lt;/s&gt;)&lt;br /&gt;
E.G.&lt;br /&gt;
😅🤤🤡&lt;br /&gt;
用好这个功能可以让你的文本非常的可爱！&lt;s&gt;太抽象了&lt;/s&gt;&lt;br /&gt;
这里分享一个可以复制&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9lbW9qaXBlZGlhLm9yZy9hcHBsZS8=&#34;&gt;全 Emoji 的网站&lt;/span&gt;，非常好用！我之前的 C 语言大作业也是从这里下载的资源！&lt;/p&gt;
&lt;h2 id=&#34;进阶教程&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#进阶教程&#34;&gt;#&lt;/a&gt; 🔥 进阶教程&lt;/h2&gt;
&lt;h3 id=&#34;1-目录-自动生成&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#1-目录-自动生成&#34;&gt;#&lt;/a&gt; 1. 目录 [自动生成]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;[TOC] (此为 Typora 特有的, 如本文档开头)&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 若使用 VS Code 搭配 Markdown All in One 扩展，可在 VS Code 的 &lt;code&gt;命令面板&lt;/code&gt;  (即 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb2RlLnZpc3VhbHN0dWRpby5jb20vZG9jcy9nZXRzdGFydGVkL3VzZXJpbnRlcmZhY2UjX2NvbW1hbmQtcGFsZXR0ZQ==&#34;&gt;VS Code Command Palette&lt;/span&gt;) 输入  &lt;code&gt;Create Table of Contents&lt;/code&gt;  自动生成目录，且可在扩展设置中细调目录参数.&lt;/p&gt;
&lt;h3 id=&#34;2-内联-html-代码-用-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#2-内联-html-代码-用-包围&#34;&gt;#&lt;/a&gt; 2. 内联 HTML 代码 [用 &amp;quot;&amp;lt;&amp;gt; &amp;lt;/&amp;gt;&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;&amp;lt;div style=&amp;quot;text-align:center&amp;quot;&amp;gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;  &amp;lt;font style=&amp;quot;color:red&amp;quot;&amp;gt;我不会 HTML 呜呜呜... 浇浇我&amp;lt;/font&amp;gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;lt;center&amp;gt;简单的文字居中也可以这样&amp;lt;/center&amp;gt;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;lt;u&amp;gt;我差点忘了还有下划线这东西...&amp;lt;/u&amp;gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 只要你会写，你完全可以把 Markdown 当作 &lt;strong&gt;HTML&lt;/strong&gt; 来写.&lt;br /&gt;
 同时， &lt;code&gt;.md&lt;/code&gt;  文件可以直接导出成一个网页.&lt;br /&gt;
 下划线可以选中想要下划的文字按下  &lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;U&lt;/code&gt; .&lt;br /&gt;
E.G.&lt;br /&gt;
&amp;lt;div style=&amp;quot;text-align:center&amp;quot;&amp;gt;&lt;br /&gt;
&amp;lt;font style=&amp;quot;color:red&amp;quot;&amp;gt; 我不会 HTML 呜呜呜... 浇浇我 &amp;lt;/font&amp;gt;&lt;br /&gt;
&amp;lt;/div&amp;gt;&lt;br /&gt;
&amp;lt;center&amp;gt; 简单的文字居中也可以这样 &amp;lt;/center&amp;gt;&lt;br /&gt;
&amp;lt;u&amp;gt; 我差点忘了还有下划线这东西...&amp;lt;/u&amp;gt;&lt;/p&gt;
&lt;h3 id=&#34;3-内联-latex-公式-用-包围&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#3-内联-latex-公式-用-包围&#34;&gt;#&lt;/a&gt; 3. 内联 &lt;span class=&#34;katex&#34;&gt;&lt;span class=&#34;katex-mathml&#34;&gt;&lt;math xmlns=&#34;http://www.w3.org/1998/Math/MathML&#34;&gt;&lt;semantics&gt;&lt;mrow&gt;&lt;mtext&gt;LaTeX&lt;/mtext&gt;&lt;/mrow&gt;&lt;annotation encoding=&#34;application/x-tex&#34;&gt;\LaTeX&lt;/annotation&gt;&lt;/semantics&gt;&lt;/math&gt;&lt;/span&gt;&lt;span class=&#34;katex-html&#34; aria-hidden=&#34;true&#34;&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.89883em;vertical-align:-0.2155em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;L&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.36em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.68333em;&#34;&gt;&lt;span style=&#34;top:-2.904999em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm mtight sizing reset-size6 size3&#34;&gt;A&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.15em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.1667em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t vlist-t2&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.46782999999999997em;&#34;&gt;&lt;span style=&#34;top:-2.7845em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:3em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;E&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-s&#34;&gt;​&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.2155em;&#34;&gt;&lt;span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.125em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord textrm&#34;&gt;X&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt; 公式 [用 &amp;quot;$&amp;quot; 包围]&lt;/h3&gt;
&lt;p&gt;&lt;strong&gt;(注意：部分编译器会不识别部分符号)&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;13&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;14&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;$\LaTeX$ 是最好用的论文排版语言! 不信你看!&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;$a^n+b^n=c^n$&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;$$&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;%\usepackage&amp;#123;unicode-math&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\displaystyle \ointctrclockwise\mathcal&amp;#123;D&amp;#125;[x(t)]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\sqrt&amp;#123;\frac&amp;#123;\displaystyle3\uppi^2-\sum_&amp;#123;q=0&amp;#125;^&amp;#123;\infty&amp;#125;(z+\hat L)^&amp;#123;q&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\exp(\symrm&amp;#123;i&amp;#125;q^2 \hbar x)&amp;#125;&amp;#123;\displaystyle (\symsfup&amp;#123;Tr&amp;#125;\symbfcal&amp;#123;A&amp;#125;)&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\left(\symbf\Lambda_&amp;#123;j_1j_2&amp;#125;^&amp;#123;i_1i_2&amp;#125;\Gamma_&amp;#123;i_1i_2&amp;#125;^&amp;#123;j_1j_2&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\hookrightarrow\vec D\cdot \symbf P \right)&amp;#125;&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;=\underbrace&amp;#123;\widetilde&amp;#123;\left\langle \frac&amp;#123;\notin \emptyset&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;&amp;#123;\varpi\alpha_&amp;#123;k\uparrow&amp;#125;&amp;#125;\middle\vert&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\frac&amp;#123;\partial_\mu T_&amp;#123;\mu\nu&amp;#125;&amp;#125;&amp;#123;2&amp;#125;\right\rangle&amp;#125;&amp;#125;_&amp;#123;\mathrm&amp;#123;K&amp;#125;_3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;\mathrm&amp;#123;Fe&amp;#125;(\mathrm&amp;#123;CN&amp;#125;)_6&amp;#125; ,\forall z \in \mathbb&amp;#123;R&amp;#125;&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;$$&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
 用  &lt;code&gt;$&lt;/code&gt;  包围为单条公式，按下两个  &lt;code&gt;$&lt;/code&gt;  并敲回车即生成公式块.&lt;br /&gt;
E.G.&lt;br /&gt;
&lt;span class=&#34;katex&#34;&gt;&lt;span class=&#34;katex-mathml&#34;&gt;&lt;math xmlns=&#34;http://www.w3.org/1998/Math/MathML&#34;&gt;&lt;semantics&gt;&lt;mrow&gt;&lt;mtext&gt;LaTeX&lt;/mtext&gt;&lt;/mrow&gt;&lt;annotation encoding=&#34;application/x-tex&#34;&gt;\LaTeX&lt;/annotation&gt;&lt;/semantics&gt;&lt;/math&gt;&lt;/span&gt;&lt;span class=&#34;katex-html&#34; aria-hidden=&#34;true&#34;&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.89883em;vertical-align:-0.2155em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;L&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.36em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.68333em;&#34;&gt;&lt;span style=&#34;top:-2.904999em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm mtight sizing reset-size6 size3&#34;&gt;A&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.15em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.1667em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t vlist-t2&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.46782999999999997em;&#34;&gt;&lt;span style=&#34;top:-2.7845em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:3em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;E&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-s&#34;&gt;​&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.2155em;&#34;&gt;&lt;span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.125em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord textrm&#34;&gt;X&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt; 是最好用的论文排版语言！不信你看！&lt;br /&gt;
&lt;span class=&#34;katex&#34;&gt;&lt;span class=&#34;katex-mathml&#34;&gt;&lt;math xmlns=&#34;http://www.w3.org/1998/Math/MathML&#34;&gt;&lt;semantics&gt;&lt;mrow&gt;&lt;msup&gt;&lt;mi&gt;a&lt;/mi&gt;&lt;mi&gt;n&lt;/mi&gt;&lt;/msup&gt;&lt;mo&gt;+&lt;/mo&gt;&lt;msup&gt;&lt;mi&gt;b&lt;/mi&gt;&lt;mi&gt;n&lt;/mi&gt;&lt;/msup&gt;&lt;mo&gt;=&lt;/mo&gt;&lt;msup&gt;&lt;mi&gt;c&lt;/mi&gt;&lt;mi&gt;n&lt;/mi&gt;&lt;/msup&gt;&lt;/mrow&gt;&lt;annotation encoding=&#34;application/x-tex&#34;&gt;a^n+b^n=c^n&lt;/annotation&gt;&lt;/semantics&gt;&lt;/math&gt;&lt;/span&gt;&lt;span class=&#34;katex-html&#34; aria-hidden=&#34;true&#34;&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.747722em;vertical-align:-0.08333em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord mathnormal&#34;&gt;a&lt;/span&gt;&lt;span class=&#34;msupsub&#34;&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.664392em;&#34;&gt;&lt;span style=&#34;top:-3.063em;margin-right:0.05em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;sizing reset-size6 size3 mtight&#34;&gt;&lt;span class=&#34;mord mathnormal mtight&#34;&gt;n&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:0.2222222222222222em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mbin&#34;&gt;+&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:0.2222222222222222em;&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.69444em;vertical-align:0em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord mathnormal&#34;&gt;b&lt;/span&gt;&lt;span class=&#34;msupsub&#34;&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.664392em;&#34;&gt;&lt;span style=&#34;top:-3.063em;margin-right:0.05em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;sizing reset-size6 size3 mtight&#34;&gt;&lt;span class=&#34;mord mathnormal mtight&#34;&gt;n&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:0.2777777777777778em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mrel&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:0.2777777777777778em;&#34;&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.664392em;vertical-align:0em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord mathnormal&#34;&gt;c&lt;/span&gt;&lt;span class=&#34;msupsub&#34;&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.664392em;&#34;&gt;&lt;span style=&#34;top:-3.063em;margin-right:0.05em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;sizing reset-size6 size3 mtight&#34;&gt;&lt;span class=&#34;mord mathnormal mtight&#34;&gt;n&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
%\usepackage{unicode-math}
\displaystyle \ointctrclockwise\mathcal{D}[x(t)]
\sqrt{\frac{\displaystyle3\uppi^2-\sum_{q=0}^{\infty}(z+\hat L)^{q}
\exp(\symrm{i}q^2 \hbar x)}{\displaystyle (\symsfup{Tr}\symbfcal{A})
\left(\symbf\Lambda_{j_1j_2}^{i_1i_2}\Gamma_{i_1i_2}^{j_1j_2}
\hookrightarrow\vec D\cdot \symbf P \right)}}
=\underbrace{\widetilde{\left\langle \frac{\notin \emptyset}
{\varpi\alpha_{k\uparrow}}\middle\vert
\frac{\partial_\mu T_{\mu\nu}}{2}\right\rangle}}_{\mathrm{K}_3
\mathrm{Fe}(\mathrm{CN})_6} ,\forall z \in \mathbb{R}

&lt;h3 id=&#34;4-网络图床&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#4-网络图床&#34;&gt;#&lt;/a&gt; 4. * 网络图床&lt;/h3&gt;
&lt;p&gt;(这是学长给我的网络图床教程，我并未实践过...)&lt;br /&gt;
 分享一个 Typora 搭配腾讯云 COS / 阿里云 OSS 图床的&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2d1b19yaWRnZXBvbGUvYXJ0aWNsZS9kZXRhaWxzLzEwODI1NzI3Nw==&#34;&gt;例子&lt;/span&gt;。新用户免费试用 6 个月，另外还可选择七牛云或者路过图床.&lt;/p&gt;
&lt;h3 id=&#34;5-typora-的常用快捷键&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#5-typora-的常用快捷键&#34;&gt;#&lt;/a&gt; 5. *Typora 的常用快捷键&lt;/h3&gt;
&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th style=&#34;text-align:center&#34;&gt;按键&lt;/th&gt;
&lt;th style=&#34;text-align:center&#34;&gt;效果&lt;/th&gt;
&lt;th style=&#34;text-align:center&#34;&gt;按键&lt;/th&gt;
&lt;th style=&#34;text-align:center&#34;&gt;效果&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;D&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;选中当前词&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;L&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;选中当前句 / 行&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;E&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;选中当前区块&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;F&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;搜索当前选中&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;B&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;加粗当前选中&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;H&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;替换当前选中&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;I&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;倾斜当前选中&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;U&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;下划当前选中&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;K&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;将当前选中生成链接&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;J&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;滚动屏幕将选中滚至顶部&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;W&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;关闭当前窗口&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;N&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;打开新窗口&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;O&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;打开文件&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;P&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;搜索文件并打开&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;回车&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;表格下方插入行&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;,&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;打开偏好设置&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;.&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;切换全角 / 半角标点&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;/&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;切换正常 / 源代码视图&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;Shift&lt;/code&gt;  +  &lt;code&gt;-&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;缩小视图缩放&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;&lt;code&gt;Ctrl&lt;/code&gt;  +  &lt;code&gt;Shift&lt;/code&gt;  +  &lt;code&gt;+&lt;/code&gt;&lt;/td&gt;
&lt;td style=&#34;text-align:center&#34;&gt;放大视图缩放&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;还有一些不常用的 / 三键的快捷键不在此列出.&lt;/p&gt;
&lt;h3 id=&#34;6-typora-的主题样式与检查元素&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#6-typora-的主题样式与检查元素&#34;&gt;#&lt;/a&gt; 6. *Typora 的主题样式与检查元素&lt;/h3&gt;
&lt;p&gt;Markdown 在编译后约等于 HTML. 而 Typora 的正常视图就是编译后的 Markdown, 故 Typora 的主题样式本质就是 CSS 文件.&lt;br /&gt;
 可以下载各种好看的主题给 Typora 换上，同时也可以自己调整对应的 CSS 文件，或者自己手搓.&lt;br /&gt;
 在 Typora 设置中开启  &lt;code&gt;调试模式&lt;/code&gt;  后即可在正常视图右击打开  &lt;code&gt;检查元素&lt;/code&gt; ，在其中就可以完全将 Markdown 文件当成 HTML 来编辑.&lt;/p&gt;
&lt;h2 id=&#34;总结&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#总结&#34;&gt;#&lt;/a&gt; 💯 总结&lt;/h2&gt;
&lt;p&gt;至此，&lt;strong&gt;Markdown + Typora / VSCode&lt;/strong&gt; 的手册教程也告一段落.&lt;br /&gt;
 不知你看完这么长的教程 / 手册，是否能体会到 Markdown 的精妙简洁之处呢？&lt;br /&gt;
 其实 Markdown 只是标记语言的最开始，我的感受是会了 Markdown 之后对于理解 HTML 也有帮助，对于用 &lt;span class=&#34;katex&#34;&gt;&lt;span class=&#34;katex-mathml&#34;&gt;&lt;math xmlns=&#34;http://www.w3.org/1998/Math/MathML&#34;&gt;&lt;semantics&gt;&lt;mrow&gt;&lt;mtext&gt;LaTeX&lt;/mtext&gt;&lt;/mrow&gt;&lt;annotation encoding=&#34;application/x-tex&#34;&gt;\LaTeX&lt;/annotation&gt;&lt;/semantics&gt;&lt;/math&gt;&lt;/span&gt;&lt;span class=&#34;katex-html&#34; aria-hidden=&#34;true&#34;&gt;&lt;span class=&#34;base&#34;&gt;&lt;span class=&#34;strut&#34; style=&#34;height:0.89883em;vertical-align:-0.2155em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;L&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.36em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.68333em;&#34;&gt;&lt;span style=&#34;top:-2.904999em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:2.7em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm mtight sizing reset-size6 size3&#34;&gt;A&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.15em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord text&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.1667em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;vlist-t vlist-t2&#34;&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.46782999999999997em;&#34;&gt;&lt;span style=&#34;top:-2.7845em;&#34;&gt;&lt;span class=&#34;pstrut&#34; style=&#34;height:3em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord&#34;&gt;&lt;span class=&#34;mord textrm&#34;&gt;E&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-s&#34;&gt;​&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;vlist-r&#34;&gt;&lt;span class=&#34;vlist&#34; style=&#34;height:0.2155em;&#34;&gt;&lt;span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;mspace&#34; style=&#34;margin-right:-0.125em;&#34;&gt;&lt;/span&gt;&lt;span class=&#34;mord textrm&#34;&gt;X&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt; 来写论文也有帮助。标记语言正是为了摆脱 Word 那种虽然 &amp;quot;所见即所得&amp;quot;, 但又过于花哨浮华，很差的兼容性与闭源的编码的缺陷。当你能掌握这样的 &amp;quot;所写即所得&amp;quot; 时，你肯定会感受到用 Markdown 这类语言来处理文本的妙处！&lt;/p&gt;
</content>
        <category term="Markdown" scheme="https://jdjwzx233.cn/categories/Markdown/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="Markdown" scheme="https://jdjwzx233.cn/tags/Markdown/" />
        <category term="教程" scheme="https://jdjwzx233.cn/tags/%E6%95%99%E7%A8%8B/" />
        <updated>2022-07-20T19:32:57.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/02/03/jdjwzxAPI%E7%9A%84%E5%8D%9A%E5%AE%A2/</id>
        <title>jdjwzx233的博客</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/02/03/jdjwzxAPI%E7%9A%84%E5%8D%9A%E5%AE%A2/"/>
        <content type="html">&lt;ol&gt;
&lt;li&gt;&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如无特别声明，该博客文章均为 jdjwzx233 原创，转载请遵循署名 - 非商业性使用 4.0 国际（CC BY-NC-SA）协议，即转载请注明文章来源。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;如发现用户发布违规内容或评论，管理员将封禁其 IP 地址！（所有 jdjwzx233 的站点将不可访问。如果有误封，请联系 &lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt; 进行申诉）&lt;/strong&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本博客使用 &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvLw==&#34;&gt;hexo&lt;/span&gt; 进行搭建，采用 shoka 主题。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本博客属于非商业性质的博客。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如需联系 jdjwzx233，请&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9hcGkuYnRzdHUuY24vcXF0YWxrL2FwaS5waHA/cXE9MTQzODE0ODI0Mw==&#34;&gt;点击这里&lt;/span&gt;，或通过添加好友的方式联系 jdjwzx233-bot（QQ: 1438148243）。在进入 QQ 后，向 jdjwzx233-bot 发送指令 &amp;quot;!rg&amp;quot;，即可获取 jdjwzx233 的联系方式。获取好友验证码请参考第 7 条。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果博客文章、使用的图片等侵犯了您的版权或给您带来了损失，请联系 &lt;strong&gt;&lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt;&lt;/strong&gt;。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;jdjwzx233-bot 的好友验证码为：jdjwzx233blogyyds（不定时更改）。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;jdjwzx233-bot 将于 2023 年二月份关闭，客服业务已经转移到 jdjwzx233-Blog 上。您现在可以通过博客右下角的咨询按钮联系 jdjwzx233-Blog 的管理员。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果喜欢 jdjwzx233-Blog，请&lt;a href=&#34;/Subscribe&#34;&gt;点击这里&lt;/a&gt;订阅，获取 jdjwzx233-Blog 的最新动态。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;如果您访问本站，即表示您同意本站的&lt;a href=&#34;/Privacy%20policy&#34;&gt;隐私政策&lt;/a&gt;、&lt;a href=&#34;/Cookiepolicy&#34;&gt;Cookie 政策&lt;/a&gt;、&lt;a href=&#34;/Term%20sand%20conditions&#34;&gt;服务条款&lt;/a&gt;和&lt;a href=&#34;/Disclaimer&#34;&gt;免责声明&lt;/a&gt;。如果您不同意相关政策和条款，请勿访问本站。您可以联系 &lt;strong&gt;&lt;a href=&#34;mailto:admin@jdjwzx233.cn&#34;&gt;admin@jdjwzx233.cn&lt;/a&gt;&lt;/strong&gt; 删除您在本站中的一切信息（包括评论、账户、文章等）。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;为了尊重和保护访客和用户的隐私权，我们提供了一种方便的方式来关闭网站跟踪器。您可以在网站底部找到相应选项，以便自主选择是否接受网站跟踪。我们鼓励您在使用我们的网站时行使您的选择权，以获得更加个性化和符合您需求的浏览体验。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;本站点已启用腾讯云 CDN 加速，加速网址：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cDovL3d3dy5qZGp3engyMzMuY24=&#34;&gt;www.jdjwzx233.cn&lt;/span&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;您可以使用爱发电赞助本博客的运营和开发。&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;赞助感谢名单：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9zcG9uc29ybWUuamRqd3p4MjMzLmNvbS8=&#34;&gt;https://sponsorme.jdjwzx233.com/&lt;/span&gt;&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;div class=&#34;links&#34;&gt;&lt;div class=&#34;item&#34; title=&#34;jdjwzx233&#34; style=&#34;--block-color:#e9546b;&#34;&gt;&lt;span class=&#34;exturl image&#34; data-url=&#34;aHR0cHM6Ly9hZmRpYW4uY29tL3UvY2Q3ZjQ5ZjIwZjRiMTFlZDlmM2M1MjU0MDAyNWMzNzc=&#34; data-background-image=&#34;https://upcdn.jdjwzx233.cn/upload/Qexo/24/11/24/logo_0bab5ae4d8eb33ed096e89d0912170f3.png&#34;&gt;&lt;/span&gt;
          &lt;div class=&#34;info&#34;&gt;
          &lt;span class=&#34;exturl title&#34; data-url=&#34;aHR0cHM6Ly9hZmRpYW4uY29tL3UvY2Q3ZjQ5ZjIwZjRiMTFlZDlmM2M1MjU0MDAyNWMzNzc=&#34;&gt;爱发电-jdjwzx233&lt;/span&gt;
          &lt;p class=&#34;desc&#34;&gt;每月5元，感谢您的赞助&lt;/p&gt;
          &lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;广告&lt;/strong&gt;：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;LightNode&lt;/strong&gt;：拥有高质量香港 CN2 GIA 节点与原生 IP (河内、曼谷、华盛顿、柬埔寨)。充值 10 美元，最多账户获得 30 美元，10 美元可用 5 个月，相当于&lt;strong&gt;不要钱&lt;/strong&gt;。（&lt;strong&gt;支持支付宝、银联、paypal 等支付方式&lt;/strong&gt;）。对于想用 VPS 解锁 **「Netflix、 TikTok」** 或者其他流媒体，以及对 CN2 有需求的都可以看看。官网链接：&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly93d3cubGlnaHRub2RlLmNvbS8/aW52aXRlQ29kZT1BRFFWTUomYW1wO3Byb21vdGVXYXk9TElOSw==&#34;&gt;www.lightnode.com&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;又拍云&lt;/strong&gt;：又拍云有非常多的优惠：加入又拍云联盟 (网站需备案，要在网站 / 应用底部添加又拍云 LOGO 并指向官网) 后，可以获得每月 10G 储存空间和 15G 的 CDN 流量 (按年发放，以 67 元的代金卷发放到账户)；新用户注册 (&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jb25zb2xlLnVweXVuLmNvbS9yZWdpc3Rlci8/aW52aXRlPXRJOGxqaXhJVA==&#34;&gt;点我注册&lt;/span&gt;) 还可以直接获得 61 元的代金卷 (有效期一年)。在这些优惠的加成下，你可以零成本建站。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;strong&gt;&lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9jaWFsbG8ubXkv&#34;&gt;Ciallo～(∠・ω&amp;lt; )⌒★&lt;/span&gt;&lt;/strong&gt;&lt;/p&gt;
</content>
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/categories/jdjwzx233/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="jdjwzx233" scheme="https://jdjwzx233.cn/tags/jdjwzx233/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="梦开始的地方" scheme="https://jdjwzx233.cn/tags/%E6%A2%A6%E5%BC%80%E5%A7%8B%E7%9A%84%E5%9C%B0%E6%96%B9/" />
        <category term="声明" scheme="https://jdjwzx233.cn/tags/%E5%A3%B0%E6%98%8E/" />
        <updated>2022-02-03T12:53:56.000Z</updated>
    </entry>
    <entry>
        <id>https://jdjwzx233.cn/2022/02/02/hello-world/</id>
        <title>Hello World</title>
        <link rel="alternate" href="https://jdjwzx233.cn/2022/02/02/hello-world/"/>
        <content type="html">&lt;p&gt;Welcome to &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvLw==&#34;&gt;Hexo&lt;/span&gt;! This is your very first post. Check &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3Mv&#34;&gt;documentation&lt;/span&gt; for more info. If you get any problems when using Hexo, you can find the answer in &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3MvdHJvdWJsZXNob290aW5nLmh0bWw=&#34;&gt;troubleshooting&lt;/span&gt; or you can ask me on &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9naXRodWIuY29tL2hleG9qcy9oZXhvL2lzc3Vlcw==&#34;&gt;GitHub&lt;/span&gt;.&lt;/p&gt;
&lt;h2 id=&#34;quick-start&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#quick-start&#34;&gt;#&lt;/a&gt; Quick Start&lt;/h2&gt;
&lt;h3 id=&#34;create-a-new-post&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#create-a-new-post&#34;&gt;#&lt;/a&gt; Create a new post&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight bash&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;$ hexo new &lt;span class=&#34;string&#34;&gt;&amp;quot;My New Post&amp;quot;&lt;/span&gt;&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;More info: &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3Mvd3JpdGluZy5odG1s&#34;&gt;Writing&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;也可以手动添加文档 -&amp;gt; 文件名.md 放入：主文件夹 /source/_posts/ 中。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;一定要在文档开头添加:&lt;/strong&gt;&lt;br /&gt;
&lt;figure class=&#34;highlight plaintext&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;3&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;4&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;5&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;6&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;7&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;8&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;9&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;10&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;11&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;12&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;---&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;title: 文章的标题&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;date: 2022-01-01 01:01:01&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;categories:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [博客的分类1]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [博客的分类2]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- [博客的分类3]&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;tags:&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- 标签1&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;- 标签2&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;---&lt;/span&gt;&lt;br&gt;&lt;span class=&#34;line&#34;&gt;这里开始使用Markdown书写博客正文&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;br /&gt;
&lt;strong&gt; 否则会出现问题！！！&lt;/strong&gt;&lt;/p&gt;
&lt;h3 id=&#34;run-server&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#run-server&#34;&gt;#&lt;/a&gt; Run server&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight bash&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;$ hexo server&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;More info: &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3Mvc2VydmVyLmh0bWw=&#34;&gt;Server&lt;/span&gt;&lt;/p&gt;
&lt;h3 id=&#34;generate-static-files&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#generate-static-files&#34;&gt;#&lt;/a&gt; Generate static files&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight bash&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;$ hexo generate&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;More info: &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3MvZ2VuZXJhdGluZy5odG1s&#34;&gt;Generating&lt;/span&gt;&lt;/p&gt;
&lt;h3 id=&#34;deploy-to-remote-sites&#34;&gt;&lt;a class=&#34;anchor&#34; href=&#34;#deploy-to-remote-sites&#34;&gt;#&lt;/a&gt; Deploy to remote sites&lt;/h3&gt;
&lt;p&gt;&lt;figure class=&#34;highlight bash&#34;&gt;&lt;table&gt;&lt;tr&gt;&lt;td class=&#34;gutter&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;1&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;td class=&#34;code&#34;&gt;&lt;pre&gt;&lt;span class=&#34;line&#34;&gt;$ hexo deploy&lt;/span&gt;&lt;br&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;&lt;/figure&gt;&lt;/p&gt;
&lt;p&gt;More info: &lt;span class=&#34;exturl&#34; data-url=&#34;aHR0cHM6Ly9oZXhvLmlvL2RvY3Mvb25lLWNvbW1hbmQtZGVwbG95bWVudC5odG1s&#34;&gt;Deployment&lt;/span&gt;&lt;/p&gt;
</content>
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/categories/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/categories/jdjwzxAPI/" />
        <category term="奇怪的知识" scheme="https://jdjwzx233.cn/tags/%E5%A5%87%E6%80%AA%E7%9A%84%E7%9F%A5%E8%AF%86/" />
        <category term="jdjwzxAPI" scheme="https://jdjwzx233.cn/tags/jdjwzxAPI/" />
        <category term="梦开始的地方" scheme="https://jdjwzx233.cn/tags/%E6%A2%A6%E5%BC%80%E5%A7%8B%E7%9A%84%E5%9C%B0%E6%96%B9/" />
        <updated>2022-02-02T15:32:57.000Z</updated>
    </entry>
</feed>
