杏坛豆瓣书籍自动检索工具

已有的书籍名称通过豆瓣API获取信息,然后填充至各个信息区

// ==UserScript==
// @name         杏坛豆瓣书籍自动检索工具
// @namespace    zhoubanxian
// @version      4.1
// @description  已有的书籍名称通过豆瓣API获取信息,然后填充至各个信息区
// @author       周半仙
// @match        https://xingtan.one/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=xingtan.one
// @grant        unsafeWindow
// @grant        GM_xmlhttpRequest
// @grant        GM_download
// @grant        GM_setValue
// @grant        GM_getValue
// ==/UserScript==

(function () {
    'use strict';
    // 获取当前页面的链接
    var currentUrl = window.location.href;
    // 判断链接是否包含 "details.php"
    if (currentUrl.includes("details.php")) {
        // 匹配给定的 XPath 表达式
        var xpathExpression = '/html/body/table[2]/tbody/tr[2]/td/div/font/table[1]/tbody/tr[1]/td[2]/a[1]';
        var result = document.evaluate(xpathExpression, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null);

        // 获取匹配的元素
        var element = result.singleNodeValue;

        if (element) {
            // 获取元素的文本内容
            var text = element.textContent;

            // 提取倒数第二个 `.` 到倒数第三个 `.` 之间的内容
            var regex = /(?:\.[^.]+)(\.)([^.]+)(?:\.[^.]+)$/; // 正则表达式
            var match = regex.exec(text);

            if (match && match[2]) {
                var extractedText = match[2];
                // 匹配给定的 XPath 表达式
                var xpathExpression = '/html/body/table[2]/tbody/tr[2]/td/div/font/table[1]/tbody/tr[4]/td[2]/a[2]';
                var result = document.evaluate(xpathExpression, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null);

                // 获取匹配的链接元素
                var linkElement = result.singleNodeValue;

                if (linkElement) {
                // 获取链接的 href 属性值
                var link = linkElement.getAttribute('href');

                // 在链接后面追加参数
                var updatedLink = link + '&type='+extractedText;

                // 更新链接的 href 属性
                linkElement.setAttribute('href', updatedLink);
                }
            }
        }
    }
    // 判断链接是否包含 "edit.php",判断是否是编辑页面
    if (currentUrl.includes("edit.php")) {
        const xtXpath = "/html/body/table[2]/tbody/tr[2]/td/div/div[2]";
        // 获取目标元素
        const targetElement = document.evaluate(xtXpath, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
        // 创建并插入<div>元素
        const divElement = document.createElement('div');
        targetElement.parentNode.insertBefore(divElement, targetElement.nextSibling);
        divElement.style = 'width:58%;background-color:#f1939c;font-size:15px'
        // 获取编辑页面标题的值
        const titleXpath = "/html/body/table[2]/tbody/tr[2]/td/div/form/font/font/b/table/tbody/tr[2]/td[2]/input";
        // 使用XPath获取元素
        const element = document.evaluate(titleXpath, document, null, XPathResult.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
        // 检查元素是否存在并输出值
        if (element) {
            if (document.querySelector('input[name="autor"]').value != '本资源由LM-AUTO-BOT机器人自动发布,请及时修改资料') {
                divElement.innerHTML += '当前种子已被编辑过,不再执行自动检索脚本....<br>';
                return 0
            }
            // console.log("获取到标题是: ", element.value);
            divElement.innerHTML += '温馨提示:<br>请<a style="color:red" href="https://xingtan.one/forums.php?action=viewtopic&forumid=23&topicid=43" target="\_blank">点击此处</a>了解完整的编辑规则后再使用脚本<br>否则只是给审核人员添加负担' + '<br><hr>';
            divElement.innerHTML += '开始搜索:' + '<br>';
            const url = `https://api.douban.com/v2/book/search?q=${encodeURIComponent(element.value)}&apikey=0ac44ae016490db2204ce0a042db2916`;
            var values = [];
            GM_xmlhttpRequest({
                method: "GET",
                url: url,
                onload: function (response) {
                    var data = JSON.parse(response.responseText); // 解析返回值为JSON格式
                    var books = data.books; // 获取books数据数组
                    localStorage.setItem('books', JSON.stringify(books));
                    if(books.length == 0){
                        divElement.innerHTML += '暂未检索到相关资源' + '<br>';
                    }
                    // 循环遍历books数据,只显示前五条,然后自动匹配
                    for (var i = 0; i < 8; i++) {
                        var book = books[i]; // 获取当前书籍数据
                        var author = ''; // 获取作者
                        for (var j = 0; j < book.author.length; j++) {
                            author += book.author[j] +'&';
                        }
                        author = author.slice(0, -1);
                        var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
                        var publisher = book.publisher; // 获取出版社
                        var value = "\n"
                        if (author) {
                            value += "作者: " + author + "\n";
                        }
                        if (publisher) {
                            value += "出版社: " + publisher + "\n";
                        }
                        if (book.subtitle) {
                            value += "副标题: " + book.subtitle + "\n";
                        }
                        if (pubdate) {
                            value += "出版年: " + pubdate + "\n";
                        }
                        if (book.pages) {
                            value += "页数: " + book.pages + "\n";
                        }
                        if (book.price) {
                            value += "定价: " + book.price + "\n";
                        }
                        if (book.binding) {
                            value += "装帧: " + book.binding + "\n";
                        }
                        if (book.isbn13) {
                            value += "ISBN: " + book.isbn13 + "\n\n";
                        }
                        if (book.summary) {
                            value += "内容简介: \n    " + book.summary + "\n\n";
                        }
                        if (book.author_intro) {
                            value += "作者简介: \n    " + book.author_intro + "\n";
                        }
                        values.push(value)
                        divElement.innerHTML += '<a style="color:yellow" onclick="insert(' + i +')">填充对应信息</a><a style="color:green" target="\_blank" href=' + "https://book.douban.com/subject/" + book.id + '>第' + (i + 1) + "条:" + book.title + '[查看对应书籍]</a><br>';
                    }
                    localStorage.setItem('values', JSON.stringify(values));
                    // 备用手动检索模式
                    // for (var i = 0; i < 5; i++) {
                    //     var book = books[i]; // 获取当前书籍数据
                    //     var author = book.author[0]; // 获取作者
                    //     var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
                    //     var publisher = book.publisher; // 获取出版社
                    //     var result = "作者:" + author +"/" + publisher +"/" + pubdate +"【对应格式】";
                    //     console.log(book.title)
                    //     console.log(result); // 输出拼接后的结果
                    //     console.log("https://book.douban.com/subject/"+book.id) //输出豆瓣连接
                    // }
                },
                onerror: function (error) {

                }
            });
        } else {
            console.log("找不到元素");
        }
    }
    // 创建一个 <script> 元素
    var script = document.createElement('script');

    // 定义要插入的函数
    script.textContent = `
        function insert(id,value) {
            var urlString = window.location.href;
            // 创建 URL 对象
            var url = new URL(urlString);
            // 获取链接中的 type 参数的值
            var type = url.searchParams.get('type');
            book = JSON.parse(localStorage.getItem('books'))[id];
            var author = ''; // 获取作者
            for (var j = 0; j < book.author.length; j++) {
                author += book.author[j] +'&';
            }
            author = author.slice(0, -1);
            var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
            var publisher = book.publisher; // 获取出版社
            var small_descr = "作者:" + author +"/" + publisher +"/" + pubdate +"【"+type+"】";
            var pic_url = ""
            values = JSON.parse(localStorage.getItem('values'))[id]
            alert("请等待一会,其中图片自动上传比较慢") 
            uploadImg("https://images.weserv.nl/?url=" + book.images.large).then(imageUrl => {
                pic_url = imageUrl  
                values = JSON.parse(localStorage.getItem('values'))[id]  
                values = "[img]"+pic_url+"["+"/"+"img]"+ values;  
                document.querySelector('textarea[name="descr"]').value = values;
            }).catch(error => {  
                console.error('图片上传或处理过程中发生错误:', error);
                document.querySelector('textarea[name="descr"]').value = values;
            });
            document.querySelector('input[name="autor"]').value =author?author:"作者信息未获取";
            document.querySelector('input[name="publisher"]').value = publisher?publisher:"出版社信息未获取";
            document.querySelector('input[name="year"]').value = pubdate?pubdate:"年份信息未获取";
            document.querySelector('input[name="ftype"]').value = "请自行填写";
            document.querySelector('input[name="isbn"]').value = book.isbn13?book.isbn13:"无";
            document.querySelector('input[name="pt_gen"]').value = "https://book.douban.com/subject/" + book.id;

            
        }
        function uploadImg(imageUrl){
            return fetch(imageUrl) // 返回一个Promise
                .then(response => response.blob())
                .then(blob => {
                    const formData = new FormData();
                    formData.append('file', blob, 'image.jpg');
                    return fetch('https://img.xingtan.one/api/v1/upload', { // 注意这里也返回Promise
                        method: 'POST',
                        body: formData,
                    });
                })
                .then(response => response.json())
                .then(data => {
                    if (data.status) {
                        const imageUrl = data.data.links.url;
                        console.log('图片上传成功,URL:', imageUrl);
                        return imageUrl; // 返回图片URL
                    } else {
                        throw new Error('图片上传失败: ' + data.message); // 抛出错误以便在外部捕获
                    }
                })
                .catch(error => {
                    console.error('图片上传过程中发生错误:', error);
                    throw error; // 重新抛出错误以便在外部捕获
                });
        }
    `;

    // 将 <script> 元素插入到页面的 <head> 元素中
    document.head.appendChild(script);
})();