// ==UserScript== // @name chatGPT tools Plus(修改版) // @namespace http://tampermonkey.net/ // @version 3.7.0 // @description Google、必应、百度、Yandex、360搜索、谷歌镜像、搜狗、b站、F搜、duckduckgo、CSDN侧边栏Chat搜索,集成国内一言,星火,天工,混元,通义AI,ChatGLM,360智脑,miniMax,DeepSeek、Gemini。即刻体验AI,无需翻墙,无需注册,无需等待! // @description:en Google, Bing, Baidu, Yandex, 360 Search, Google Mirror, Sogou, B Station, F Search, DuckDuckgo, CSDN sidebar CHAT search, integrate domestic words, star fire, sky work, righteous AI, Chatglm, 360 wisdom, 360 wisdom brain. Experience AI immediately, no need to turn over the wall, no registration, no need to wait! // @description:zh-TW Google、必應、百度、Yandex、360搜索、谷歌鏡像、搜狗、b站、F搜、duckduckgo、CSDN側邊欄Chat搜索,集成國內一言,星火,天工,通義AI,ChatGLM,360智腦。即刻體驗AI,無需翻墻,無需註冊,無需等待! // @author 夜雨 // @match https://cn.bing.com/* // @match https://www.bing.com/* // @match *://*.bing.com/* // @match https://chat.openai.com/chat // @match https://www.google.com/* // @match https://duckduckgo.com/* // @match https://www.so.com/s* // @match *://m.so.com/s* // @match *://www.baidu.com/s* // @match https://www.baidu.com/* // @match https://m.baidu.com/* // @match *://baidu.com/s* // @match *://yandex.ru/search* // @match *://yandex.com/search* // @match https://search.ecnu.cf/search* // @match https://search.aust.cf/search* // @match https://search.*.cf/search* // @match https://*.cf:*/* // @match *://gooo.azurewebsites.net/* // @match https://fsoufsou.com/search* // @match https://www.google.com.hk/* // @match *://www.sogou.com/* // @match *://m.sogou.com/* // @match *://chat.scnet.cn/* // @match *://wap.sogou.com/* // @match *://www.bilibili.com/video/* // @match *://blog.csdn.net/*/article/details/* // @match *://chatglm.cn/* // @icon64 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAAAZlBMVEUAAAD///+hoaFoaGhsbGy7u7vd3d2+vr76+vra2tr29va2trYrKyvg4ODs7OxXV1dgYGCtra0xMTGXl5fExMQ6OjqOjo7R0dEVFRWnp6dSUlIiIiIcHBwLCwt4eHhycnKEhIRHR0f14+hfAAADN0lEQVRYhe1WyZajMAyEsMQshgABEwIJ+f+fbC02W0yHnjnNvNYFDFbZKpUlO86v/e/Wpve/8M4TFckwSvI/cx8z11g2/tw9vZKrEIKe159GUkvwipPxVb4eQQzvYV12XX3Y/x6BT5LqUZkgWixEHF/9/hAAeozz0I8nOtzoccDfg8CbaZQrYkOGYUaEFO2RDUTT4MZefjkMpVcQo5/Wr2DSi9/bhlYPhukvZqf41l3hiiFv8xJR2CslIT+XXfc+YapojY60kG1ZA0rknj+lL4YtnGCQ4lbESSczf5R6Ugc5ee4AoL9KAwbwYXDWXJTXhaDhf2L3R44rxzkbgFgHn55Y0JJjzyeONpYLDn4CCPn7A46VaggjwIB6eEltAOConCUAcZVDXBKIHHgbp9IZ4KW0AZj8LAHaQEzaY0lmHk60AXiQ8XYFEDoVrRpXOmSfdQFfbMe7MuTOJMLU6IJqkh7PuTMVrhosAJCp2xrApA6Lk+p4VllMQjsAcNNkpzeQlKkPHhQb0VkAEgO8TSMaVqhMH/EyW57W2R7moNoBCjwDPg1QzM07QAk7o+wUrIcNwAVZ1ktAROE7gBMaEq4kaW8NgHlQOsrULiUoHjGT40PIqngHOIGYzRK22ggJz3TpbrCt7AMU9gPZwc4y5slJC7FO4woAxmcLgMMi0dF1ymSOtnMEYFDczxqtdJRM6HlAbhSvARIqHG+G5BJGqONoK2opooIMLQFaYMvWs0EJruNRV1b8vy+wqDtbEj2caAcQg5NWdIQL6IJPjIGg1gDKhLINARyxed4DpgLFq+vvKoRiEszGWmlCy0OmcyrqSxKr/eaUzFvDGnDWCX2d5zQmNdJsO4xoz8XeyqcpIdRexZ0BBOYl2r2wyHfwB2WFO0zBjS/Zv2Vc8Pey3l3kor0iR65Q+61Vr6GmttNSOtxRf+jgvfnW3eFa4CZ+3fb1k1q1uC0D3GmKC2s5zkxKvieqWbKQPvFpfbRnNF+pYn/+3ny6m0zW+9eYDIMxlQsbvKuO3zfrV5fWKMc4GLu6G+m2KY/fNNnu6/vu2drTv7fFjVuOP3dHy5MolJEqrKfvoPXp57vpr/3r9gUxwiW4OiuC3wAAAABJRU5ErkJggg== // @grant GM_xmlhttpRequest // @grant GM_addStyle // @grant GM_openInTab // @grant GM_registerMenuCommand // @grant GM_setValue // @grant GM_getValue // @grant GM_getResourceText // @grant GM_setClipboard // @grant GM_info // @run-at document-end // @require https://bowercdn.net/c/jquery-3.4.0/dist/jquery.min.js // @require https://s4.zstatic.net/ajax/libs/showdown/2.1.0/showdown.min.js // @require https://s4.zstatic.net/ajax/libs/highlight.js/11.7.0/highlight.min.js // @require https://cdnjs.cloudflare.com/ajax/libs/crypto-js/4.1.1/crypto-js.min.js // @require https://s4.zstatic.net/ajax/libs/KaTeX/0.16.6/katex.min.js // @require https://s4.zstatic.net/ajax/libs/marked/13.0.2/marked.min.js // @resource katexCss https://cdn.bootcdn.net/ajax/libs/KaTeX/0.16.6/katex.css // @connect hunyuan.tencent.com // @connect yuanbao.tencent.com // @connect zw7.lol // @connect aifree.site // @connect ai.ls // @connect qianwen.biz.aliyun.com // @connect chatgpt.com // @connect openai.com // @connect jennyapi.site // @connect binjie.fun // @connect free-api.cveoy.top // @connect caipacity.com // @connect api.minimax.chat // @connect baidu.com // @connect bing.com // @connect generativelanguage.googleapis.com // @connect tongyi.aliyun.com // @connect qianwen.aliyun.com // @connect xinghuo.xfyun.cn // @connect geetest.com // @connect chatglm.cn // @connect open.bigmodel.cn // @connect chat.360.cn // @connect mixerbox.com // @connect api.deepseek.com // @connect api.moonshot.cn // @connect dashscope.aliyuncs.com // @connect api.groq.com // @connect api.together.xyz // @connect api.mistral.ai // @connect api.perplexity.ai // @connect api.siliconflow.cn // @connect api.lingyiwanwu.com // @connect api.stepfun.com // @connect spark-api-open.xf-yun.com // @connect api.cohere.com // @connect api.baichuan-ai.com // @connect qianfan.baidubce.com // @connect ark.cn-beijing.volces.com // @connect api.sensenova.cn // @connect api.kunlun.com // @connect api.tiangong.cn // @connect api.internlm.org // @connect api.zhipuai.cn // @connect api.minimaxi.com // @connect api.deepwords.cn // @connect abab.ai // @connect api.anthropic.com // @compatible Chrome // @compatible Firefox // @license MIT // @website https://yeyu2048.xyz/gpt.html // ==/UserScript== // import { // GM_registerMenuCommand,GM_openInTab,GM_xmlhttpRequest,GM_setValue,GM_getValue, // GM_setClipboard,GM_addStyle // } from "../jslib/tampermonkey"; (function () { 'use strict'; const JSver = '3.7.0'; function getGPTMode() { return localStorage.getItem("GPTMODE"); } let darkTheme = localStorage.getItem("darkTheme") console.log(darkTheme) //katex Css try { GM_addStyle(GM_getResourceText("katexCss")) }catch (e) {} //(prefers-color-scheme: light) function addHeadCss() { if(!document.getElementById("github-markdown-link")){ const cssUrl = !darkTheme ? 'https://cdn.bootcdn.net/ajax/libs/github-markdown-css/5.2.0/github-markdown-dark.min.css' : 'https://cdn.bootcdn.net/ajax/libs/github-markdown-css/5.2.0/github-markdown-light.min.css'; $("head").append($(``)); } if(!document.getElementById("highlight-link")){ const hlUrl = !darkTheme ? 'https://cdn.bootcdn.net/ajax/libs/highlight.js/11.7.0/styles/monokai-sublime.min.css' : 'https://cdn.bootcdn.net/ajax/libs/highlight.js/11.7.0/styles/atom-one-light.min.css'; $("head").append($(``)); } //spark-js if(!document.getElementById("spark-js")){ $("head").append($('')); } } setTimeout(addHeadCss) // 使用 MutationObserver 替代 setInterval,仅在 DOM 变化时检查 const _headObserver = new MutationObserver(() => { addHeadCss(); }); _headObserver.observe(document.head, { childList: true }); addHeadCss(); try { console.log( `%c【chatGPT tools Plus】${JSver} 已加载`, 'color: yellow;font-size: large;font-weight: bold;background-color: darkblue;' ); const menu_updateChat_id = GM_registerMenuCommand("更新脚本", function (event) { GM_openInTab("https://greasyfork.org/zh-CN/scripts/459997") }, "updateChat"); const menu_groupNum_id = GM_registerMenuCommand("交流群", function (event) { Toast.info("交流总群:249733992", "QQ交流群", {timeOut: 15000} ) }, "groupNum"); //禁用console 未转义警告 hljs.configure({ ignoreUnescapedHTML: true }) } catch (ex) { console.error(ex) } //自定义Toast通知 ----start---- GM_addStyle(` #sp-toast-container { position: fixed; top: 16px; right: 16px; z-index: 99999; display: flex; flex-direction: column; gap: 8px; pointer-events: none; } .sp-toast { pointer-events: auto; min-width: 240px; max-width: 380px; padding: 12px 16px; border-radius: 10px; color: #fff; font-size: 14px; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif; box-shadow: 0 4px 16px rgba(0,0,0,0.15); display: flex; align-items: flex-start; gap: 10px; opacity: 0; transform: translateX(100%); transition: opacity 0.3s ease, transform 0.3s ease; line-height: 1.5; } .sp-toast.sp-show { opacity: 1; transform: translateX(0); } .sp-toast.sp-hide { opacity: 0; transform: translateX(100%); } .sp-toast-icon { flex-shrink: 0; font-size: 16px; line-height: 1.4; } .sp-toast-body { flex: 1; min-width: 0; } .sp-toast-title { font-weight: 600; margin-bottom: 2px; } .sp-toast-msg { word-break: break-all; } .sp-toast-close { flex-shrink: 0; cursor: pointer; opacity: 0.7; font-size: 18px; line-height: 1; padding: 0 2px; transition: opacity 0.2s; } .sp-toast-close:hover { opacity: 1; } .sp-toast-success { background: linear-gradient(135deg, #43a047, #388e3c); } .sp-toast-error { background: linear-gradient(135deg, #e53935, #c62828); } .sp-toast-info { background: linear-gradient(135deg, #1e88e5, #1565c0); } .sp-toast-warning { background: linear-gradient(135deg, #fb8c00, #ef6c00); } `); const Toast = { _container: null, _getContainer: function() { if (!this._container) { this._container = document.createElement('div'); this._container.id = 'sp-toast-container'; document.body.appendChild(this._container); } return this._container; }, _show: function(type, icon, msg, title, options) { try { const container = this._getContainer(); const timeOut = (options && options.timeOut) || 3000; const el = document.createElement('div'); el.className = 'sp-toast sp-toast-' + type; let bodyHtml = ''; if (title) { bodyHtml += '
' + title + '
'; } bodyHtml += '
' + msg + '
'; el.innerHTML = '' + icon + '' + '
' + bodyHtml + '
' + '×'; el.querySelector('.sp-toast-close').addEventListener('click', () => { Toast._remove(el); }); container.appendChild(el); el.offsetHeight; // reflow el.classList.add('sp-show'); var timer = setTimeout(function() { Toast._remove(el); }, timeOut); el._timer = timer; } catch (e) { console.error(e); } }, _remove: function(el) { if (el._timer) clearTimeout(el._timer); el.classList.remove('sp-show'); el.classList.add('sp-hide'); setTimeout(function() { el.remove(); }, 300); }, success: function(msg, title, options) { this._show('success', '✅', msg, title, options); }, error: function(msg, title, options) { this._show('error', '❌', msg, title, options); }, info: function(msg, title, options) { this._show('info', 'ℹ️', msg, title, options); }, warn: function(msg, title, options) { this._show('warning', '⚠️', msg, title, options); } }; //自定义Toast通知 ----end---- //封装GM_xmlhttpRequest ---start--- async function GM_fetch(details) { return new Promise((resolve, reject) =>{ switch (details.responseType){ case "stream": details.onloadstart = (res)=>{ resolve(res) } break; default: details.onload = (res)=>{ resolve(res) }; } details.onerror = (res)=>{ reject(res) }; details.ontimeout = (res)=>{ reject(res) }; details.onabort = (res)=>{ reject(res) }; //中断支持 if(details.responseType === "stream"){ abortXml = GM_xmlhttpRequest(details) }else{ GM_xmlhttpRequest(details) } }); } function GM_httpRequest(details, callBack, errorCallback, timeoutCallback, abortCallback){ if(callBack){ switch (details.responseType){ case "stream": details.onloadstart = callBack; break; default: details.onload = callBack } } if(errorCallback){ details.onerror = errorCallback; } if(timeoutCallback){ details.ontimeout = timeoutCallback; } if(abortCallback){ details.onabort = abortCallback; } console.log(details) //中断支持 if(details.responseType === "stream"){ abortXml = GM_xmlhttpRequest(details) }else{ GM_xmlhttpRequest(details) } } //封装GM_xmlhttpRequest ---end--- //is TM function isTM(){ try{ if(/Tampermonkey/gi.test(GM_info.scriptHandler)){ return true; }else{ return false; } }catch (e) { return false; } } //获取chrome版本 function getChromeVersion() { try { const brands = navigator.userAgentData.brands for (let i = 0; i < brands.length; i++) { if(/Chromium/gi.test(brand[i].brand )){ return Number(brand[i].version) } } }catch (e) { return 0 } return 0 } const generateRandomIP = () => { const ip = []; for (let i = 0; i < 4; i++) { ip.push(Math.floor(Math.random() * 256)); } console.log(ip.join('.')) return ip.join('.'); } //各线路API配置项定义 const API_CONFIG_SCHEMA = { 'ZhipuAI': [ { key: 'ZhipuapiKey', label: 'API Key', placeholder: '请输入智谱API Key' } ], 'OPENAI': [ { key: 'openai_base_url', label: 'Base URL', placeholder: 'https://api.openai.com' }, { key: 'openai_api_key', label: 'API Key', placeholder: '请输入API Key' }, { key: 'openai_model', label: '模型', placeholder: 'gpt-5.5' } ], 'miniMax': [ { key: 'minimax_group_id', label: 'Group ID', placeholder: '请输入minimax_group_id' }, { key: 'minimax_api_key', label: 'API Key', placeholder: '请输入minimax_api_key' } ], 'Anthropic': [ { key: 'anthropic_base_url', label: 'Base URL', placeholder: 'https://api.anthropic.com' }, { key: 'anthropic_api_key', label: 'API Key', placeholder: '请输入Anthropic API Key' }, { key: 'anthropic_model', label: '模型', placeholder: 'claude-sonnet-4-20250514' } ] }; //渲染API配置面板 function renderApiConfigPanel() { const panel = document.getElementById('apiConfigPanel'); if (!panel) return; const GPTMODE = getGPTMode(); const schema = API_CONFIG_SCHEMA[GPTMODE]; if (!schema) { panel.innerHTML = ''; panel.style.display = 'none'; return; } panel.style.display = 'block'; let html = ''; schema.forEach(item => { const val = localStorage.getItem(item.key) || ''; html += `
${item.label}
`; }); // OPENAI/Anthropic模式下提示添加@connect if (GPTMODE === 'OPENAI' || GPTMODE === 'Anthropic') { html += `
⚠️ 若使用第三方接口,请在脚本头部添加:// @connect  你的域名
例如:// @connect api.deepseek.com
`; } html += '
修改后自动保存 ✓
'; panel.innerHTML = html; //绑定自动保存事件 panel.querySelectorAll('.api-config-input').forEach(input => { input.addEventListener('input', function () { const key = this.dataset.key; let val = this.value.trim(); if (key === 'openai_base_url' || key === 'anthropic_base_url') { val = val.replace(/\/+$/, ''); } if (val) { localStorage.setItem(key, val); } else { localStorage.removeItem(key); } //同步全局变量 if (key === 'ZhipuapiKey') zhipu_apiKey = val; if (key === 'minimax_group_id') minimax_group_id = val; if (key === 'minimax_api_key') minimax_api_key = val; }); }); } //enc-start async function digestMessage(r) { const hash = CryptoJS.SHA256(r); return hash.toString(CryptoJS.enc.Hex); } const generateSignatureWithPkey = async r => { const { t: e, m: t, pkey: n } = r; console.log("CURRENT KEY:" + n) const a = `${e}:${t}:${n}`; return await digestMessage(a); }; let aesKey = "hj6cdzrhj72x8ht1"; const AES_CBC = { encrypt: function(e, t) { return CryptoJS.AES.encrypt(CryptoJS.enc.Utf8.parse(e), CryptoJS.enc.Utf8.parse(t), { iv: CryptoJS.enc.Utf8.parse(aesKey), mode: CryptoJS.mode.CBC }).toString() }, decrypt: function(e, t) { return CryptoJS.AES.decrypt(e, CryptoJS.enc.Utf8.parse(t), { iv: CryptoJS.enc.Utf8.parse(aesKey), mode: CryptoJS.mode.CBC }).toString(CryptoJS.enc.Utf8) } }; //enc-end //start function addChatBtn() { let mybtn = ``; $(".bg.s_btn_wr").after(mybtn) document.getElementById("mybtn").addEventListener("click", function () { console.log("reloadPage") if (window.location.href.indexOf("baidu.com\/s") > -1) { GM_add_box_style(2) addBothStyle() keyEvent() appendBox(2).then((res) => { pivElemAddEventAndValue(2) }) } }) } function isMobile() { let userAgentInfo = navigator.userAgent.toLowerCase(); let mobileAgents = ["Android", "iPhone", "SymbianOS", "Windows Phone", "iPad", "iPod","Mobile"]; let mobile_flag = false; //根据userAgent判断是否是手机 for (let v = 0; v < mobileAgents.length; v++) { if (userAgentInfo.indexOf(mobileAgents[v].toLowerCase()) > -1) { mobile_flag = true; break; } } return mobile_flag; } //end const katex_options = {displayMode: false, throwOnError: false} function toRawText(exp){ //处理html标签 try { exp = exp.replace(/\&/gi, "&").replace(/
/g,"\n").replace(/
/g,"\n") .replace(/\>/g,">").replace(/\</g,"<") // 处理矩阵 exp = exp.replace(/\\begin\{bmatrix\}(.*?)\\end\{bmatrix\}/g, (_, tex) => { //debugger return `\\begin\{bmatrix\}${tex.replace(/\\/g,"\\\\")}\\end\{bmatrix\}`; }) exp = exp.replace(/\\begin\{pmatrix\}(.*?)\\end\{pmatrix\}/g, (_, tex) => { //debugger return `\\begin\{pmatrix\}${tex.replace(/\\/g,"\\\\")}\\end\{pmatrix\}`; }) }catch (e) { } return exp; } function katexTohtml(rawHtml) { // console.log("========katexTohtml start=======") let renderedHtml = rawHtml; try { renderedHtml = rawHtml.replace(//g, "").replace(/<\/em>/g, "").replace(/\$\$(.*?)\$\$/g, (_, tex) => { //debugger return katex.renderToString(toRawText(tex), katex_options); }); renderedHtml = renderedHtml.replace(/\$(.*?)\$/g, (_, tex) => { //debugger return katex.renderToString(toRawText(tex), katex_options); }); }catch (ex) { console.error(ex) } // console.log("========katexTohtml end=======") //console.log(renderedHtml) return renderedHtml; } let rawAns = undefined; let isShowRaw = false; //显示答案并高亮代码函数 function showAnserAndHighlightCodeStr(codeStr) { if(!codeStr) return rawAns = codeStr;//记录原文 try { document.getElementById('gptAnswer').innerHTML = mdConverter(codeStr) } catch (ex) { console.error(ex) } highlightCodeStr()//高亮 //添加代码复制按钮 start let preList = document.querySelectorAll("#gptAnswer pre") preList.forEach((pre)=>{ try{ if(!pre.querySelector(".btn-pre-copy")){ //复制代码 let copyBtn = document.createElement("span"); copyBtn.setAttribute("class","btn-pre-copy"); copyBtn.addEventListener("click",(event)=>{ let _this = event.target console.log(_this) let pre = _this.parentNode; console.log(pre.innerText) _this.innerText = ''; GM_setClipboard(pre.innerText, "text"); _this.innerText = '复制成功' Toast.success("复制成功!") setTimeout(() =>{ _this.innerText = '复制代码' },2000) }) copyBtn.innerText = '复制代码' pre.insertBefore(copyBtn, pre.firstChild) } }catch (e) { console.log(e) } }) //添加代码复制按钮 end } //高亮代码函数 function highlightCodeStr() { let gptAnswerDiv = document.querySelector("#gptAnswer"); gptAnswerDiv.querySelectorAll('pre code').forEach((el) => { hljs.highlightElement(el); }); } //顶级配置 let webSessionId let autoClick = localStorage.getItem("autoClick") let autoTips = localStorage.getItem("autoTips")? localStorage.getItem("autoTips") :'on'; let isFullScreen = false; let your_qus; let abortXml; let regx = /search.*?\.cf/g; // 站点初始化配置表:{ match, mobileMatch?, appendCase, inputCase, mobileInputCase?, delay?, autoHide? } const SITE_CONFIGS = [ { match: h => h.includes("bing.com"), appendCase: 0, inputCase: 0, styleCase: 0 }, { match: h => h.includes("google.com") || h.match(regx), appendCase: 1, inputCase: 1, mobileInputCase: 11 }, { match: h => h.includes("baidu.com/s") && !isMobile(), appendCase: 2, inputCase: 2, styleCase: 2 }, { match: h => h.includes("m.baidu.com") || (h.includes("baidu.com") && isMobile()), appendCase: 6, inputCase: 2, styleCase: 2 }, { match: h => h.includes("yandex.ru/search") || h.includes("yandex.com/search"), appendCase: 3, inputCase: 3 }, { match: h => h.includes("so.com/s"), appendCase: 4, inputCase: 4, mobileInputCase: 9 }, { match: h => h.includes("fsoufsou.com/search"), appendCase: 5, inputCase: 5, delay: 3000 }, { match: h => h.includes("duckduckgo.com/?q"), appendCase: 7, inputCase: 7 }, { match: h => h.includes("sogou.com"), appendCase: 8, inputCase: 8, mobileInputCase: 10 }, { match: h => h.includes("bilibili.com"), appendCase: 9, inputCase: null }, { match: h => h.includes("blog.csdn.net"), appendCase: 10, inputCase: null, autoHide: true }, ]; function initSite(cfg) { const run = () => { GM_add_box_style(cfg.styleCase !== undefined ? cfg.styleCase : 1); addBothStyle(); keyEvent(); appendBox(cfg.appendCase).then(() => { const ic = (isMobile() && cfg.mobileInputCase !== undefined) ? cfg.mobileInputCase : cfg.inputCase; pivElemAddEventAndValue(ic); if (cfg.autoHide) { document.getElementById('hideGptDiv').click(); } }); }; if (cfg.delay) { setTimeout(run, cfg.delay); } else { run(); } } const currentUrl = window.location.href; for (const cfg of SITE_CONFIGS) { if (cfg.match(currentUrl)) { initSite(cfg); break; } } //顶级函数 function uuid() { //uuid 产生 let s = []; let hexDigits = "0123456789abcdef"; for (let i = 0; i < 36; i++) { s[i] = hexDigits.substr(Math.floor(Math.random() * 0x10), 1); } s[14] = "4"; // bits 12-15 of the time_hi_and_version field to 0010 s[19] = hexDigits.substr((s[19] & 0x3) | 0x8, 1); // bits 6-7 of the clock_seq_hi_and_reserved to 01 s[8] = s[13] = s[18] = s[23] = "-"; return s.join(""); } function GM_add_box_style(case_web) { case_web = 2; switch (case_web) { case 2: GM_addStyle(` #gptAnswer{ margin: 12px 0; border: none; border-top: 1px solid rgba(0,0,0,0.06); padding: 12px 8px; line-height: 1.75; font-size: 14px; color: #333; max-height: 60vh; overflow-y: auto; } #gptAnswer::-webkit-scrollbar { width: 5px; } #gptAnswer::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.12); border-radius: 10px; } #gptAnswer::-webkit-scrollbar-track { background: transparent; } #gptInput{ border-radius: 24px; flex: 1; padding: 0 16px; height: 42px; border: none; background-color: transparent; font-size: 14px; font-weight: 400; color: #1a1a1a; outline: none; font-family: inherit; } #gptInput::placeholder{ color: #aab; font-size: 13px; } #button_GPT:hover{ cursor: pointer; opacity: 0.85; } #gptDiv{ width: 452px; flex: 1; display: flex; flex-direction: column; height: fit-content; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif; } #gptInputBox{ display: flex; align-items: center; justify-content: space-between; border-radius: 24px; border: 1.5px solid #e0e3e8; background: #f7f8fa; padding: 0 6px 0 0; margin: 0; transition: border-color 0.2s, box-shadow 0.2s; } #gptInputBox:focus-within{ border-color: #4e6ef2; box-shadow: 0 0 0 3px rgba(78,110,242,0.1); background: #fff; } #button_GPT{ border: none; background: linear-gradient(135deg, #4e6ef2, #3b5bdb); color: #fff; font-size: 13px; padding: 8px 18px; border-radius: 20px; font-weight: 500; display: flex; align-items: center; gap: 5px; transition: all 0.2s; white-space: nowrap; } #button_GPT svg path{ fill: #fff; } #gptStatus{ margin: 8px 0 0 0; font-size: 13px; color: #666; } #modeSelect { border: 1.5px solid #e0e3e8; border-radius: 8px; padding: 6px 10px; text-align: center; color: #4e6ef2; background: #fff; font-size: 13px; font-weight: 500; -webkit-appearance: none; cursor: pointer; outline: none; transition: border-color 0.2s; } #modeSelect:hover{ border-color: #4e6ef2; } #modeSelect:focus{ border-color: #4e6ef2; box-shadow: 0 0 0 3px rgba(78,110,242,0.08); } #modeSelect::-webkit-scrollbar { width: 6px; } #modeSelect::-webkit-scrollbar-thumb { background-color: #ccc; border-radius: 3px; } #modeSelect::-webkit-scrollbar-thumb:hover { background-color: #aaa; } #modeSelect::-webkit-scrollbar-track { background-color: #f5f5f5; border-radius: 3px; } .chatSetting{ display: block; text-align: right; margin: 10px 0 2px; } .chatHide{ display: none; } #chatSetting{ text-decoration: none !important; display: inline-flex; align-items: center; gap: 4px; color: #909399; font-size: 13px; padding: 4px 8px; border-radius: 6px; transition: all 0.2s; } #chatSetting:hover{ cursor: pointer; text-decoration: none !important; background: rgba(78,110,242,0.06); color: #4e6ef2; } #chatSetting svg{ transition: transform 0.3s; } #chatSetting:hover svg{ transform: rotate(60deg); } gptDiv p{ white-space: pre-line; } pre .btn-pre-copy{ text-align: right; display: block; font-size: 12px; color: #4e6ef2; padding: 2px 8px; opacity: 0; transition: opacity 0.2s; } pre:hover .btn-pre-copy{ opacity: 1; } pre .btn-pre-copy:hover{ cursor: pointer; color: #3b5bdb; } .fullScreen{ z-index: 999 !important; position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important; width: 100% !important; height: 100% !important; bottom: 0 !important; overflow-y: scroll !important; background: #fff; padding: 20px; } .bgtransparent{ background-color: transparent !important; } .floating-button { position: fixed; bottom: 24px; right: 24px; background: linear-gradient(135deg, #4e6ef2, #3b5bdb); color: #fff; border-radius: 50%; width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(78,110,242,0.35); z-index: 9999 !important; transition: transform 0.2s, box-shadow 0.2s; font-size: 13px; cursor: pointer; } .floating-button:hover{ transform: scale(1.08); box-shadow: 0 6px 20px rgba(78,110,242,0.45); } .floating-button a { text-decoration: none; color: inherit; z-index: 9999 !important; } /* fix bilibili高级弹幕背景问题 */ #bilibili-player pre { background-color: transparent !important; overflow-x: hidden; !important; overflow-y: hidden; !important; } `) break; default: Toast.error("参数没设定") } } // AI线路调度表:模式名 -> 启动函数 const GPT_MODE_HANDLERS = { 'YeYu': () => { /* YeYu() */ }, 'YQCLOUD': () => YQCLOUD(), 'TDCHAT': () => TDCHAT(), 'AILS': () => AILS(), 'CVEOY': () => CVEOY(), 'AIFREE': () => AIFREE(), 'OPENAI': () => OPENAI(), 'TONGYI': () => TONGYI(), 'SPARK': () => SPARK(), 'Hunyuan': () => Hunyuan(''), 'DeepSeekYuanBao':() => Hunyuan('deepseek'), 'ChatGLM': () => ChatGLM(), 'ChatGLM4': () => ChatGLM4(), 'ZhipuAI': () => ZhipuAI(), 'Zhinao360': () => Zhinao360(), 'MixerBox': () => MixerBox(), 'miniMax': () => miniMax(), 'Anthropic': () => Anthropic(), }; function do_it() { isShowRaw = false; rawAns = undefined; document.getElementById('gptAnswer').innerHTML = `
加载中
`; let GPTMODE = getGPTMode(); if (GPTMODE && GPT_MODE_HANDLERS[GPTMODE]) { console.log("当前模式:", GPTMODE); GPT_MODE_HANDLERS[GPTMODE](); return; } console.log("默认线路:"); Hunyuan(''); } function creatBox() { return new Promise((resolve) => { let divE = document.createElement('div'); let divId = document.createAttribute("id"); //创建属性 divId.value = 'gptDiv'; //设置属性值 divE.setAttributeNode(divId); //给div添加属性 let pE = document.createElement('p'); let pClass = document.createAttribute('class'); pClass.value = 'textClass'; pE.setAttributeNode(pClass) let pText = document.createTextNode(""); pE.appendChild(pText); divE.appendChild(pE); divE.classList.add("gpt-container"); divE.classList.add("markdown-body"); divE.innerHTML = `
设置
🌐 AI 线路
部分线路需科学上网
更新KEY 适用于智谱 / miniMax / OPENAI / Anthropic
⚙️ 功能设置
自动点击 ${localStorage.getItem("autoClick") ? "已开启" : "已关闭"}
暗黑模式 ${darkTheme ? "已关闭" : "已开启"}
搜索建议 ${autoTips === 'on' ? "已开启" : "已关闭"}
🤖
版本 ${JSver}
当前线路: ${getGPTMode() || "Default"} · 自动点击: ${localStorage.getItem("autoClick") || "关闭"}
更换AI接口请点击上方「设置」
朗读 复制 原文 中断 全屏 隐藏 `; resolve(divE) }) } let speakAudio; let isPlayend = true; async function pivElemAddEventAndValue(append_case) { let search_content try { if (append_case === 11) {//手机google search_content = document.querySelector("#tsf textarea").value } if (append_case === 10) {//手机sogou search_content = document.querySelector("input#keyword").value } if (append_case === 9) {//手机360 search_content = document.querySelector("input#q").value } if (append_case === 8) { search_content = document.querySelector("input#upquery").value } if (append_case === 7) { search_content = document.querySelector("#search_form input").value } if (append_case === 5) { search_content = document.getElementById("search-input").value } if (append_case === 4) { search_content = document.getElementById("keyword").value } if (append_case === 3) { search_content = document.querySelectorAll("input")[0].value } if (append_case === 2) { search_content = document.getElementById('kw').value } if (append_case === 1) { try { search_content = document.querySelector( "#tsf > div:nth-child(1) > div.A8SBwf > div.RNNXgb > div > div.a4bIc > input:nth-child(3)" ).value } catch (e) { search_content = document.querySelector("textarea").value } } if (append_case === 0) { search_content = document.getElementsByClassName('b_searchbox')[0].value if (!search_content) { search_content = document.querySelector("textarea[class='b_searchbox']").value; } } } catch (e) { console.log(e) } document.getElementById("gptInput").value = search_content || '' document.getElementById('button_GPT').addEventListener('click', () => { your_qus = document.getElementById("gptInput").value //字体设置 if(your_qus.startsWith("/font-size:")){ let fontSize = your_qus.substring("/font-size:".length) document.querySelector("#gptDiv").style.fontSize = fontSize; localStorage.setItem("gpt_font_size",fontSize) Toast.success(`字体设置成功:${fontSize}`) return } //禁用历史记录 if(your_qus.startsWith("/history_disable:")){ let dis = your_qus.substring("/history_disable:".length) history_disable = (dis === 'true' ? true : false); localStorage.setItem("history_disable", dis) Toast.success(`禁用历史记录设置成功:${history_disable}`) return } do_it() }) //搜索建议 document.getElementById('gptInput').addEventListener('keyup', () => { console.log("autoTips:",autoTips) if(autoTips !== 'on') return let current; let word = document.getElementById('gptInput').value; if(!word) return; if(current){ current.abort(); } console.log(word) current = GM_xmlhttpRequest({ method: "GET", url: "https://www.baidu.com/sugrec?&prod=pc&wd="+encodeURIComponent(word), responseType: "text", onload:(r) => { //console.log(r) if (r.status === 200) { //console.log(r); let dataList = JSON.parse(r.responseText).g; const su = document.querySelector('#suggestions'); su.innerHTML = ''; dataList && dataList.forEach(v => { const optionElement = document.createElement('option'); optionElement.value = v.q; optionElement.innerText = v.q; su.appendChild(optionElement); }); } } }); }) document.getElementById('updatePubkey').addEventListener('click', () => { const panel = document.getElementById('apiConfigPanel'); if (panel.style.display === 'none' || !panel.innerHTML) { renderApiConfigPanel(); Toast.info("请在下方直接编辑配置") } else { panel.style.display = 'none'; panel.innerHTML = ''; } }) document.getElementById('autoClick').addEventListener('click', () => { if(autoClick){ localStorage.removeItem("autoClick") autoClick = undefined; document.getElementById('autoClickStatus').textContent = '已关闭'; document.getElementById('autoClickStatus').classList.remove('sp-on'); Toast.error("自动点击已经关闭") }else{ localStorage.setItem("autoClick", "开启") autoClick = "开启"; document.getElementById('autoClickStatus').textContent = '已开启'; document.getElementById('autoClickStatus').classList.add('sp-on'); Toast.success("自动点击已经开启") } }) document.getElementById('autoTips').addEventListener('click', () => { if(autoTips === 'on'){ localStorage.setItem("autoTips", "off") autoTips = "off"; document.getElementById('autoTipsStatus').textContent = '已关闭'; document.getElementById('autoTipsStatus').classList.remove('sp-on'); Toast.error("自动提示已关") }else{ localStorage.setItem("autoTips", "on") autoTips = "on"; document.getElementById('autoTipsStatus').textContent = '已开启'; document.getElementById('autoTipsStatus').classList.add('sp-on'); Toast.success("自动提示已开启") } }) document.getElementById('darkTheme').addEventListener('click', () => { try{ document.getElementById("github-markdown-link").remove() document.getElementById("highlight-link").remove() }catch (e) { console.error(e) } if(darkTheme){ localStorage.removeItem("darkTheme") darkTheme = undefined; document.getElementById('darkThemeStatus').textContent = '已开启'; document.getElementById('darkThemeStatus').classList.add('sp-on'); Toast.success("暗黑已经开启") }else{ localStorage.setItem("darkTheme", "关闭") darkTheme = "关闭"; document.getElementById('darkThemeStatus').textContent = '已关闭'; document.getElementById('darkThemeStatus').classList.remove('sp-on'); Toast.error("暗黑已经关闭") } }) //朗读 document.getElementById('speakAnser').addEventListener('click', () => { let ans = document.querySelector("#gptAnswer"); if(!isPlayend){ Toast.success('已暂停播放!'); speakAudio.pause(); isPlayend = true; return; }else { Toast.warn('音频已停止,正在重新播放!') } if(ans){ // let speakText = encodeURIComponent(ans.innerText); let speakText = ans.innerText; //new sogou api // 弹出对话框询问用户是否同意 const result = confirm("是否启用外国口音朗读? 默认为中文口音。"); let dialect = "zh-CHS" if (result) { dialect = "en" console.log("英文朗读!"); } let f = JSON.stringify({ curTime: Date.now(), rate: "1", spokenDialect: dialect, text: speakText }) let sParam = CryptoJS.AES.encrypt(f.replace(/^"|"$/g, ""), CryptoJS.enc.Utf8.parse("76350b1840ff9832eb6244ac6d444366"), { "iv": CryptoJS.enc.Utf8.parse(atob("AAAAAAAAAAAAAAAAAAAAAA==") || "76350b1840ff9832eb6244ac6d444366"), "mode": CryptoJS.mode.CBC, "pad": CryptoJS.pad.Pkcs7 }).toString(); speakAudio = new Audio(`https://fanyi.sogou.com/openapi/external/getWebTTS?S-AppId=102356845&S-Param=${encodeURIComponent(sParam)}`); speakAudio.play() isPlayend = false; speakAudio.addEventListener("ended",function() { isPlayend = true; Toast.success('音频已播放完毕!'); }) } }) //原文切换 document.getElementById('rawAns').addEventListener('click', (ev) => { let ans = document.querySelector("#gptAnswer"); if(!rawAns) { Toast.error("原文无内容") return }; if(!isShowRaw){ ans.innerText = rawAns; isShowRaw = true; Toast.success("已为你显示原文") }else{ showAnserAndHighlightCodeStr(rawAns) isShowRaw = false; Toast.success("已为你显示非原文") } }) //中断回答 document.getElementById('stopAns').addEventListener('click', (ev) => { try{ if(abortXml){ abortXml.abort(); abortXml = undefined; }else { Toast.error("无法中断!") } }catch(ex){ console.error("中断失败:",ex) Toast.error("中断失败!") } }) //全屏 document.getElementById('fullScreen').addEventListener('click', (ev) => { try{ if(!isFullScreen){ document.getElementById("gptDiv").classList.add("fullScreen") isFullScreen = true; }else { document.getElementById("gptDiv").classList.remove("fullScreen") isFullScreen = false; } }catch(ex){ console.error("ex:",ex) Toast.error("未知异常!") } }) //隐藏 document.getElementById('hideGptDiv').addEventListener('click', (ev) => { try{ $("body").append(`
显示
`) $(".floating-button a").click(function() { $("#gptDiv").show(); $(".floating-button").remove() }); $("#gptDiv").hide(); }catch(ex){ console.error("ex:",ex) Toast.error("未知异常!") } }) //复制答案 document.getElementById('copyAns').addEventListener('click', (ev) => { let ans = document.querySelector("#gptAnswer"); if(isShowRaw){ GM_setClipboard(rawAns, "text"); }else{ let cps = document.querySelectorAll(".btn-pre-copy"); for (let cp of cps){ cp.innerText = '' } GM_setClipboard(ans.innerText, "text"); for (let cp of cps){ cp.innerText = '复制代码' } } Toast.success("复制成功!") }) document.getElementById('modeSelect').addEventListener('change', () => { const selectEl = document.getElementById('modeSelect'); const selectedValue = selectEl.options[selectEl.selectedIndex].value; localStorage.setItem('GPTMODE', selectedValue); renderApiConfigPanel(); Toast.success(`切换成功,当前线路:${selectedValue}`) }); let chatSetting = false; const settingsPanel = document.getElementById('settingsPanel'); document.getElementById('chatSetting').addEventListener('click', () => { chatSetting = !chatSetting; settingsPanel.classList.toggle('chatHide', !chatSetting); // 更新齿轮图标旋转状态 document.getElementById('chatSetting').classList.toggle('sp-active', chatSetting); if (chatSetting) { renderApiConfigPanel(); } }) } async function appendBox(append_case) { return new Promise((resolve, reject) => { creatBox().then((divE) => { let resetWidth = (width)=>{ try { if(width){ document.querySelector("#gptDiv").style.setProperty("width",width); return } document.querySelector("#gptDiv").style.setProperty("width", "100%") /*document.querySelector("#gptInput").setAttribute("class", "se-input adjust-input")*/ } catch (e) { console.error(e) } } switch (append_case) { case 0: //bing if (divE) { if(isMobile()){ //手机bing document.getElementById('b_results').prepend(divE) resetWidth(); }else{ document.getElementById('b_context').prepend(divE) } } break; case 1: //google if(isMobile()){ //手机google document.querySelector("div#msc").after(divE); resetWidth(); }else if (document.getElementsByClassName('TQc1id ')[0]) { document.getElementsByClassName('TQc1id ')[0].prepend(divE); } else { //other document.getElementById("rcnt").appendChild(divE); } break; case 2: //baidu if (document.getElementById('content_right')) { document.getElementById('content_right').prepend(divE) } break; case 3: //yandex if (document.getElementById('search-result-aside')) { document.getElementById('search-result-aside').prepend(divE) } break; case 4: //360 if(isMobile()){ //手机360 document.getElementById("search-box").appendChild(divE); resetWidth(); }else{ if (document.getElementById('side')) { document.getElementById('side').prepend(divE) } } break; case 5: //fsoufsou if(isMobile()){ //手机fsou let frow = document.querySelectorAll(".flex-row")[3] if (frow.children!==undefined ) { frow.children.item(0).prepend(divE) } resetWidth() }else{ let frow = document.querySelectorAll(".flex-row")[2] if (frow.children!==undefined && frow.children.length === 2) { frow.children.item(1).prepend(divE) } else { frow.innerHTML = frow.innerHTML + `
${divE.innerHTML}
` } } break; case 6: //手机百度 if (document.getElementById('page-bd')) { document.getElementById('page-bd').prepend(divE) //调整css resetWidth(); } break; case 7: //duckduckgo if(isMobile()){ //手机dockgo document.querySelector('form#search_form').after(divE) resetWidth(); }else{ if (document.querySelector('[data-area="sidebar"]')) { document.querySelector('[data-area="sidebar"]').prepend(divE) } } break; case 8: //sogou if(isMobile()){ //手机搜狗 document.querySelector('form#searchform').after(divE) resetWidth(); }else{ if (document.querySelector('div.right')) { document.querySelector('div.right').prepend(divE) } } break; case 9: //bilibili if (document.querySelector('div#danmukuBox')) { document.querySelector('div#danmukuBox').children.item(0).prepend(divE) resetWidth(); } break; case 10: //csdn let asideDiv = document.querySelector("aside.blog_container_aside div") if (asideDiv) { asideDiv.after(divE) let t = asideDiv.offsetTop + asideDiv.offsetHeight + 5; const screenHeight = window.screen.height; document.querySelector("#gptDiv").setAttribute("style", `position: fixed;top: ${t}px;left: 0px;z-index: 9999;width:410px;`) //滚动条 document.querySelector("#gptAnswer").setAttribute("style", `height: ${screenHeight/5}px;overflow-y:scroll`) } break; default: if (divE) { console.log(`啥情况${divE}`) } } }).catch((err) => { throw new Error(err) }).finally(()=>{ if(autoClick){ setTimeout(() => { document.getElementById("button_GPT").click(); //自动点击 }, 1500) } }) resolve("finished") }) } //焦点函数 function isBlur() { let myInput = document.getElementById('gptInput'); if (myInput === document.activeElement) { return 1 } else { return 0 } } function keyEvent() { document.onkeydown = function (e) { let keyNum = window.event ? e.keyCode : e.which; if (13 === keyNum) { if (isBlur()) { document.getElementById('button_GPT').click() } else { console.log("失焦不执行") } } } } function addBothStyle() { GM_addStyle(` .gpt-container { box-sizing: border-box; height: -webkit-min-content; height: min-content; width: 455px; margin-top: 12px; margin-bottom: 12px; border: 1px solid rgba(0,0,0,0.06); border-radius: 16px; overflow: hidden; padding: 18px; background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif; transition: box-shadow 0.3s; } .gpt-container:hover{ box-shadow: 0 4px 20px rgba(0,0,0,0.1); } #dot{ height: 4px; width: 4px; display: inline-block; border-radius: 2px; animation: dotting 2.4s infinite step-start; } @keyframes dotting { 25%{ box-shadow: 4px 0 0 #4e6ef2; } 50%{ box-shadow: 4px 0 0 #4e6ef2, 14px 0 0 #4e6ef2; } 75%{ box-shadow: 4px 0 0 #4e6ef2, 14px 0 0 #4e6ef2, 24px 0 0 #4e6ef2; } } pre{ overflow-x: auto; overflow-y: hidden; background: #f6f8fa; border-radius: 10px; padding: 14px 16px; margin: 8px 0; border: 1px solid rgba(0,0,0,0.04); font-size: 13px; line-height: 1.6; } pre::-webkit-scrollbar { height: 5px; } pre::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.12); border-radius: 10px; } #gptAnswer p{ margin: 6px 0; } #gptAnswer h1, #gptAnswer h2, #gptAnswer h3, #gptAnswer h4{ margin: 12px 0 6px; color: #1a1a1a; } #gptAnswer ul, #gptAnswer ol{ padding-left: 20px; } #gptAnswer li{ margin: 4px 0; } #gptAnswer code{ background: #f0f2f5; padding: 2px 6px; border-radius: 4px; font-size: 13px; color: #d63384; } #gptAnswer pre code{ background: transparent; padding: 0; color: inherit; } #gptAnswer blockquote{ border-left: 3px solid #4e6ef2; padding: 8px 12px; margin: 8px 0; background: #f0f4ff; border-radius: 0 8px 8px 0; color: #555; } #gptAnswer table{ border-collapse: collapse; width: 100%; margin: 8px 0; font-size: 13px; } #gptAnswer th, #gptAnswer td{ border: 1px solid #e8e8e8; padding: 8px 12px; text-align: left; } #gptAnswer th{ background: #f6f8fa; font-weight: 600; } #gptAnswer a{ color: #4e6ef2; text-decoration: none; } #gptAnswer a:hover{ text-decoration: underline; } #gptAnswer img{ max-width: 100%; border-radius: 8px; } .speak a{ display: inline-flex; align-items: center; gap: 3px; color: #909399; font-size: 12.5px; padding: 4px 8px; border-radius: 6px; transition: all 0.2s; } .speak a:hover{ background: rgba(78,110,242,0.06); color: #4e6ef2; } .speak a:hover svg path, .speak a:hover svg circle{ fill: #4e6ef2; } .gpt-loading-spinner{ width: 16px; height: 16px; border: 2px solid #e8e8e8; border-top: 2px solid #4e6ef2; border-radius: 50%; animation: gpt-spin 0.8s linear infinite; } @keyframes gpt-spin{ 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } /* ===== 设置面板 ===== */ #settingsPanel{ margin-top: 10px; border: 1px solid #ebedf0; border-radius: 12px; overflow: hidden; background: #fafbfc; animation: sp-slide 0.25s ease; } @keyframes sp-slide{ from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } } .sp-section{ padding: 10px 14px; border-bottom: 1px solid #f0f0f0; } .sp-section:last-child{ border-bottom: none; } .sp-section-title{ font-size: 11px; font-weight: 600; color: #999; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; } /* 线路选择 */ #gptStatus{ margin: 0; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; } .sp-hint{ color: #bbb; font-size: 11.5px; } /* 功能开关行 */ .sp-row{ display: flex; align-items: center; justify-content: space-between; padding: 5px 0; } .sp-row a{ display: inline-flex; align-items: center; gap: 6px; color: #333; font-size: 13px; padding: 5px 10px; border-radius: 8px; transition: all 0.2s; text-decoration: none; } .sp-row a:hover{ background: rgba(78,110,242,0.06); color: #4e6ef2; } .sp-status{ font-size: 11.5px; padding: 2px 10px; border-radius: 20px; background: #f0f0f0; color: #999; font-weight: 500; transition: all 0.2s; } .sp-status.sp-on{ background: #e8f5e9; color: #43a047; } /* API配置面板 */ #apiConfigPanel{ margin-top: 8px; padding: 10px 12px; background: #fff; border-radius: 8px; border: 1px solid #e8e8e8; } .api-config-row{ display: flex; align-items: center; margin-bottom: 8px; } .api-config-row:last-child{ margin-bottom: 0; } .api-config-label{ font-size: 12px; color: #666; min-width: 70px; flex-shrink: 0; } .api-config-input{ flex: 1; height: 28px; padding: 0 8px; border: 1px solid #e0e0e0; border-radius: 6px; font-size: 12px; color: #333; background: #fafbfc; outline: none; transition: border-color 0.2s; } .api-config-input:focus{ border-color: #4e6ef2; background: #fff; } .api-config-input::placeholder{ color: #ccc; } .api-config-hint{ font-size: 11px; color: #4e6ef2; margin-top: 6px; text-align: right; } .api-config-warn{ margin-top: 8px; padding: 8px 10px; background: #fff8e1; border: 1px solid #ffe082; border-radius: 6px; font-size: 11.5px; color: #8d6e00; line-height: 1.6; } .api-config-warn code{ background: rgba(0,0,0,0.06); padding: 1px 5px; border-radius: 3px; font-size: 11px; color: #c76c00; } /* 更新KEY行 */ #warn{ margin: 6px 0 0; display: flex; align-items: center; gap: 8px; } #warn a{ display: inline-flex; align-items: center; gap: 4px; color: #4e6ef2; font-size: 13px; padding: 4px 10px; border-radius: 8px; transition: all 0.2s; } #warn a:hover{ background: rgba(78,110,242,0.06); } /* 网站链接 */ .sp-links{ display: flex; flex-wrap: wrap; gap: 6px; } .sp-links a{ display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: 12px; text-decoration: none; border: 1px solid #e8e8e8; background: #fff; color: #555; transition: all 0.2s; } .sp-links a:hover{ border-color: #4e6ef2; color: #4e6ef2; background: #f0f4ff; transform: translateY(-1px); box-shadow: 0 2px 8px rgba(78,110,242,0.1); } .sp-footer-links{ display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; padding-top: 8px; border-top: 1px dashed #e8e8e8; } .sp-footer-links a{ display: inline-block; padding: 3px 10px; border-radius: 6px; font-size: 12px; text-decoration: none; color: #888; transition: all 0.2s; } .sp-footer-links a:hover{ color: #4e6ef2; background: rgba(78,110,242,0.04); } /* 齿轮旋转 */ #chatSetting.sp-active svg{ transform: rotate(90deg); } `); } function Uint8ArrayToString(fileData) { let dataString = ""; for (let i = 0; i < fileData.length; i++) { dataString += String.fromCharCode(fileData[i]); } return dataString; } function decodeUnicode(str) { str = str.replace(/\\/g, "%"); //转换中文 str = unescape(str); //将其他受影响的转换回原来 str = str.replace(/%/g, "\\"); //对网址的链接进行处理 str = str.replace(/\\/g, ""); return str; } (function (extension) { if (typeof showdown !== 'undefined') { // global (browser or node.js global) extension(showdown); } else if (typeof define === 'function' && define.amd) { // AMD define(['showdown'], extension); } else if (typeof exports === 'object') { // Node, CommonJS-like module.exports = extension(require('showdown')); } else { // showdown was not found so an error is thrown throw Error('Could not find showdown library'); } }(function (showdown) { // loading extension into showdown showdown.extension('myext', function () { return [ //to katex { type: 'output', filter: function (source, converter, options) { //debugger return katexTohtml(source); } }, // filter xss { type: 'output', filter: function (source, converter, options) { //debugger return source.replace(/ let req1 = await GM_fetch({ method: "GET", url: "https://xinghuo.xfyun.cn/chat", headers: { "origin":"https://xinghuo.xfyun.cn", "referer":"https://xinghuo.xfyun.cn/" } }) let r = req1.responseText; //console.log(r); let mainjs; try{ mainjs = /src="(\/static\/js\/main.*?.js)"/.exec(r)[1];//https://xinghuo.xfyun.cn/static/js/main.04f3ec36.js console.log("mainjs:",mainjs) }catch (e) { console.error(r) Toast.error("出错了,js获取失败") } if(mainjs){ console.log("https://xinghuo.xfyun.cn"+ mainjs.trim()) let req2 = await GM_fetch({ method: "GET", url: "https://xinghuo.xfyun.cn"+ mainjs.trim(), headers: { "origin":"https://xinghuo.xfyun.cn", "referer":"https://xinghuo.xfyun.cn/" } }) let rr = req2.responseText; console.log(rr.substring(0,100)) try{ const re = /appId:"(.*?)"/gi; let match; while ((match = re.exec(rr)) !== null) { console.log(match[1]); sp_appId = match[1]; } /*let index = rr.indexOf("appId"); if (index !== -1) { let sp_appId = rr.substring(index, index + 10); // 指定文本 }*/ console.log("sp_appId:",sp_appId) }catch (e) { console.error(e) Toast.error("出错了,sp_appId获取失败",) } } } /*setTimeout(()=>{ if(getGPTMode()==="SPARK"){ init_sp_appId() } })*/ async function init_sp_chatId() { //https://xinghuo.xfyun.cn/iflygpt/u/chat-list/v1/create-chat-list let req1 = await GM_fetch({ method: "POST", url: "https://xinghuo.xfyun.cn/iflygpt/u/chat-list/v1/create-chat-list", headers: { "accept": "application/json, text/plain, */*", "x-requested-with": "XMLHttpRequest", "origin":"https://xinghuo.xfyun.cn", "Content-Type":"application/json", "referer":"https://xinghuo.xfyun.cn/desk" }, data:"{}" }) let r = req1.responseText; try{ sp_chatId = JSON.parse(r).data.id; console.log("sp_chatId:",sp_chatId) }catch (e) { console.error(r) Toast.error("sp_chatId获取失败") } } setTimeout(()=>{ if(getGPTMode()==="SPARK"){ init_sp_chatId() } },500) async function get_sp_GtToken() { return new Promise(async (resolve, reject) => { //https://riskct.geetest.com/g2/api/v1/pre_load?client_type=h5&callback=geetest_时间戳 let timestamp = Date.now(); let req1 = await GM_fetch({ method: "GET", url: `https://riskct.geetest.com/g2/api/v1/pre_load?client_type=h5&callback=geetest_${timestamp}`, headers: { "accept": "*/*", "referer": "https://xinghuo.xfyun.cn/" } }) let r = req1.responseText; console.log(r); try { let rr = r.replace(`geetest_${timestamp}(`, ""); rr = rr.substring(0, rr.length - 1) console.log("rr", rr) let rj = JSON.parse(rr); console.log("rj:"); console.log(rj); //==== let config = { appId: sp_appId, js: rj.data.js, staticPath: rj.data.staticPath, gToken: rj.data.gToken } console.log("config") console.log(config) setTimeout(() => { initGeeGuard(config, (gd) => { console.log(gd) if (gd.data.gee_token) { sp_GtToken = gd.data.gee_token; resolve(sp_GtToken) }else{ reject("出错") } }) }, 500) } catch (e) { console.error(e) setTimeout(init_sp_chatId) reject("出错") } }) } //解码 function decodeSpark(src) { /*let rv = function(e) { return e.replace(/[^A-Za-z0-9\+\/]/g, "") }*/ let dv = function(e) { //return Buffer.from(e, "base64").toString("utf8") // 将 base64 编码的字符串转换为字节数组 const bytes = CryptoJS.enc.Base64.parse(e); // 将字节数组转换为 UTF-8 字符串 return bytes.toString(CryptoJS.enc.Utf8); }//等价BASE64解码 6KaB /*let fv = function(e) { return dv(function(e) { return rv(e.replace(/[-_]/g, (function(e) { return "-" == e ? "+" : "/" } ))) }(e)) };*/ return dv(src); } let spark_first = true; async function SPARK(){ showAnserAndHighlightCodeStr("请稍后,第一次切换到该线路需要刷新页面,该线路为官网线路,使用前确保已经登录[讯飞星火](https://xinghuo.xfyun.cn/)") if(!sp_chatId){ showAnserAndHighlightCodeStr("chatId为空,请重试。。。使用前确保已经登录[讯飞星火](https://xinghuo.xfyun.cn/)") init_sp_chatId() return } await get_sp_GtToken() console.log("sp_GtToken",sp_GtToken) //重命名 if(spark_first){ let req1 = await GM_fetch({ method: "POST", url: "https://xinghuo.xfyun.cn/iflygpt/u/chat-list/v1/rename-chat-list", headers: { "accept": "application/json, text/plain, */*", "x-requested-with": "XMLHttpRequest", "origin":"https://xinghuo.xfyun.cn", "Content-Type":"application/json", "referer":"https://xinghuo.xfyun.cn/desk" }, data:JSON.stringify({ "chatListId": sp_chatId, "chatListName": your_qus.substring(0,10) }) }) let r = req1.responseText; console.log("rename chat:",r) spark_first = false; } //提问 let sendData = `------WebKitFormBoundaryAS7tSr3osJng5Nxk\r\nContent-Disposition: form-data; name=\"fd\"\r\n\r\n${sp_fd}\r\n------WebKitFormBoundaryAS7tSr3osJng5Nxk\r\nContent-Disposition: form-data; name=\"clientType\"\r\n\r\n2\r\n------WebKitFormBoundaryAS7tSr3osJng5Nxk\r\nContent-Disposition: form-data; name=\"chatId\"\r\n\r\n${sp_chatId}\r\n------WebKitFormBoundaryAS7tSr3osJng5Nxk\r\nContent-Disposition: form-data; name=\"text\"\r\n\r\n${your_qus}\r\n------WebKitFormBoundaryAS7tSr3osJng5Nxk\r\nContent-Disposition: form-data; name=\"GtToken\"\r\n\r\n${sp_GtToken}\r\n------WebKitFormBoundaryAS7tSr3osJng5Nxk--\r\n`; GM_fetch({ method: 'POST', url: 'https://xinghuo.xfyun.cn/iflygpt-chat/u/chat_message/chat', headers: { "Content-Type": "multipart/form-data; boundary=----WebKitFormBoundaryAS7tSr3osJng5Nxk", "challenge": "undefined", "seccode": "", "validate": "undefined", "accept": "text/event-stream", "x-requested-with": "XMLHttpRequest", "origin":"https://xinghuo.xfyun.cn", "referer":"https://xinghuo.xfyun.cn/desk" }, responseType: "stream", data: sendData }).then((stream)=> { let reader = stream.response.getReader() let ans = [] //let de = [] reader.read().then(function processText({done, value}) { if (done) { console.log("===done==") //console.log(de) return } let responseItem = new TextDecoder("utf-8").decode(value) console.log(responseItem) responseItem.split("\n").forEach(item=>{ try { let ii = item.replace(/data:/gi,"").trim(); if(ii && ii !==""){ let chunk = decodeSpark(ii) //de.push(item.replace(/data:/gi,"").trim()) ans.push(chunk) showAnserAndHighlightCodeStr(ans.join("")) } }catch (ex){ console.error(item) } }) return reader.read().then(processText) },function (reason) { console.log(reason) Toast.error("未知错误!") }).catch((ex)=>{ console.log(ex) Toast.error("未知错误!") }) }) } //星火相关====end===== //腾讯混元 ----start----- let hunyuan_tUserId = ''; let hunyuan_count = 0; async function initHunyuanID() { if (location.href.includes("hunyuan.tencent.com") || location.href.includes("yuanbao.tencent.com")) { hunyuan_tUserId = getCookieValue(document.cookie,"hy_user"); GM_setValue("hunyuan_tUserId", hunyuan_tUserId) if(hunyuan_tUserId){ Toast.info(`hunyuan_tUserId获取成功:${hunyuan_tUserId}`) }else{ setTimeout(initHunyuanID, 5000) if(hunyuan_count < 3){ Toast.info(`hunyuan_tUserId获取失败,请再次刷新!`) } hunyuan_count++; } } else { hunyuan_tUserId = GM_getValue("hunyuan_tUserId") } } //setTimeout(initHunyuanID) let hunyuan_isfirst = true; let hunyuan_chatId ; async function initHunyuan(){ let req1 = await GM_fetch({ method: "POST", url: `https://hunyuan.tencent.com/api/generate/id`, headers: { "accept": "application/json, text/plain, */*", "origin":"https://hunyuan.tencent.com", "referer":`https://hunyuan.tencent.com/bot/chat`, "t-userid": hunyuan_tUserId, "x-requested-with": "XMLHttpRequest", "x-source": "web" }, data:null }) let r = req1.responseText; hunyuan_chatId = r; if(hunyuan_chatId) hunyuan_isfirst = false; console.error("hunyuan_chatId:",r) } /* fetch('https://yuanbao.tencent.com/api/chat/ca7b253f-a1a7-4e24-82ca-667cc0fbd98d', { method: 'POST', headers: { 'authority': 'yuanbao.tencent.com', 'accept': '*!/!*', 'accept-language': 'zh-CN,zh;q=0.9', 'cache-control': 'no-cache', 'chat_version': 'v1', 'content-type': 'text/plain;charset=UTF-8', 'cookie': '_ga=GA1.2.1033776250.1698727525; _gcl_au=1.1.484286265.1713846526; hy_source=web; sensorsdata2015jssdkcross=%7B%22distinct_id%22%3A%2229491242%22%2C%22first_id%22%3A%2218b840cf7219d8-044a60801af8344-1f7e152e-1440000-18b840cf7229ea%22%2C%22props%22%3A%7B%22%24latest_traffic_source_type%22%3A%22%E5%BC%95%E8%8D%90%E6%B5%81%E9%87%8F%22%7D%2C%22identities%22%3A%22eyIkaWRlbnRpdHlfY29va2llX2lkIjoiMThiODQwY2Y3MjE5ZDgtMDQ0YTYwODAxYWY4MzQ0LTFmN2UxNTJlLTE0NDAwMDAtMThiODQwY2Y3MjI5ZWEiLCIkaWRlbnRpdHlfbG9naW5faWQiOiIyOTQ5MTI0MiJ9%22%2C%22history_login_id%22%3A%7B%22name%22%3A%22%24identity_login_id%22%2C%22value%22%3A%2229491242%22%7D%2C%22%24device_id%22%3A%2218b840cf7219d8-044a60801af8344-1f7e152e-1440000-18b840cf7229ea%22%7D; hy_user=Bcw9KJaWemFaQ9iL; hy_token=bP9sp/yaXedZmIELMZz0hGSfpb6zW8UN7hFQeec8RFQIVAhWHCHLbFxq0tF5U6pO', 'origin': 'https://yuanbao.tencent.com', 'pragma': 'no-cache', 'referer': 'https://yuanbao.tencent.com/chat/naQivTmsDa', 'sec-ch-ua': '"Chromium";v="122", "Not(A:Brand";v="24", "Google Chrome";v="122"', 'sec-ch-ua-mobile': '?0', 'sec-ch-ua-platform': '"Windows"', 'sec-fetch-dest': 'empty', 'sec-fetch-mode': 'cors', 'sec-fetch-site': 'same-origin', 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/122.0.6261.95 Safari/537.36', 'x-requested-with': 'XMLHttpRequest', 'x-source': 'web' }, body: '{"model":"gpt_175B_0404","prompt":"你叫我什么","plugin":"Adaptive","displayPrompt":"你很牛吗","displayPromptType":1,"options":{},"multimedia":[],"agentId":"naQivTmsDa","version":"v2"}' }); */ async function Hunyuan(mtag) { showAnserAndHighlightCodeStr("请稍后...deepseek较慢。该线路为官网线路,请确保登录[元宝](https://yuanbao.tencent.com/chat)") if(!hunyuan_tUserId){ let req1 = await GM_fetch({ method: "GET", url: `https://yuanbao.tencent.com/api/getuserinfo`, headers: { "accept": "application/json, text/plain, */*", "origin":"https://yuanbao.tencent.com", "referer":`https://yuanbao.tencent.com` } }) let r = req1.responseText; hunyuan_tUserId = JSON.parse(r).userId console.warn("hunyuan_tUserId:",hunyuan_tUserId) if(!hunyuan_tUserId){ showAnserAndHighlightCodeStr("UserId获取失败,请登录[元宝](https://yuanbao.tencent.com/chat)") return } } if(hunyuan_isfirst && !hunyuan_chatId){ await initHunyuan() } let payload = JSON.stringify({ "model": "gpt_175B_0404", "prompt": your_qus, "displayPrompt": your_qus, "displayPromptType": 1, "plugin": "Adaptive", "isSkipHistory": false }) //deepseek联网 2025.02 if(mtag === 'deepseek'){ payload = JSON.stringify({ "model": "gpt_175B_0404", "prompt": your_qus, "displayPrompt": your_qus, "displayPromptType": 1, "plugin": "Adaptive", "isSkipHistory": false, "chatModelId": "deep_seek", "supportFunctions": [ "supportInternetSearch" ] }) } GM_fetch({ method: 'POST', url: `https://hunyuan.tencent.com/api/chat/${hunyuan_chatId}`, headers: { "origin":"https://hunyuan.tencent.com", "referer":`https://hunyuan.tencent.com/bot/chat`, "chat_version": "v1", "content-type": "text/plain;charset=UTF-8", "accept": "*/*", "t-userid": hunyuan_tUserId, "x-requested-with": "XMLHttpRequest", "x-source": "web" }, responseType: "stream", data: payload }).then((stream)=> { let reader = stream.response.getReader() let ans = [] reader.read().then(function processText({done, value}) { if (done) { console.log("===done==") //console.log(de) let result = ans.join(""); showAnserAndHighlightCodeStr(result) return } let responseItem = new TextDecoder("utf-8").decode(value) console.log(responseItem) responseItem.split("\n").forEach(item=>{ try { let ii = item.replace(/data:/gi,"").trim(); if(ii && ii !==""){ let chunk = '' //de.push(item.replace(/data:/gi,"").trim()) //add deepseek 2025.02 if(mtag === 'deepseek'){ chunk = JSON.parse(ii).content }else{ chunk = JSON.parse(ii).msg } ans.push(chunk) showAnserAndHighlightCodeStr(ans.join("")) } }catch (ex){ console.error(item) } }) return reader.read().then(processText) },function (reason) { Toast.error("未知错误!") console.log(reason) }).catch((ex)=>{ Toast.error("未知错误!") console.log(ex) }) }) } //腾讯混元 ----end----- //ChatGLM相关 ----start----- //https://chatglm.cn let chatgml_token; async function init_chatgml_token() { if (location.href.includes("chatglm.cn")) { chatgml_token = getCookieValue(document.cookie, "chatglm_token") GM_setValue("chatgml_token", chatgml_token) if (chatgml_token) { console.log(`chatgml_token获取成功:${chatgml_token}`) } else { console.log('invite_Token获取失败,请再次刷新') } } else if(getGPTMode() === 'ChatGLM' || getGPTMode() === 'ChatGLM4') { chatgml_token = await GM_getValue("chatgml_token") console.log("chatgml_token:", chatgml_token) } } setTimeout(()=>{ init_chatgml_token() setInterval(init_chatgml_token,5000) }) let chatgml_first = true; let chatgml_task_id; let chatgml_context_id; async function ChatGLM() { console.log("chatgml_token:",chatgml_token) showAnserAndHighlightCodeStr("请稍后...该线路为官网线路,使用该线路,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") if(!chatgml_token){ setTimeout(init_chatgml_token) showAnserAndHighlightCodeStr("init_chatgml_token为空,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") return } if (chatgml_first || !chatgml_task_id) { let req1 = await GM_fetch({ method: "POST", url: `https://chatglm.cn/chatglm/backend-api/v1/conversation`, headers: { "accept": "application/json, text/plain, */*", "authorization": `Bearer ${chatgml_token}`, "origin": "https://chatglm.cn", "content-type": "application/json;charset=UTF-8", "referer": `https://chatglm.cn/detail` }, data: JSON.stringify({ "prompt": your_qus }) }) let r = req1.responseText; let jsonObj = JSON.parse(r); try { chatgml_task_id = jsonObj.result.task_id; console.log("chatgml_task_id:",chatgml_task_id) chatgml_first = false; }catch (e) { showAnserAndHighlightCodeStr("task_id出错了,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") return } } let req1 = await GM_fetch({ method: "POST", url: `https://chatglm.cn/chatglm/backend-api/v1/stream_context`, headers: { "accept": "application/json, text/plain, */*", "authorization": `Bearer ${chatgml_token}`, "origin": "https://chatglm.cn", "content-type": "application/json;charset=UTF-8", "referer": `https://chatglm.cn/detail` }, data: JSON.stringify({ "prompt": your_qus, "seed": 69809, "max_tokens": 512, "conversation_task_id": chatgml_task_id, "retry": false, "retry_history_task_id": null }) }) let r = req1.responseText; let jsonObj = JSON.parse(r); try { chatgml_context_id = jsonObj.result.context_id; console.log("chatgml_context_id:",chatgml_task_id) }catch (e) { showAnserAndHighlightCodeStr("context_id出错了,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") return } GM_fetch({ method: "GET", url: `https://chatglm.cn/chatglm/backend-api/v1/stream?context_id=${chatgml_context_id}`, headers: { "accept": "text/event-stream", "origin": "https://chatglm.cn", "referer": `https://chatglm.cn/detail` }, responseType:"stream" }).then((stream)=> { let reader = stream.response.getReader() reader.read().then(function processText({done, value}) { if (done) { return } let responseItem = new TextDecoder("utf-8").decode(value) // console.error(responseItem) responseItem = responseItem.split("\n\n"); console.warn(responseItem) responseItem.forEach(item=>{ try { if(item && item.startsWith("event:add") || item.startsWith("event:finish")){ let ii = item.replace(/data:/gi,"") .replace(/event:add/gi,"") .replace(/event:finish/gi,"") .trim(); if(ii){ showAnserAndHighlightCodeStr(ii) } } }catch (ex){ console.error(item) } }) return reader.read().then(processText) },function (reason) { Toast.error("未知错误!") console.log(reason) }).catch((ex)=>{ Toast.error("未知错误!") console.log(ex) }) }) } let glm_conversation_id async function ChatGLM4(){ console.log("chatgml_token:",chatgml_token) showAnserAndHighlightCodeStr("请稍后...该线路为官网线路,使用该线路,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") if(!chatgml_token){ setTimeout(init_chatgml_token) showAnserAndHighlightCodeStr("init_chatgml_token为空,请确保已经登录并获取token,再刷新页面。[ChatGLM](https://chatglm.cn/)") return } GM_fetch({ method: "POST", url: `https://chatglm.cn/chatglm/backend-api/assistant/stream`, headers: { "authorization": `Bearer ${chatgml_token}`, "accept": "text/event-stream", "content-type": "application/json", "origin": "https://chatglm.cn", "referer": `https://chatglm.cn/main/alltoolsdetail` }, data:JSON.stringify({ "assistant_id": "65940acff94777010aa6b796", "conversation_id": glm_conversation_id ? glm_conversation_id : "", "meta_data": { "mention_conversation_id": "", "is_test": false, "input_question_type": "xxxx", "channel": "", "draft_id": "" }, "messages": [ { "role": "user", "content": [ { "type": "text", "text": your_qus } ] } ] }), responseType:"stream" }).then((stream)=> { let reader = stream.response.getReader() let res = [] reader.read().then(function processText({done, value}) { if (done) { return } let responseItem = new TextDecoder("utf-8").decode(value) //console.error(responseItem) responseItem = responseItem.split("\n\n"); console.warn(responseItem) if(responseItem.length >= 2 && responseItem[responseItem.length - 2].includes("finish")){ responseItem.forEach(item=>{ try { let resJson = JSON.parse(item.replace(/event:message\ndata:/gi,"")) let part = resJson.parts[0].content[0].text if(resJson.parts[0].status == 'finish'){ res.push(part) showAnserAndHighlightCodeStr(res.join("")) }else if (resJson.parts[0].status == 'init'){ showAnserAndHighlightCodeStr(part) } if(resJson.conversation_id){ glm_conversation_id = resJson.conversation_id } }catch (ex){ console.error(item) } }) } return reader.read().then(processText) },function (reason) { Toast.error("未知错误!") console.log(reason) }).catch((ex)=>{ Toast.error("未知错误!") console.log(ex) }) }) } //ChatGLM相关 ----start----- //智谱AI let zhipuToken = '4056fc44f1474c1e85e976577f930e40.O6WKndzKWBjQJWcA'; let zhipuPrompt = [] let zhipu_apiKey = localStorage.getItem("ZhipuapiKey") function base64UrlEncode(str) { let encodedSource = CryptoJS.enc.Base64.stringify(str); const reg = new RegExp('/', 'g'); encodedSource = encodedSource.replace(/=+$/,'').replace(/\+/g,'-').replace(reg,'_'); return encodedSource; } function generate_token(apikey, exp_seconds) { const [id, secretKey] = apikey.split("."); const payload = { "api_key": id, "exp": Date.now() + exp_seconds * 1000, "timestamp": Date.now(), // "exp": 1687878553567, // "timestamp": 1687877553567 }; const encodedHeader = base64UrlEncode(CryptoJS.enc.Utf8.parse(JSON.stringify({ alg: 'HS256', sign_type: 'SIGN', typ: "JWT"}))); const encodedPayload = base64UrlEncode(CryptoJS.enc.Utf8.parse(JSON.stringify(payload))); const signature = CryptoJS.HmacSHA256(encodedHeader + '.' + encodedPayload, secretKey); console.log(signature) //const encodedSignature = window.btoa(signature); const jwt = encodedHeader + '.' + encodedPayload + '.' + base64UrlEncode(signature); console.log(jwt); return jwt; } function ZhipuAI(){ showAnserAndHighlightCodeStr("请稍后。未申请key的,请前往[智谱AI](https://open.bigmodel.cn/usercenter/apikeys)申请,然后点击设置里的更新key") if(!localStorage.getItem("ZhipuapiKey")){ showAnserAndHighlightCodeStr("apikey不存在。请前往[智谱AI](https://open.bigmodel.cn/usercenter/apikeys)申请,然后点击设置里的更新key") return } zhipu_apiKey = zhipu_apiKey || localStorage.getItem("ZhipuapiKey"); addMessageChain(zhipuPrompt, {"role": "user", "content": your_qus} , 10) GM_fetch({ method: "POST", url: `https://open.bigmodel.cn/api/paas/v3/model-api/chatglm_std/sse-invoke`, headers: { "accept": "text/event-stream", "Content-Type":"application/json", "Authorization": generate_token(zhipu_apiKey, 1000) // "Authorization": 'eyJhbGciOiJIUzI1NiIsInNpZ25fdHlwZSI6IlNJR04iLCJ0eXAiOiJKV1QifQ.eyJhcGlfa2V5IjoiZjM3ZDVlMjFhZDk1NGJhOTM0NmYyOTgwMTgzNDJiMjciLCJleHAiOjE2ODc4Nzg1NTM1NjcsInRpbWVzdGFtcCI6MTY4Nzg3NzU1MzU2N30.e8SMjA0vBaUxXB-WrViFa0-C0qVLechNV5L5s2WoF8c' }, data:JSON.stringify({ model:"chatglm_std", prompt : zhipuPrompt, temperature: 0.95, top_p: 0.7, incremental: true }), responseType:"stream" }).then((stream)=> { let reader = stream.response.getReader() let ans = []; reader.read().then(function processText({done, value}) { if (done) { if(ans.length > 0){ addMessageChain(zhipuPrompt, {"role": "assistant", "content": ans.join("")} , 10) } return } let responseItem = new TextDecoder("utf-8").decode(value) console.error(responseItem) responseItem = responseItem.split("\n"); console.warn(responseItem) responseItem.forEach(item=>{ try { if(item && item.startsWith("data:")){ let ii = item.replace(/data:/gi,"") if(ii){ ans.push(ii) showAnserAndHighlightCodeStr(ans.join("")) } } }catch (ex){ console.error(item) } }) return reader.read().then(processText) },function (reason) { Toast.error("未知错误!") console.log(reason) }).catch((ex)=>{ Toast.error("未知错误!") console.log(ex) }) }) } //360智脑 -------start------ let conversation_id; async function Zhinao360(){ showAnserAndHighlightCodeStr("请稍后...该线路为官网线路,使用该线路,请确保已经登录[360智脑](https://chat.360.cn/)") const sendData = JSON.stringify({ "prompt": your_qus, "conversation_id": conversation_id || "", "source_type": "prophet_web", "role": "00000001", "is_regenerate": false, "is_so": false }); console.log(conversation_id) GM_fetch({ method: "POST", url: `https://chat.360.cn/backend-api/api/common/chat`, headers: { "accept": "text/event-stream", "origin": "https://chat.360.cn", "referer": `https://chat.360.cn/index`, "content-type": "application/json", }, data: sendData, responseType:"stream" }).then((stream)=> { let reader = stream.response.getReader() let result = [] reader.read().then(function processText({done, value}) { if (done) { return } let responseItem = new TextDecoder("utf-8").decode(value) // console.error(responseItem) console.warn(responseItem) if(responseItem){ responseItem.split("\n").forEach(item=>{ try{ if(item.startsWith("data: CONVERSATIONID####")){ conversation_id = item.replace(/data: CONVERSATIONID####/gi,"") }else if(item.startsWith("data: MESSAGEID####")){ }else if(item.startsWith("data")){ let i = item.replace(/data: /gi,"") if(i){ result.push(i) }else{ result.push("\n") } } }catch (e) {} }) showAnserAndHighlightCodeStr(result.join("")) } return reader.read().then(processText) },function (reason) { console.log(reason) Toast.error("未知错误!") }).catch((ex)=>{ Toast.error("未知错误!") console.log(ex) }) }) } //360智脑 -------end------ async function MixerBox() { GM_fetch({ method: "POST", url: `https://chatai.mixerbox.com/api/chat/stream`, headers: { "Referer": "https://chatai.mixerbox.com/chat", "origin": "https://chatai.mixerbox.com", "accept": "*/*", "content-type": "application/json", "user-agent": "Mozilla/5.0 (Android 12; Mobile; rv:107.0) Gecko/107.0 Firefox/107.0" }, data:JSON.stringify({ "prompt": [ { "role": "user", "content": your_qus } ], "lang": "zh", "model": "gpt-3.5-turbo", "plugins": [], "pluginSets": [], "getRecommendQuestions": true, "isSummarize": false, "webVersion": "1.4.5", "userAgent": "Mozilla/5.0 (Android 12; Mobile; rv:107.0) Gecko/107.0 Firefox/107.0", "isExtension": false }), responseType:"stream" }).then((stream)=>{ let result = [] const reader = stream.response.getReader(); reader.read().then(function processText({done, value}) { if (done) { return; } try { let d = new TextDecoder("utf8").decode(new Uint8Array(value)); console.warn(d) d.split("\n").forEach(item=>{ try { if(item.startsWith("data")){ result.push(item.replace(/data:/gi,"")) } }catch (ex){ } }) showAnserAndHighlightCodeStr(result.join(""). replace(/\[space\]/gi," "). replace(/\[NEWLINE\]/gi,"\n"). replace(/message_donedone/gi,"\n"). replace(/\[DONE\]/gi,"\n")) } catch (e) { console.log(e) } return reader.read().then(processText); }); },reason => { console.log(reason) Toast.error("未知错误!") }).catch((ex)=>{ console.log(ex) Toast.error("未知错误!") }) } let minimax_group_id = localStorage.getItem("minimax_group_id")//"172531245..."; let minimax_api_key = localStorage.getItem("minimax_api_key")// "eyJhbGciOi..... let minimax_messageChain = []; async function miniMax() { if(!minimax_group_id || !minimax_api_key){ showAnserAndHighlightCodeStr("group_id或api_key不存在,请到[https://api.minimax.chat/](https://api.minimax.chat/)注册,申请。然后点击 设置-》更新秘钥") } addMessageChain(minimax_messageChain, { "sender_type": "USER", "sender_name": "用户", "text": your_qus },10) let sendData = { "model": "abab5.5-chat", "tokens_to_generate": 1024, "temperature": 0.9, "top_p": 0.95, "stream": false, "reply_constraints": { "sender_type": "BOT", "sender_name": "MM智能助理" }, "sample_messages": [], "plugins": [], "messages": minimax_messageChain, "bot_setting": [ { "bot_name": "MM智能助理", "content": "MM智能助理是一款由MiniMax自研的,没有调用其他产品的接口的大型语言模型。MiniMax是一家中国科技公司,一直致力于进行大模型相关的研究。" } ] } GM_fetch({ method: "POST", url:`https://api.minimax.chat/v1/text/chatcompletion_pro?GroupId=${minimax_group_id}`, headers: { "Content-Type": "application/json", "Authorization": `Bearer ${minimax_api_key}`, }, data: JSON.stringify(sendData), responseType:"stream" }).then((stream)=>{ let result = [] const reader = stream.response.getReader(); reader.read().then(function processText({done, value}) { if (done) { addMessageChain(minimax_messageChain,{ "sender_type": "BOT", "sender_name": "MM智能助理", "text": result.join("") },10) return; } try { let d = new TextDecoder("utf8").decode(new Uint8Array(value)); console.warn(d) result.push(JSON.parse(d).reply) showAnserAndHighlightCodeStr(result.join("")) } catch (e) { console.log(e) } return reader.read().then(processText); }); },reason => { console.log(reason) Toast.error("未知错误!") }).catch((ex)=>{ console.log(ex) Toast.error("未知错误!") }) } //https://ai1.chagpt.fun/ function CVEOY() { let baseURL = "https://free-api.cveoy.top/"; GM_xmlhttpRequest({ method: "POST", url: baseURL + "v3/completions", headers: { "Content-Type": "application/json", "origin": "https://ai1.chagpt.fun", "Referer": baseURL }, data: JSON.stringify({ prompt: your_qus }), onloadstart: (stream) => { let result = []; const reader = stream.response.getReader(); reader.read().then(function processText({done, value}) { if (done) { try { let finalResult = result.join("") console.log(finalResult) showAnserAndHighlightCodeStr(finalResult) } catch (e) { console.log(e) Toast.error("未知错误!") } return; } try { let d = new TextDecoder("utf8").decode(new Uint8Array(value)); if(d.match(/wxgpt@qq.com/gi)){ d = d.replace(/wxgpt@qq.com/gi,"") } result.push(d); console.log(d) showAnserAndHighlightCodeStr(result.join("")) } catch (e) { console.log(e) } return reader.read().then(processText); }); }, responseType: "stream", onerror: function (err) { console.log(err) Toast.error("未知错误!") } }); } //https://s.aifree.site/ let messageChain_aifree = [] function AIFREE() { let now = Date.now(); let Baseurl = `https://am.aifree.site/` generateSignatureWithPkey({ t:now, m: your_qus || "", pkey: {}.PUBLIC_SECRET_KEY || "" }).then(sign => { addMessageChain(messageChain_aifree, {role: "user", content: your_qus})//连续话 console.log(sign) GM_fetch({ method: "POST", url: Baseurl + "api/generate", headers: { "Content-Type": "text/plain;charset=UTF-8", "Referer": Baseurl, "accept": "application/json, text/plain, */*" }, data: JSON.stringify({ messages: messageChain_aifree, time: now, pass: null, sign: sign }), responseType: "stream" }).then((stream) => { let result = []; const reader = stream.response.getReader(); reader.read().then(function processText({done, value}) { if (done) { let finalResult = result.join("") try { console.log(finalResult) addMessageChain(messageChain_aifree, { role: "assistant", content: finalResult }) showAnserAndHighlightCodeStr(finalResult) if(finalResult.includes("Invalid signature") || finalResult.includes("exceeded your current")){ Toast.error(`无效或过期,请到设置更新key`) } } catch (e) { console.log(e) } return; } try { let d = new TextDecoder("utf8").decode(new Uint8Array(value)); result.push(d) showAnserAndHighlightCodeStr(result.join("")) } catch (e) { console.log(e) } return reader.read().then(processText); }); },function (reason) { console.log(reason) Toast.error("未知错误!" + reason.message) }).catch((ex)=>{ console.log(ex) Toast.error("未知错误!" + ex.message) }); }); } function TDCHAT(){ abortXml = GM_xmlhttpRequest({ method: "POST", url: "http://7shi.zw7.lol/chat.php", headers: { "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8", "Referer": "http://7shi.zw7.lol/", "accept": "application/json, text/plain, */*" }, data: `id=3.5&key=&role=&title=&text=${encodeURIComponent(your_qus).replace(/%/g, '‰')}&length=${your_qus.length}&stream=1`, onloadstart: (stream) => { let result = []; let finalResult = []; const reader = stream.response.getReader(); reader.read().then(function processText({done, value}) { if (done) { finalResult = result.join("") showAnserAndHighlightCodeStr(finalResult.replace(/tdchat/gi,"")) return; } try { let d = new TextDecoder("utf8").decode(new Uint8Array(value)); console.log("raw:",d) let dd = d.replace(/data: /g, "").split("\n\n") console.log("dd:",dd) dd.forEach(item=>{ try { let delta = JSON.parse(item).choices[0].delta.content result.push(delta) showAnserAndHighlightCodeStr(result.join("").replace(/tdchat/gi,"")) }catch (e) { } }) } catch (e) { console.log(e) } return reader.read().then(processText); }); }, responseType: "stream", onerror: function (err) { console.log(err) Toast.error("未知错误!" + err.message) } }) } //默认设置 setTimeout(()=>{ if(localStorage.getItem('GPTMODE')){ const selectEl = document.getElementById('modeSelect'); let optionElements = selectEl.querySelectorAll("option"); for (let op in optionElements) { if(optionElements[op].value === localStorage.getItem('GPTMODE')){ optionElements[op].setAttribute("selected", "selected"); break; } } } if(localStorage.getItem('gpt_font_size')){ document.querySelector("#gptDiv").style.fontSize = localStorage.getItem('gpt_font_size'); } //禁用历史 if(localStorage.getItem('history_disable')){ let dis = localStorage.getItem('history_disable'); history_disable = (dis === 'true' ? true : false); } },1000) })();