ChatGPT-Magic

这是一个最新的ai交互功能chatgpt,与搜索引擎融合的油猴插件,通过这个插件可以实现左边查看搜索引擎搜索结果,右边查看ai方给的答案方便日常工作优化搜索引擎。

// ==UserScript==
// @name         ChatGPT-Magic
// @namespace    ChatGPT-Magic
// @version      0.5
// @license MIT
// @description  这是一个最新的ai交互功能chatgpt,与搜索引擎融合的油猴插件,通过这个插件可以实现左边查看搜索引擎搜索结果,右边查看ai方给的答案方便日常工作优化搜索引擎。
// @author       //作者微信号wxid_qo94xu9bwvwo22
// @match        *://*.baidu.com/*
// @match        *://*.csdn.net/*
// @match        *://*.google.com/*
// @match        *://*.bing.com/*
// @icon         

// @grant        none
// ==/UserScript==

(function () {
    'use strict';
    // 节流函数
    function throttle(fn, delay) {
        // last为上一次触发回调的时间
        let last = 0;
        // 将throttle处理结果当作函数返回
        return function () {
            // 保留调用时的this上下文
            let context = this;
            // 保留调用时传入的参数
            let args = arguments;
            // 获取当前时间
            let now = +new Date();
            // 判断上次触发的时间和当前的时间差是否小于时间间隔的阈值
            if (now - last >= delay) {
                // 将this和参数传入函数执行
                fn.apply(context, args);
                // 更新时间
                last = now;
            }
        }
    }
    //xss注入转义函数 防范xss
    function htmlEncodeByRegExp  (str){  
        var s = "";
        if(str.length == 0) return "";
        s = str.replace(/&/g,"&");
        s = s.replace(/</g,"&lt;");
        s = s.replace(/>/g,"&gt;");
        s = s.replace(/ /g,"&nbsp;");
        s = s.replace(/\'/g,"&#39;");
        s = s.replace(/\"/g,"&quot;");
        return s;  
}


    // Your code here...
    var su, kw

    window.onload = function () {
        console.log("欢迎使用chatgpt功能")
        var href = window.location.href;
        if (href.indexOf("https://www.baidu.com") != -1) {
            su = document.querySelector("#su")
            kw = document.querySelector("#kw")
        }
        if (href.indexOf("csdn") != -1) {
            su = document.querySelector("#search")
            kw = document.querySelector("#keyword")
            console.log(su, kw)
        }
        if (href.indexOf("google") != -1) {


            su = document.querySelector(".Tg7LZd")
            kw = document.querySelector("input")
            console.log(su, kw)


        }
        if (href.indexOf("bing") != -1) {


            su = document.querySelector("#sb_form_q")
            kw = document.querySelector("#sb_form_go")
            console.log(su, kw)


        }

        su.addEventListener("click", throttle(() => {
            let warps = document.querySelectorAll("#warp")
            console.log(warps)
            if (warps.length != 0) {
                warps[0].remove()
            }

            var box = `
    <div id="warp" class="warp">
        <div class="content">
            <div id="gbt_title" class ="gbt_title" style="padding-top:20px;margin-bottom:0px;font-weight: 800;text-align: center">Chatgpt-AI插件</div>
            <span style="word-wrap:break-word;word-break:break-all;" class="content_val">chatgpt插件已经触发,稍等片刻即可获得相应答案~</span>
            <img id="chatgpt_img" style="width:100%;margin-top:20px;border-radius:20px"  src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fc-ssl.duitang.com%2Fuploads%2Fblog%2F202107%2F19%2F20210719182507_fbc17.thumb.1000_0.gif&refer=http%3A%2F%2Fc-ssl.duitang.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1673322367&t=ab3d1b28dfc19845790520826340af93" alt="">

        </div>
    </div>
    `
            document.body.insertAdjacentHTML('afterbegin', box);
            let warp = document.querySelector("#warp")
            let gbt_title = document.querySelector("#gbt_title")
            let flag = false;
            let disX, disY;
            let bound;
            // flag 设为 true 表示按下鼠标,并记录鼠标离盒子左上角的相对距离
            function leftDown(e) {
                if (e.button === 0) {   // 按下鼠标左键
                    flag = true;
                    bound = warp.getBoundingClientRect();

                    disX = e.clientX - bound.left;
                    disY = e.clientY - bound.top;
                }
            }

            function drag(e) {
                if (flag) {
                    let top = e.clientY - disY;
                    let left = e.clientX - disX;

                    // 处理边界条件
                    if (top < 0) top = 0;
                    if (left < 0) left = 0;
                    // if (top + bound.height > document.body.clientHeight) {
                    //     top = document.body.clientHeight - bound.height;
                    //     console.log(top,"top")
                    // }
                    if (left + bound.width > document.body.clientWidth) {
                        left = document.body.clientWidth - bound.width;
                    }

                    warp.style.top = `${top}px`;
                    warp.style.left = `${left}px`;
                }
            }

            function leftUp(e) {
                if (e.button === 0) {
                    flag = false;
                }
            }

            gbt_title.addEventListener('mousedown', leftDown);
            document.addEventListener('mousemove', drag);
            document.addEventListener('mouseup', leftUp);
            console.log(warp)
            gbt_title.style.padding = "10px"
            warp.style.position = "absolute"
            warp.style.borderRadius = "20px"
            warp.style.margin = "50px 20px"
            warp.style.border = "1px solid #96C2F1"
            warp.style.backgroundColor = "rgba(247, 247, 247)"

            warp.style.paddingBottom = "20px"
            warp.style.right = "20px"
            warp.style.width = "15%"
            warp.style.zIndex = "999"
            let content = document.querySelector(".content")
  
            content.style.padding = "10px"
            content.style.color = "rgba(112, 112, 112)"
            let content_val = document.querySelector(".content_val")
            let chatgpt_img = document.querySelector("#chatgpt_img")
            content_val.style.paddingRight = "20px"
            $.ajax({
                "url": "https://www.miku39.fun/openai/get_answer", "data": JSON.stringify({
                    "prompt": kw.value,
                }),
                "type": "POST",
                contentType: 'application/json; charset=utf-8',
                dataType: 'json',
                success: function (result) {
                        console.log(result.msg)
                        //console.log(content_val)
                        content_val.innerHTML = ""
                        chatgpt_img.remove()
                        content_val.innerHTML = htmlEncodeByRegExp(result.msg)
                        console.log(content_val)
                },
                error: function (XMLHttpRequest, textStatus, errorThrown) {
                    console.log(XMLHttpRequest.status, XMLHttpRequest.statusText, XMLHttpRequest.responseText); // 获取状态码
                    chatgpt_img.remove()
                    if (XMLHttpRequest.status == 0) {
                        content_val.innerHTML = "服务器出错请联系开发者~"//作者微信号wxid_qo94xu9bwvwo22,有问题请联系
                    }
             
                }
            })

        }, 1000))
    }




})();