// ==UserScript==
// @name my crack slide
// @license MIT
// @namespace http://oneoneone.cn/
// @version 3.9
// @description This is a script file used to move the slider verification code, but the success rate cannot be guaranteed.
// @author ChoiWan
// @match https://*.temu.com/*
// @icon 
// @grant GM_xmlhttpRequest
// @grant GM_setValue
// @grant GM_getValue
// @connect 127.0.0.1
// @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js
// @require https://cdn.jsdelivr.net/npm/[email protected]/dist/short-unique-id.min.js
// @require https://scriptcat.org/lib/637/1.4.3/ajaxHooker.js#sha256=y1sWy1M/U5JP1tlAY5e80monDp27fF+GMRLsOiIrSUY=
// ==/UserScript==
this.$ = this.jQuery = jQuery.noConflict(true);
(function() {
'use strict'
/* var isFirstRun = GM_getValue('IS_FIRST_RUN',null)
if(!isFirstRun){
console.log('IS_FIRST_RUN')
clearAllCookies()
GM_setValue("IS_FIRST_RUN", "1");
windows.location.reload(true)
}*/
//===================Function 0: anti ========================================
/*var anti = ''
function doGetAnti(){
return new Promise((resolve, reject) => {
GM_xmlhttpRequest({
method: 'get',
url: 'http://127.0.0.1:6699/api/anti',
dataType: 'json',
onload: function(res) {
if (res.status === 200) {
const responseData = JSON.parse(res.responseText)
const anti = responseData.data
resolve(anti)
}
}
})
})
}
doGetAnti().then((data)=>{
anti = data
console.log(anti)
})
*/
//===================Function : HOOK REQUEST ========================================
/*ajaxHooker.hook(request => {
//if (request.url === '/api/bg/sigerus/auth/login_name/is_registered') {
// console.log('ajaxHooker :',request)
// request.headers['Anti-Content'] = anti
//}
});*/
//===================Function 1: doAutoRefresh ========================================
/*doAutoRefresh()
function doAutoRefresh(){
setInterval(() => {
waitElement('#best_new_log')
.then(result => {
const text = $('#best_new_log>p').text()
if(text.indexOf('任务队列为空')!=-1){
console.log('doAutoRefresh')
location.reload();
}
})
},5000)
}*/
//===================Function 1: doAutoClick ========================================
doAutoClick()
function doAutoClick() {
setInterval(() => {
// Reject all
const rejectItem = $('span:contains("Reject all")')
// 隐藏cookie弹框
if (rejectItem.length > 0) {
rejectItem.click()
}
const startBtn = $('.kasdsaj>.btn-box>#task-start')
if (startBtn.length > 0) {
const text = startBtn.text()
if (text == 'start') {
console.log('start')
startBtn.click()
}else {
console.log('stop')
startBtn.click()
setTimeout(() => {
const _startBtn = $('.kasdsaj>.btn-box>#task-start')
const text = startBtn.text()
if (text == 'start') {
console.log('start')
_startBtn.click()
}
}, 300)
setTimeout(() => {
const _startBtn = $('.kasdsaj>.btn-box>#task-start')
const text = startBtn.text()
if (text == 'start') {
console.log('start')
_startBtn.click()
}
}, 1000)
setTimeout(() => {
const _startBtn = $('.kasdsaj>.btn-box>#task-start')
const text = startBtn.text()
if (text == 'start') {
console.log('start')
_startBtn.click()
}
}, 2000)
}
}
}, 30000)
}
//===================Function 1: doCheckSoldOut ========================================
/* doCheckSoldOut()
function doCheckSoldOut() {
setInterval(() => {
const flag = $('div:contains("This item is sold out.")')
if (flag.length > 0) {
console.log('sold out')
clearAllCookies();
window.location.replace('https://temu.com/?' + Math.random())
}
}, 20000)
}
*/
//===================Function 2: doCheckJumpToLogin ========================================
//doCheckJumpToLogin()
navigation.addEventListener("navigate", (event) => {
const d_url = event.destination.url
if(d_url.indexOf('login.html')!==-1) {
event.intercept({
focusReset: "manual",
scroll: "manual",
async handler() {
// You could navigate again with {history: 'replace'} to change the URL here,
// which might indicate "done"
},
});
}
});
function doCheckJumpToLogin() {
var isLogining = false
setInterval(() => {
if(!isLogining){
const href = window.location.href
if (href.indexOf('temu.com/login.html') !== -1) {
isLogining = true
waitElement('#user-account')
.then(result => {
var uid = new ShortUniqueId({ length: 11,dictionary:'number' });
const account = uid.rnd()+'@qq.com'
$('#user-account').val(account)
waitElement('#submit-button')
.then(result => {
$('#submit-button').click()
waitElement('#pwdInputInLoginDialog')
.then(result => {
$('#user-account').val(account)
$('#pwdInputInLoginDialog').trigger("focus")
document.execCommand("insertText", false, account)
waitElement('#submit-button')
.then(result => {
$('#submit-button').click()
isLogining = false
console.log('register finish!',account)
}).catch(err=>{
console.log('sorry:submit-button2')
isLogining = false
})
}).catch(err=>{
console.log('sorry:pwdInputInLoginDialog')
isLogining = false
})
}).catch(err=>{
console.log('sorry:submit-button')
isLogining = false
})
$('#submit-button').click()
}).catch(err=>{
console.log('sorry:user-account')
isLogining = false
})
}
}
}, 60000)
}
//====================Function 3: auto slide =======================================
var isVerifying = false
var GapimgBase64 = null
// check dialog
const interval_verifyDialog = setInterval(() => {
const element = document.querySelector('.verifyDialog')
if (element && !isVerifying) {
waitElement('#slider')
.then(result => {
beginCrack()
}).catch(err=>{
console.log('warnning:no slider !!!!!!!!')
//doRandomGo()
//window.location.replace('https://www.temu.com/uk?' + Math.random())
})
}
}, 10000)
async function doRandomGo(){
console.log('doRandomGo')
isVerifying = true
var verifyDialog = $('.verifyDialog')[0]
//
var mousedown = document.createEvent('MouseEvents')
var rect = verifyDialog.getBoundingClientRect()
var x = rect.width * 0.5 + getRandomInteger(-10, 10)
var y = rect.height * 0.5 + getRandomInteger(-10, 10)
mousedown.initMouseEvent(
'mousedown',
true,
true,
document.defaultView,
0,
x,
y,
x,
y,
false,
false,
false,
false,
0,
null
)
verifyDialog.dispatchEvent(mousedown)
await sleep(100)
//
var mousemove = document.createEvent('MouseEvents')
var _x = x + getRandomInteger(-10, 10)
var _y = y + getRandomInteger(-10, 10)
mousemove.initMouseEvent(
'mousemove',
true,
true,
document.defaultView,
0,
_x,
_y,
_x,
_y,
false,
false,
false,
false,
0,
null
)
verifyDialog.dispatchEvent(mousemove)
//
await sleep(1000)
var __x = _x + getRandomInteger(-10, 10)
var __y = _y + getRandomInteger(-10, 10)
var mouseup = document.createEvent('MouseEvents')
mouseup.initMouseEvent(
'mouseup',
true,
true,
document.defaultView,
0,
__x,
__y,
__x,
__y,
false,
false,
false,
false,
0,
null
)
verifyDialog.dispatchEvent(mouseup)
$('.verifyDialog').click()
isVerifying = false
}
//=======================================================
function beginCrack() {
if (isVerifying) {
console.log('isVerifying...')
return
}
console.log('beginCrack')
isVerifying = true
doMouseDown()
doRareMove()
const interval = setInterval(() => {
// Check if the DOM element exists
const element = document.querySelector('#img-button>img')
if (element) {
var gapimg_base64 = $('#img-button>img')
.attr('src')
var isSame = GapimgBase64 === gapimg_base64
if (!isSame) {
clearInterval(interval) // Stop the interval
doSlide()
}
}
else {
console.log('no element...')
doMouseDown()
}
}, 500)
}
function endCrack(){
isVerifying = false
doMouseUp()
}
function doMouseDown() {
console.log('doMouseDown')
var btn = $('#slide-button')[0]
var mousedown = document.createEvent('MouseEvents')
var rect = btn.getBoundingClientRect()
var x = rect.x + getRandomInteger(0, 2)
var y = rect.y + getRandomInteger(-2, 2)
mousedown.initMouseEvent(
'mousedown',
true,
true,
document.defaultView,
0,
x,
y,
x,
y,
false,
false,
false,
false,
0,
null
)
btn.dispatchEvent(mousedown)
}
function doMouseUp() {
console.log('doMouseUp')
var btn = $('#slide-button')[0]
var rect = btn.getBoundingClientRect()
var x = rect.x + getRandomInteger(0, 2)
var y = rect.y + getRandomInteger(-2, 2)
var mouseup = document.createEvent('MouseEvents')
mouseup.initMouseEvent(
'mouseup',
true,
true,
document.defaultView,
0,
x,
y,
x,
y,
false,
false,
false,
false,
0,
null
)
btn.dispatchEvent(mouseup)
}
async function doSlide() {
console.log('doSlide...')
var fullimg_base64 = $('#slider>img')
.attr('src')
var gapimg_base64 = $('#img-button>img')
.attr('src')
if (fullimg_base64 && gapimg_base64) {
GapimgBase64 = gapimg_base64
try{
const gapOffset = await getOffset2Img()
console.log('gapOffset:',gapOffset)
const padding = await doPost(gapimg_base64, fullimg_base64)
console.log('padding:',padding)
doMove(padding, gapOffset)
}catch(e){
endCrack()
setTimeout(() => {
beginCrack()
}, 1000)
}
} else {
//console.error('没有拿到base64~~~~~~~~~~~')
endCrack()
setTimeout(() => {
beginCrack()
}, 1000)
}
}
function doPost(gapimg_base64, fullimg_base64) {
return new Promise((resolve, reject) => {
GM_xmlhttpRequest({
method: 'post',
url: 'http://127.0.0.1:6699/api/ocr/slider/gap',
data: JSON.stringify({
gapimg_base64: gapimg_base64,
fullimg_base64: fullimg_base64
}),
headers: {
'Content-Type': 'application/json; charset=utf-8'
},
dataType: 'json',
onload: function(res) {
if (res.status === 200) {
const responseData = JSON.parse(res.responseText)
const padding = responseData.result.target[0]
resolve(padding)
} else {
//console.log('失败')
//console.log(res)
endCrack()
reject(0)
}
},
onerror: function(err) {
//console.log('error')
//console.log(err)
endCrack()
reject(0)
}
})
})
}
function getOffset2Img() {
return new Promise((resolve, reject) => {
// 步骤1: 加载图片
var img = new Image()
img.src = $('#img-button>img')
.attr('src')
img.onload = function() {
// 步骤2: 创建Canvas并绘制图片
var canvas = document.createElement('canvas')
canvas.width = img.width
canvas.height = img.height
var ctx = canvas.getContext('2d')
ctx.drawImage(img, 0, 0)
// 步骤3: 获取像素数据
var imageData = ctx.getImageData(0, 0, canvas.width, canvas.height)
var data = imageData.data
// 初始化最左边非透明像素点坐标
var leftMostPixel = { x: -1, y: -1 }
// 步骤4: 遍历每一行,寻找最左边的非透明像素点
for (var y = 0; y < canvas.height; y++) {
for (var x = 0; x < canvas.width; x++) {
var i = (y * canvas.width + x) * 4
if (data[i + 3] !== 0) { // 检查alpha通道是否不为0
// 如果这是第一个非透明像素点或者比之前记录的更靠左
if (leftMostPixel.x === -1 || x < leftMostPixel.x) {
leftMostPixel = { x: x, y: y }
}
break // 找到非透明像素点后,跳出内层循环
}
}
}
// 打印结果
if (leftMostPixel.x !== -1) {
//console.log('最左边的第一个非透明像素点坐标:', leftMostPixel)
resolve(leftMostPixel.x)
} else {
//console.log('没有找到非透明像素点')
resolve(0)
}
}
})
}
function doRareMove() {
// console.log('doRareMove')
var btn = $('#slide-button')[0]
var rect = btn.getBoundingClientRect()
var x = rect.x
var y = rect.y
var dx = getRandomInteger(-2, 2)
var dy = getRandomInteger(-2, 2)
var mousemove = document.createEvent('MouseEvents')
var _x = x + dx
var _y = y + dy
mousemove.initMouseEvent(
'mousemove',
true,
true,
document.defaultView,
0,
_x,
_y,
_x,
_y,
false,
false,
false,
false,
0,
null
)
btn.dispatchEvent(mousemove)
}
function doMove(length, gapOffset) {
if(!length){
length = 0
}
console.log('Move:',length,gapOffset)
var btn = $('#slide-button')[0]
var rect = btn.getBoundingClientRect()
var x = rect.x
var y = rect.y
var dx = 0
var dy = 0
let varible = null
var sliderLeft = $('#slider')
.offset().left
var targetLeft = $('#img-button > img')
.offset().left - sliderLeft
var targetWidth = $('#img-button > img')
.width()
var distance = length * 203 / 250
dx = distance / 3 + getRandomInteger(-10, 10)
var mousemove = document.createEvent('MouseEvents')
var _x = x + dx + getRandomInteger(0, 2)
var _y = y + dy + getRandomInteger(-2, 2)
mousemove.initMouseEvent(
'mousemove',
true,
true,
document.defaultView,
0,
_x,
_y,
_x,
_y,
false,
false,
false,
false,
0,
null
)
btn.dispatchEvent(mousemove)
var interval = setInterval(function() {
var mousemove = document.createEvent('MouseEvents')
var _x = x + dx + getRandomInteger(0, 2)
var _y = y + dy + getRandomInteger(-2, 2)
mousemove.initMouseEvent(
'mousemove',
true,
true,
document.defaultView,
0,
_x,
_y,
_x,
_y,
false,
false,
false,
false,
0,
null
)
btn.dispatchEvent(mousemove)
var newTargetLeft = $('#img-button > img')
.offset().left
varible = newTargetLeft - sliderLeft + gapOffset
//console.log('gapOffset:',gapOffset)
//console.log('distance:',distance)
//console.log('newTargetLeft:',newTargetLeft)
//console.log('sliderLeft:',sliderLeft)
//console.log('varible:',varible)
var size = varible - distance
//console.log('size:',size)
if (size > -1 && size < 1) {
doRareMove()
clearInterval(interval)
//console.log('varible >= distance,finish move:',varible , distance)
endCrack()
setTimeout(() => {
beginCrack()
}, 1000)
} else {
if (distance > varible) {
if (distance - varible > 40) {
dx += getRandomInteger(0, 4)
} else {
dx += getRandomInteger(4, 12)
}
} else {
dx -= getRandomInteger(0, 2)
}
}
}, 30)
setTimeout(() => {
clearInterval(interval)
endCrack()
setTimeout(() => {
beginCrack()
}, 1000)
}, 4000)
}
function waitElement(selector, times, interval, flag = true) {
var _times = times || 50, // 默认50次
_interval = interval || 100, // 默认每次间隔100毫秒
_selector = selector, //选择器
_iIntervalID,
_flag = flag; //定时器id
return new Promise(function (resolve, reject) {
_iIntervalID = setInterval(function () {
if (!_times) { //是0就退出
clearInterval(_iIntervalID);
reject();
}
_times <= 0 || _times--; //如果是正数就 --
var _self = document.querySelector(_selector); //再次选择
if ((_flag && _self) || (!_flag && !_self)) { //判断是否取到
clearInterval(_iIntervalID);
resolve(_self);
}
}, _interval);
});
}
function sleep(time) {
return new Promise((resolve) => {
setTimeout(() => {
resolve();
}, time);
});
}
function getRandomInteger(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min
}
function clearAllCookies() {
localStorage.clear();
sessionStorage.clear();
var cookies = document.cookie.split(";");
for (var i = 0; i < cookies.length; i++) {
var cookie = cookies[i];
var eqPos = cookie.indexOf("=");
var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
document.cookie = name + "=;expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/";
}
}
})()