HOWTO 如何写一个油猴子(篡改猴 / Tampermonkey)脚本

title.jpg

什么是油猴子?

它是一款插件,用来在浏览器里运行自定义的js脚本,以弥补某些网站的不够人性化问题。

最初油猴子诞生于firefox平台,以上面优点获得前端开发者的青睐。最初的油猴子叫Greasemonkey,后来出现了新的插件Tampermonkey,它兼容了油猴子的功能,而且支持跨浏览器运行。所以现在大家都普遍称Tampermonkey为油猴子。

说到浏览器,大家用的可能都不太一样,有用firefox,chrome的,也有用微软edge,苹果safari的,还有用chromium内核的360和qq浏览器,以及一些老旧的浏览器。

Tampermonkey 是一款免费的浏览器扩展和最为流行的用户脚本管理器,它适用于 Chrome, Microsoft Edge, Safari, Opera Next, 和 Firefox

360/qq浏览器应该去他们的应用商店查询
safari下的插件是付费的 (10.15以后变为付费,safari的win版并不支持插件功能)

如何安装Tampermonkey ?

网址: https://www.tampermonkey.net/
下载适合自己浏览器的插件

插件能干什么 ?

有了插件并不能实现什么功能,他只是一个平台,具体功能需要你去以下网站下载。
GreasyForkOpenUserJS

这里已经有很多的功能脚本,已经能基本满足需求,搜索到满意的脚本点击安装即可。Tampermonkey支持脚本备份导出功能,方便你在不同平台共享脚本。

如果还满足不了需求,那就继续看下面的文章。

如何写一个脚本 ?

首先,要写一个脚本需要你满足一下技术需求:

  1. 掌握js脚本
  2. 掌握jquery模块 (可选)
  3. 正则表达式 (可选)
  4. 用控制台调试
  5. 发布脚本 (可选)
其中,jquery并不是必须要掌握,但是懂了它之后你的效率会事半功倍,不过这个模块有些网站会失效,这时候就需要用到基本js控制网页元素了。

创建一个脚本

点击插件按钮,新建脚本:

Snip20200717_1.png

图片.png

它包含了脚本的描述和结构,作为自己努力的结晶,你需要附上你的个人网站,以及自己的名字。同时对于脚本最重要的是脚本名称,脚本版本号,对脚本的描述,以及匹配网站。

这些内容随时都可以更改,包括脚本名称。

而最下面是脚本的内容,脚本默认启动严格模式,严格的好处是提醒代码出错。

代码放置的位置就在Your code here

匹配网站

如果是想全网站匹配,可以使用

// @include     *

如果包含具体网址可以用

  • 只匹配b站首页
// @match        https://www.bilibili.com/
  • 匹配全网
// @match            http*://*/*

or

// @include *
  • 排除匹配
// @exclude https://mail.google.com/*

扩展支持

因为提到用到jquery,所以我这里加入了它

// @require https://cdn.staticfile.org/jquery/3.3.1/jquery.min.js
其他扩展根据你的需求来,你可以加入vue扩展,但尽量从简,很多插件甚至为了适应更多网站,甚至抛弃了jquery

写怎样的一个脚本

为某个需求而生。
这里我有个想法,百度网盘在网上广泛分布,但每次点击都要复制密码,十分麻烦,能不能通过脚本实现大部分功能?

网上有专用脚本来实现网盘的密码复制自动填充,我这里看看自己能否实现。

试试吧~~

写代码

