JustJumpAhead

自动完成掘金、简书、知乎、百度贴吧、PC端QQ、CSDN、Gitee的跳转询问界面的点击工作,实现自动跳转

  1. /*
  2. * @Descripttion: 油猴脚本,自动继续跳转
  3. * @Version: 0.3.3
  4. * @Author: LiarCoder
  5. * @Date: 2021-09-29 19:12:14
  6. * @LastEditors: LiarCoder
  7. * @LastEditTime: 2021-12-11 23:43:48
  8. */
  9. // ==UserScript==
  10. // @name JustJumpAhead
  11. // @namespace http://tampermonkey.net/
  12. // @version 0.3.3
  13. // @description 自动完成掘金、简书、知乎、百度贴吧、PC端QQ、CSDN、Gitee的跳转询问界面的点击工作,实现自动跳转
  14. // @author LiarCoder
  15. // @match *://link.juejin.cn/*
  16. // @match *://link.zhihu.com/*
  17. // @match *://www.jianshu.com/go-wild*
  18. // @match *://jump.bdimg.com/safecheck*
  19. // @match *://link.csdn.net/*
  20. // @match *://gitee.com/link?*
  21. // @match *://c.pc.qq.com/middlem.html*
  22. // @icon 
  23. // @grant none
  24. // ==/UserScript==
  25.  
  26. (function () {
  27. "use strict";
  28. window.onload = function () {
  29. // jumpBtn 是各个跳转页面中的类似于【继续访问】的按钮,用户可以点击按钮以继续访问被拦截的链接
  30. let jumpBtn = null;
  31. // targetAddress 是针对像在PC端QQ中的拦截页面中需要用户手动复制的目标链接
  32. let targetAddress = "";
  33. // currentAddress 是当前拦截页面的完整网址
  34. let currentAddress = location.toString();
  35. // buttonMap 存储了相应拦截页面与其中的【继续访问】按钮的CSS选择器映射关系
  36. let buttonMap = new Map();
  37. // addressMap 存储了相应拦截界面与其中的需要用户手动复制的网址的CSS选择器的映射关系
  38. let addressMap = new Map();
  39.  
  40. // 匹配掘金的跳转拦截页面网址
  41. buttonMap.set("://link.juejin.cn/", "#app > div > div > button");
  42. // 匹配简书的跳转拦截页面网址
  43. buttonMap.set("://www.jianshu.com/go-wild", "._3OuyzjzFBDdQwRGk08HXHz_0");
  44. // 匹配知乎的跳转拦截页面网址
  45. buttonMap.set("://link.zhihu.com/", "a.button");
  46. // 匹配百度贴吧的跳转拦截页面网址
  47. buttonMap.set("://jump.bdimg.com/safecheck", "div.warning_info.fl > a:nth-child(2)");
  48. // 匹配CSDN的跳转拦截页面网址
  49. buttonMap.set("://link.csdn.net/", "a.loading-btn");
  50.  
  51. // 匹配PC端QQ的跳转拦截页面网址
  52. addressMap.set("://c.pc.qq.com/middlem.html", "#url");
  53.  
  54. // 开始逐个遍历 buttonMap 中的 key 值,若有匹配上的,则获取相应按钮元素并自动点击完成跳转
  55. for (let address of buttonMap.keys()) {
  56. if (currentAddress.indexOf(address) >= 0) {
  57. jumpBtn = document.querySelector(buttonMap.get(address));
  58. jumpBtn.click();
  59. return;
  60. }
  61. }
  62.  
  63. // 开始逐个遍历 addressMap 中的 key 值,若有匹配上的,则自动将浏览器的location指向目标网站完成跳转
  64. for (let address of addressMap.keys()) {
  65. if (currentAddress.indexOf(address) >= 0) {
  66. targetAddress = document.querySelector(addressMap.get(address)).innerText;
  67. location = targetAddress;
  68. return;
  69. }
  70. }
  71. };
  72. })();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址