Bypass It

Automatically Bypass Restrictions and Get Straight to Your Destination!

当前为 2025-04-17 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Bypass It
  3. // @namespace http://tampermonkey.net/
  4. // @version 2025-04-17 (2)
  5. // @description Automatically Bypass Restrictions and Get Straight to Your Destination!
  6. // @supportURL https://gf.qytechs.cn/scripts/527564/feedback
  7. // @author You
  8. // @match *://vn88.id/*
  9. // @match *://vn88.fan/*
  10. // @match *://vn88.ing/*
  11. // @match *://vn88.wtf/*
  12. // @match *://aylink.co/*
  13. // @match *://vn8eu.com/*
  14. // @match *://vn88n.com/*
  15. // @match *://gplinks.co/*
  16. // @match *://v2links.me/*
  17. // @match *://upfion.com/*
  18. // @match *://fb88dv.com/*
  19. // @match *://m88usb.com/*
  20. // @match *://vn88.group/*
  21. // @match *://vn88wo.com/*
  22. // @match *://vn88zx.com/*
  23. // @match *://vn88ko.com/*
  24. // @match *://vn88es.com/*
  25. // @match *://vn88tu.com/*
  26. // @match *://www.m88.com/*
  27. // @match *://bet88li.com/*
  28. // @match *://cutyion.com/*
  29. // @match *://vn88tk1.com/*
  30. // @match *://vn88vc.wiki/*
  31. // @match *://fb88vao.com/*
  32. // @match *://coinclix.co/*
  33. // @match *://vn88.hiphop/*
  34. // @match *://gwaher.com/ptc
  35. // @match *://www.fb88.com/*
  36. // @match *://*.devnote.in/*
  37. // @match *://naamlist.com/*
  38. // @match *://modsfire.com/*
  39. // @match *://yeumoney.com/*
  40. // @match *://165.22.63.250/*
  41. // @match *://*.gmsrweb.org/*
  42. // @match *://modijiurl.com/*
  43. // @match *://geekgrove.net/*
  44. // @match *://www.m88sut.com/*
  45. // @match *://*.techyuth.xyz/*
  46. // @match *://vn88.solutions/*
  47. // @match *://financewada.com/*
  48. // @match *://188.166.185.213/*
  49. // @match *://gemini.google.com/*
  50. // @match *://cryptowidgets.net/*
  51. // @match *://*.wikijankari.com/*
  52. // @match *://cricketlegacy.com/*
  53. // @match *://ourcoincash.xyz/ptc*
  54. // @match *://*.idblogmarket.com/*
  55. // @match *://*.phonesparrow.com/*
  56. // @match *://financenova.online/*
  57. // @match *://bitcotasks.com//lead*
  58. // @match *://rajasthantopnews.com/*
  59. // @match *://www.google.com/url?q=*
  60. // @match *://freepayz.com/framed-ads
  61. // @match *://utkarshonlinetest.com/*
  62. // @match *://www.youtube.com/redirect*
  63. // @match *://www.facebook.com/flx/warn/*
  64. // @match *://gemini.google.com/app?msg=*
  65. // @match *://www.instagram.com/linkshim/*
  66. // @match https://www.google.com/recaptcha/api2/bframe*
  67. // @match https://www.google.com/recaptcha/api2/anchor*
  68. // @icon 
  69. // @grant GM_getValue
  70. // @grant GM_setValue
  71. // @grant unsafeWindow
  72. // @grant GM_openInTab
  73. // @grant GM_deleteValue
  74. // @grant GM_xmlhttpRequest
  75. // @grant GM_registerMenuCommand
  76. // @grant GM_addValueChangeListener
  77. // @require https://openuserjs.org/src/libs/sizzle/GM_config.min.js
  78. // @connect api.nocaptchaai.com
  79. // @license MIT
  80. // ==/UserScript==
  81. const noop = () => {};
  82. const rawWindow = unsafeWindow;
  83. const currentUrl = location.href;
  84. const queryParams = new URLSearchParams(location.search);
  85. const autoRedirectToSocial = GM_getValue("autoRedirectToSocial", false);
  86. const boostTimers = GM_getValue("boostTimers", false);
  87. const ptcFaucet = GM_getValue("ptcFaucet", false);
  88. const siteDelays = {
  89. // "example.com": 0.05, // 50ms
  90. // "anotherexample.net": 0.1 // 100ms
  91. };
  92. const reCaptcha = "YOUR_API_KEY_HERE"//GM_getValue("apiKey", "");
  93.  
  94. function waitForElement(selector, callback = noop) {
  95. const findElement = () => {
  96. if (selector.startsWith("//")) {
  97. return document.evaluate(selector, document, null, 9).singleNodeValue;
  98. }
  99. return document.querySelector(selector);
  100.  
  101. };
  102.  
  103. return new Promise((resolve) => {
  104. const element = findElement();
  105. if (document.contains(element)) {
  106. callback(element);
  107. return resolve(element);
  108. }
  109. const observer = new MutationObserver((mutations, observerInstance) => {
  110. const node = findElement();
  111. if (document.contains(node)) {
  112. observerInstance.disconnect();
  113. callback(node);
  114. resolve(node);
  115. }
  116. });
  117. observer.observe(document.documentElement, {
  118. attributes: true,
  119. childList: true,
  120. subtree: true,
  121. });
  122. });
  123. }
  124.  
  125. function navigateTo(url) {
  126. location = url;
  127. }
  128.  
  129. function waitSeconds(seconds) {
  130. return new Promise((resolve) => setTimeout(resolve, seconds * 1000));
  131. }
  132.  
  133. function autoRedirectToLink(selector) {
  134. waitForElement(selector).then((element) => navigateTo(element.href));
  135. }
  136.  
  137. function createMenu(key, title) {
  138. const isActive = GM_getValue(key, false);
  139. const prefix = isActive ? "✔️ " : "❌ ";
  140.  
  141. GM_registerMenuCommand(prefix + title, function() {
  142. GM_setValue(key, !isActive);
  143. createMenu(key, title);
  144. alert(`${title} has been ${!isActive ? "enabled" : "disabled"}.`);
  145. }, {
  146. id: key
  147. });
  148. }
  149.  
  150. function imageUrlToBase64(imageUrl) {
  151. if (!imageUrl) {
  152. console.error("No imageUrl provided");
  153. return null;
  154. }
  155. try {
  156. return new Promise((resolve, reject) => {
  157. GM_xmlhttpRequest({
  158. method: "GET",
  159. url: imageUrl,
  160. responseType: "blob",
  161. onload: function(response) {
  162. if (!response.response) {
  163. reject("No response received");
  164. return;
  165. }
  166.  
  167. const blob = response.response;
  168. const reader = new FileReader();
  169. reader.onload = () => resolve(reader.result);
  170. reader.onerror = (error) => {
  171. console.error("FileReader error:", error);
  172. reject(error);
  173. };
  174. reader.readAsDataURL(blob);
  175. },
  176. onerror: function(error) {
  177. console.error("Error fetching image:", error);
  178. reject(error);
  179. }
  180. });
  181. });
  182. } catch (error) {
  183. console.error("Error converting image to Base64:", error);
  184. return null;
  185. }
  186. }
  187.  
  188. function runWhenHostMatches(hostPattern, callback, ...args) {
  189. hostPattern = hostPattern.replace("www.", "");
  190. const isMatch = new RegExp(hostPattern).test(location.host);
  191.  
  192. if (isMatch) callback(...args);
  193. }
  194.  
  195. function simulateClick(selector, delay = 0) {
  196. const clickFun = (element) => {
  197. const events = ["mouseover", "mousedown", "mouseup", "click"];
  198. events.forEach((eventName) => {
  199. const event = new MouseEvent(eventName, {
  200. bubbles: true,
  201. });
  202. element.dispatchEvent(event);
  203. });
  204. }
  205. if (typeof selector != "string") {
  206. return clickFun(selector);
  207. }
  208. const selectors = selector.split(", ");
  209. // If multiple selectors are provided, iterate over each.
  210. if (selectors.length > 1) {
  211. selectors.forEach((sel) => simulateClick(sel, delay));
  212. return;
  213. }
  214.  
  215. waitForElement(selector, async function(element) {
  216. if (delay > 0) {
  217. await waitSeconds(delay);
  218. }
  219. clickFun(element);
  220. });
  221. }
  222.  
  223. function whenCaptchaSolved(callback, onWait = noop) {
  224. let intervalId;
  225. const stopChecking = () => clearInterval(intervalId);
  226.  
  227. // waitForElement("//*[@id='captcha-result'] and normalize-space() = 'Verified!']", function() {
  228. // stopChecking();
  229. // callback();
  230. // })
  231. const checkCaptcha = () => {
  232. try {
  233. const element = document.querySelector('#captcha-result .mb-2.badge.bg-success');
  234. if (element && element.textContent.trim() === 'Verified!') {
  235. stopChecking();
  236. callback();
  237. }
  238.  
  239. const captcha = rawWindow.turnstile || rawWindow.hcaptcha || rawWindow.grecaptcha;
  240. const response = captcha.getResponse();
  241.  
  242. if (response) {
  243. stopChecking();
  244. callback();
  245. }
  246. } catch (error) {
  247. onWait(stopChecking);
  248. }
  249. };
  250.  
  251. checkCaptcha();
  252. intervalId = setInterval(checkCaptcha, 1000);
  253. }
  254.  
  255. function GM_onMessage(label, callback = noop) {
  256. GM_addValueChangeListener("postMessage-" + label, function(name, oldValue, newValue, remote) {
  257. if (remote) {
  258. GM_deleteValue("postMessage-" + label);
  259. callback(newValue);
  260. }
  261. });
  262. }
  263.  
  264. function GM_sendMessage(label, value) {
  265. GM_setValue("postMessage-" + label, value);
  266. }
  267.  
  268. function onOpenTab(callback) {
  269. const originalOpen = rawWindow.open;
  270.  
  271. rawWindow.open = function(...args) {
  272. const newWindow = originalOpen.apply(rawWindow, args);
  273. callback(newWindow);
  274. return newWindow;
  275. };
  276. }
  277.  
  278. function clickWithTrusted() {
  279. // Create window proxy to disable Object.freeze
  280. const sandbox = new Proxy(window, {
  281. get(target, key) {
  282. if (key === 'Object') {
  283. return new Proxy(Object, {
  284. get(objTarget, objKey) {
  285. if (objKey === 'freeze') {
  286. return function(obj) {
  287. console.warn("Object.freeze disabled in sandbox.");
  288. return obj;
  289. };
  290. }
  291. return Reflect.get(objTarget, objKey);
  292. }
  293. });
  294. }
  295. return Reflect.get(target, key);
  296. }
  297. });
  298.  
  299. // Patch addEventListener to clone events and force isTrusted
  300. const originalAddEventListener = EventTarget.prototype.addEventListener;
  301. EventTarget.prototype.addEventListener = function(type, listener, options) {
  302. const wrappedListener = function(event) {
  303. const clonedEvent = Object.create(event);
  304. Object.defineProperty(clonedEvent, "isTrusted", {
  305. value: true,
  306. writable: false
  307. });
  308. return listener.call(this, clonedEvent);
  309. };
  310. return originalAddEventListener.call(this, type, wrappedListener, options);
  311. };
  312.  
  313. return sandbox;
  314. }
  315.  
  316. // Main execution
  317. (function () {
  318. "use strict";
  319. runWhenHostMatches("modsfire.com", simulateClick, ".download-button, .download-button[href]");
  320. runWhenHostMatches("(financewada|utkarshonlinetest).com|financenova.online|v2links.me", simulateClick, ".get_btn a[href], //div[contains(text(),'Continue')], .get-link:not(.disabled)");
  321.  
  322. runWhenHostMatches("devnote.in|techyuth.xyz", simulateClick, "#scroll:not(.no), #getlinks[style*='display: block;'], .get-link:not(.disabled)");
  323. autoRedirectToSocial && runWhenHostMatches("(instagram|youtube|facebook).com", simulateClick, ".-cx-PRIVATE-Linkshim__followLink__, #invalid-token-redirect-goto-site-button, .selected");
  324. createMenu("autoRedirectToSocial", "Auto-Redirect to Social Media");
  325.  
  326. runWhenHostMatches("(wikijankari|idblogmarket|modijiurl|phonesparrow|naamlist|rajasthantopnews).com|gmsrweb.org", simulateClick, "center a[style*='display: block;'], .get-link:not(.disabled)");
  327.  
  328. runWhenHostMatches("aylink.co", simulateClick, ".btn-go, .complete[style*='display: block;'] a, a.btn:not(.btn-go)")
  329.  
  330. runWhenHostMatches("upfion.com", function() {
  331. simulateClick("#link-button:not([disabled])");
  332. waitForElement("a#link-button:not([disabled])").then((element) => navigateTo(element.href));
  333. });
  334.  
  335. runWhenHostMatches("cutyion.com", simulateClick, "#submit-button:not([disabled])");
  336.  
  337. runWhenHostMatches("(m88(sut|usb)?|bet88li|fb88(dv|vao)?|yeumoney|google|vn8?8(wo|tk1|eu|zx|ko|es|tu|n)?).com|188.166.185.213|165.22.63.250|vn88.(hiphop|wtf|id|now|fan|group|solutions|ing)|vn88vc.wiki", function() {
  338. waitForElement(".getcodebtn", function(element) {
  339. element.click();
  340. GM_sendMessage("close_tabs", currentUrl);
  341. })
  342. waitForElement("//*[contains(@class, 'cursor-pointer') and contains(text(), 'footer')]", function() {
  343. simulateClick("a[href*='"+location.host+"']");
  344. })
  345. waitForElement("//*[contains(@class, 'cursor-pointer') and string-length(translate(normalize-space(text()), '0123456789', '')) = 0]", function(element) {
  346. GM_sendMessage("vietnam_code", element.innerText)
  347. })
  348.  
  349. // Google search results don’t always display the exact content that a website wants for every page
  350. // const searchLinks = [...document.querySelectorAll('div#search a[href]:not([class])')].map(a => a.href)
  351. const tabs = [];
  352. const urls = [
  353. "m88.com", "vn88.id", "vn88.fan", "vn88.ing", "fb88.com", "vn88.now",
  354. "vn88.wtf", "vn8eu.com", "vn88n.com", "m88sut.com", "m88usb.com",
  355. "fb88dv.com", "vn88.group", "vn88wo.com", "vn88zx.com", "vn88ko.com",
  356. "vn88es.com", "vn88tu.com", "vn88tk1.com","vn88vc.wiki", "fb88vao.com",
  357. "vn88.hiphop", "vn88.solutions", "bet88li.com/m88", "188.166.185.213/w88",
  358. "165.22.63.250/188bet",
  359. ]
  360. urls.includes(queryParams.get("q")?.replace("https://", "")) && simulateClick(".mymGo ~ div a");
  361.  
  362. GM_onMessage("vietnam_code", function(newValue) {
  363. tabs.forEach(([_, tab]) => tab.close());
  364. document.querySelector('[name="code"]').value = newValue;
  365. simulateClick(".box-form-button button");
  366. });
  367.  
  368. waitForElement("[data-clipboard-text]:not([data-clipboard-text=''])", function(element) {
  369. const links = urls.filter(url => url.includes(element.dataset.clipboardText));
  370. links.forEach(url => {
  371. const tab = GM_openInTab("https://www.google.com/url?q=https://" + url);
  372. tabs.push([url, tab]);
  373. })
  374. GM_onMessage("close_tabs", function(newValue) {
  375. tabs.forEach(([url, tab]) => {
  376. if (new URL("https://" + url).host !== new URL(newValue).host) {
  377. tab.close();
  378. }
  379. });
  380. });
  381. })
  382. });
  383.  
  384. runWhenHostMatches("gplinks.co|cricketlegacy.com", simulateClick, "#VerifyBtn[style*='display: block;'], #NextBtn:not([href='#']), #captchaButton:not(.disabled)");
  385.  
  386. createMenu("ptcFaucet", "Opens PTC links");
  387. if (ptcFaucet) {
  388. const isHidden = el => el && (getComputedStyle(el).display === "none" || isHidden(el.parentElement));
  389. const regex = /^(visit for \d+ sec|visit(?: now)?|go|view|view now|view ads?|watch|start .* coins|start view ad)$/i;
  390. const findButton = () => [...document.querySelectorAll("button")].find(btn => regex.test(btn.textContent.trim()));
  391.  
  392. runWhenHostMatches("ourcoincash.xyz|(bitcotasks|freepayz|gwaher).com", function() {
  393. //TODO: replace the use of setInterval and fix the issue with tabs
  394. let tabObj;
  395. onOpenTab(function(tab) { tabObj = tab; });
  396. rawWindow.addEventListener("beforeunload", function() { tabObj?.close(); })
  397.  
  398. findButton()?.click();
  399.  
  400. setInterval(function() {
  401. tabObj?.close();
  402. findButton()?.click();
  403. }, 120000) // 120 sec
  404. whenCaptchaSolved(function() {
  405. const btn = document.querySelector("button[type='submit']")
  406. !isHidden(btn) && btn.click();
  407. })
  408. })
  409. }
  410. runWhenHostMatches("coinclix.co|geekgrove.net", async function() {
  411. // Add support for Google. Currently, it is not supported, and a refresh is needed when it appears.
  412. if (!autoRedirectToSocial) {
  413. //TODO: Automatically enable for a temporary amount of time
  414. return alert("To bypass this, you need to enable Auto-Redirect to Social Media.");
  415. }
  416. const code = document.querySelector(".mb-2 code");
  417. if (code) {
  418. //TODO: replace with something else
  419. const tab = GM_openInTab(document.querySelector("strong a")?.href);
  420. await waitSeconds(10);
  421. GM_sendMessage("geek_code", code.innerText);
  422.  
  423. }
  424. GM_onMessage("geek_code", function(newValue) {
  425. document.querySelector("#link_input").value = newValue;
  426. simulateClick("#btn_link, .btn-primary[href]");
  427. });
  428. })
  429.  
  430. createMenu("boostTimers", "Site-Specific Boost Timers");
  431. if (boostTimers) {
  432. [['setInterval', rawWindow.setInterval], ['setTimeout', rawWindow.setTimeout]].forEach(([funcName, func]) => {
  433. Object.defineProperty(rawWindow, funcName, {
  434. value: function(callback, delay, ...args) {
  435. delay = (siteDelays[location.host] || 1) * 1000;
  436. return func(callback, delay, ...args);
  437. },
  438. writable: false,
  439. configurable: false
  440. });
  441.  
  442. });
  443. }
  444. })();
  445.  
  446. // There are several known bugs, so if possible, it is recommended to use the official chrome extensions for now.
  447. (async function(isEnabled) {
  448. if (!isEnabled) return;
  449. console.log(123);
  450.  
  451. let isSolved = false;
  452.  
  453. const isCheckboxPresent = () => !!document.querySelector('.recaptcha-checkbox');
  454. const isCheckboxChecked = () => document.querySelector('#recaptcha-anchor')?.getAttribute('aria-checked') === 'true';
  455. const isImageChallengePresent = () => !!document.querySelector('#rc-imageselect');
  456. const isGrid4x4 = () => document.querySelectorAll('.rc-imageselect-tile').length === 16;
  457. const isGrid3x3 = () => document.querySelectorAll('.rc-imageselect-tile').length === 9;
  458. const getChallengeData = () => {
  459. const target = document.querySelector('.rc-imageselect-instructions strong')?.innerText;
  460. const imageUrl = document.querySelector('.rc-image-tile-33, .rc-image-tile-44')?.src;
  461. return [target, imageUrl];
  462. };
  463.  
  464. const solveImageChallenge = async (target, imageUrl, gridType) => {
  465. return new Promise(async (resolve) => {
  466. GM_xmlhttpRequest({
  467. method: 'POST',
  468. url: "https://api.nocaptchaai.com/createTask",
  469. headers: {
  470. 'Content-Type': 'application/json',
  471. },
  472. data: JSON.stringify({
  473. clientKey: reCaptcha,
  474. task: {
  475. type: 'ReCaptchaV2Classification',
  476. questionType: gridType,
  477. image: (await imageUrlToBase64(imageUrl)).replace("data:image/jpeg;base64,", ""),
  478. question: target
  479. }
  480. }),
  481. responseType: "json",
  482. onload: function(response) {
  483. const data = response.response;
  484. if (data.errorId) return; //TODO: reject
  485. resolve(data.solution?.objects || data.solution?.hasObject);
  486. }
  487. });
  488. });
  489.  
  490. };
  491.  
  492. const isVisible = (element) => {
  493. if (!element) return false;
  494. const style = window.getComputedStyle(element);
  495. return style.display !== 'none' &&
  496. style.visibility !== 'hidden' &&
  497. style.opacity !== '0' &&
  498. element.offsetWidth > 0 &&
  499. element.offsetHeight > 0;
  500. };
  501.  
  502. const hasError = () => {
  503. const errorSelectors = [
  504. '.rc-imageselect-error-select-more',
  505. '.rc-imageselect-error-dynamic-more',
  506. '.rc-imageselect-error-select-something'
  507. ];
  508.  
  509. for (const selector of errorSelectors) {
  510. const error = document.querySelector(selector);
  511. if (isVisible(error)) {
  512. return true;
  513. }
  514. }
  515. return false;
  516. };
  517. while (!isSolved) {
  518. await waitSeconds(2);
  519. if (isCheckboxPresent()) {
  520. if (isCheckboxChecked()) {
  521. isSolved = true;
  522. return;
  523. }
  524. await simulateClick('#recaptcha-anchor');
  525. } else if (isImageChallengePresent()) {
  526. const gridType = isGrid4x4() ? "44" : isGrid3x3() ? "33" : null;
  527. if (gridType && isImageChallengePresent() && !isCheckboxChecked()) {
  528. const [target, imageUrl] = getChallengeData();
  529. if (target && imageUrl) {
  530. const solution = await solveImageChallenge(target, imageUrl, gridType);
  531. if (solution) {
  532. const tiles = document.querySelectorAll('.rc-image-tile-wrapper');
  533. for (const index of solution) {
  534. if (tiles[index]) {
  535. simulateClick(tiles[index]);
  536. await waitSeconds(0.4);
  537. }
  538. }
  539. await waitSeconds(1);
  540. await simulateClick("#recaptcha-verify-button");
  541.  
  542. if (isCheckboxChecked()) {
  543. isSolved = true;
  544. await waitSeconds(1);
  545. return;
  546. }
  547. }
  548. }
  549. }
  550. } else if (isCheckboxChecked()) {
  551. isSolved = true;
  552. await waitSeconds(1);
  553. return;
  554. }
  555.  
  556. if (hasError()) {
  557. simulateClick("#recaptcha-reload-button");
  558. await waitSeconds(1);
  559. }
  560. }
  561.  
  562. })(reCaptcha.length > 20);

QingJ © 2025

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