现在可以正式开始写代码了,但别急,代码在这里写,既晦涩又不直观,打开控制台吧,当然打开控制台之前,先要打开对应的网站,否则打开的控制台也无法有效起作用。

  • 首先我们要知道网站的网址:window.location.href很方便就得到了,你可以在控制台试试看
  • 其次,如何获得网址的二级域名呢?答案是正则:\/\/(.+?\..*?)(\/|\?)

    • 我来简单阐述一下正则的作用,它会查询网址以//开头并以/结束的字符串,某些字符是命令字符,所以要表达它的本意需要在前面加上\构成\?来表达原本的意思。
  • 正则有了,那么执行正则得到域名
  • 判断域名如果不是百度网盘,那就搜索网盘和提取码,并把密码通过#整合到网盘链接上
  • 非百度网盘网址处理:

    • 全局搜索提取码关键字
    • 然后通过正则(码|问)[\s|:|:]*([a-zA-Z0-9]{4})把提取码复制出来
    • 通过对提取码附近的链接,找到跳转链链接:`find('a[href*="pan.baidu.com"]')
    • 提取它的链接 : attr('href')
    • 拼接即可

      • 特殊:某些网站并不会直接贴出百度网站的网址,而是增加了个统计跳转链接,这时候需要ajax解析展开
      • 判断非百度网址if(link.indexOf('https://pan.baidu.com')!=0)
      • 执行解析$.ajax({type:'get',url:link, success:function(res){
      • 通过正则提取解析的百度网盘网址:(https:\/\/pan.baidu.com\/.*?\/(\d|\w|-)+)
      • 拼接网盘网址和提取码
  • 百度网盘网址处理:

    • 正则解析网址上的提取码:#([a-zA-Z0-9]{4})
    • 填入到唯一输入框中:$('input').first().val(提取码)
    • 自动打开,咱比较懒 $('a[title="提取文件"]').click()
  • 脚本写完,多个网站验证,还蛮不错的

提交脚本到网站

  1. 注册一个greasyfork.org的账号
  2. 需要准备如下内容,方便了解脚本的作用,便于下载

    1. 脚本代码本身
    2. 对脚本的描述
    3. 脚本的运行截图
  3. 提交你的脚本
  4. 以后脚本更新需要再回来更新脚本,记住版本号是需要迭代的

成品

成品网址

    var label = 'Zszen '
    var regexp_codeback = /#([a-zA-Z0-9]{4})/
    var regexp_code = /(码|问)[\s|:|:]*([a-zA-Z0-9]{4})/
    var regexp_url = /(https:\/\/pan.baidu.com\/.*?\/(\d|\w|-)+)/
    var url = window.location.href;
    var res = /\/\/(.+?\..*?)(\/|\?)/.exec(url);
    var site = res[1];
    console.log(site);
    //parse
    if(site=="pan.baidu.com"){
        $('input').first().val(regexp_codeback.exec(url)[1]);
        $('a[title="提取文件"]').click();
    }else{//deal
        var area = $(':contains("提取码")').last();
        if(area.length>0) replaceUrl(area);
        area = $(':contains("密码:")').last();
        if(area.length>0) replaceUrl(area);
    }

    function replaceUrl(area){
        var code = regexp_code.exec(area.text())[2];
        var atag = area.find('a[href*="pan.baidu.com"]');
        if(atag.length==0){
            atag = area.find('a');
        }
        var link = atag.attr('href');
        console.log(link);
        if(link.indexOf('https://pan.baidu.com')!=0){
            $.ajax({type:'get',url:link, success:function(res){
                link = regexp_url.exec(res)[0];
                area.find('a').attr('href', link + "#" + code);
            }});
        }else{
            area.find('a').attr('href', link + "#" + code);
        }
    }

Snip20200717_14.png

摒弃Jquery

如果插件对应网站比较宽泛, 还是尽量减少外部js调用, 包括jquery的调用, 其实原始element查询速度也不慢, 写法也不太冗赘, 需要自己实现搜索处理函数, 可以正常使用. 另外由于遗忘了二次跳转百度云的网站, 所以没有对二次解析进行处理, 以后遇到再说.

贴出最新代码

var label = 'Zszen '
    var regexp_codeback = /#([a-zA-Z0-9]{4})/
    var regexp_code = /(码|问)[\s|:|:]*([a-zA-Z0-9]{4})/
    var regexp_url = /(https:\/\/pan.baidu.com\/.*?\/(\d|\w|-)+)/
    var url = window.location.href;
    var res = /\/\/(.+?\..*?)(\/|\?)/.exec(url);
    var site = res[1];
    if(site=="pan.baidu.com"){//parse
        console.log(label,'pan get');
        var pss = regexp_codeback.exec(url);
        var inputs = ELs('input');
        var as = ELs('a', el=>el.textContent.indexOf('提取文件')>=0);
        if(pss!=null && pss.length>1 && inputs.length>0 && as.length>0){
            inputs[0].value = pss[1];
            as[0].click()
        }
    }else{//deal
        console.log(label,'pan find');
        ELs('a',
            (el)=>regexp_code.test(el.parentElement.textContent) && regexp_url.test(el.href),
            el=>{
               var ps = regexp_code.exec(el.parentElement.textContent)
               el.href=el.href+'#'+ps[2]
           }
        );
    }

    function ELs(tagName, conditionFun, dealFun){
        var tags = [...document.getElementsByTagName(tagName)];
        if(conditionFun){
            tags = tags.filter(conditionFun);
        }
        if(dealFun){
            tags.forEach(dealFun);
        }
        return tags;
    }

GM函数整合

tampermonkey提供了gm函数帮你实现很多额外的功能, 使用前需要引入grant权限,也就是下面注释的的代码, 虽然是注释,但是确实是给tm看的权限api申请

申请对全局变量的读取和写入

// @grant GM_getValue
// @grant GM_setValue

它和cookie不同的是,设置是夸网站的,也就是当前插件的设置是唯一的
使用方法也很简单:

//读取
GM_getValue("key")
//设置
GM_setValue("key", value)

申请数据请求(支持跨域)

// @grant GM_xmlhttpRequest

插件提供了访问权限,这让你跨域请求成为可能,当然请求跨域的话tm插件会提示你是否允许跨域请求

GM_xmlhttpRequest({
    method: "GET",
    url: 链接地址,
    onload: (res)=>{
        //返回值处理
    }
)

通过上面两个api, 我实现了在百度网盘上开关自动下载的功能
Snip20200726_5.png
以及解析非百度网盘的功能:可以围观这个网站 , 实现预先检测到提取码,再反推找出链接,并判断链接是否需要进行进一步解析,这样就完成了对二次跳转到自动解析

对比:

插件无效时:
图片.png

成品

成品网址 撒花, 欢迎交流和支持

你可能感兴趣的:(javascript,html5,chrome,firefox,safari)