网页点击大挑战!
地址:http://110.42.220.200/test.html该网页使用了isTrusted验证
要求:使用脚本点击按钮,显示两个ok

奖励:100油猫币,以及一杯蜜雪冰城(蜜雪冰城请不起了)
警告:该网页不同于往期的油猴脚本开发教程,难度较大,如果基础不太好不推荐挑战
不明觉厉。 本帖最后由 Hangover 于 2021-11-26 14:09 编辑
// ==UserScript==
// @name 测试
// @namespace http://tampermonkey.net/
// @version 0.1
// @descriptiontry to take over the world!
// @author You
// @match http://110.42.220.200/test.html
// @require https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js
// ==/UserScript==
$(function(){
'use strict';
$('#btn').bind("myClick", function(){
$('#result').html('ok');
$('#result2').html('ok');
});
$('#btn').trigger("myClick");
});好像偷渡成功了?
Hangover 发表于 2021-11-26 14:04
好像偷渡成功了?
算偷渡!没有正式户籍没法颁发奖项! 雕虫小技竟然敢班门弄斧
大威天龙~
// ==UserScript==
// @name 艹翻李恒道(王一之)
// @namespace https://bbs.tampermonkey.net.cn/
// @version 0.1.0
// @descriptiontry to take over the world!
// @include http://110.42.220.200/test.html
// @author You
// @grant unsafeWindow
// @run-at document-start
// ==/UserScript==
var myEvent= function(){
var isTrusted=true;
var target = false;
function myEvent(){
this.isTrusted=true;
this.target=false
}
function PrivateConstructor() {
this.publicFunc = function() {}
this.isTrusted=true;
this.target=false;
}
PrivateConstructor.prototype = PointerEvent.prototype;
myEvent.prototype.target={id:'btn'};
return new PrivateConstructor()
}
var _1addEventListener = EventTarget.prototype.addEventListener;
EventTarget.prototype.addEventListener = function (tip,callback) {
let old = arguments
let args = [...arguments]
let temp = args;
arguments = function (ev) {
let args2 = [...arguments];
args2 = Object.assign({}, args2)
args2.target = ev.target;
args2.isTrusted = ev.isTrusted;
if(ev.target.id!='div'){
args2=new myEvent()
args2.isTrusted=true
Object.defineProperties(args2,{target:{value:{id:ev.target.id}}})
console.log(args2)
//debugger
}
return temp(...args2);
}
_1addEventListener.apply(this, arguments);
} 看了一下是对addEventListener做了手脚,我直接还原addEventListener绕开检测{:4_100:}// ==UserScript==
// @name 网页点击大挑战!
// @description网页点击大挑战!
// @namespace Sency
// @author Sency
// @version 1.0
// @match http://110.42.220.200/test.html
// @grant none
// @run-at document-start
// ==/UserScript==
(function() {
'use strict';
const oldAddEv = window.EventTarget.prototype.addEventListener;
const oldOnload = window.onload;
window.onload = () => {
oldOnload();
window.EventTarget.prototype.addEventListener = oldAddEv; //还原addEventListener
const btn = document.querySelector('#btn');
btn.addEventListener('click', e => {
e.stopImmediatePropagation(); //阻止原有事件监听
document.querySelector('#result').innerHTML = 'ok';
document.querySelector('#result2').innerHTML = 'ok';
}, true);
btn.click();
};
})();感觉你应该把addEventListener的劫持写到onload外面去,这样还原难度会大一点。
>本帖最后由 LinHQ 于 2021-11-27 23:05 编辑
```js
// ==UserScript==
// @name New script
// @namespace Violentmonkey Scripts
// @match http://110.42.220.200/*
// @grant none
// @version 0.0.1
// @author LinHQ
// @description 2021/11/26 下午7:01:33
// ==/UserScript==
// 直接去掉 alert
window.alert = () => false;
let old = EventTarget.prototype.addEventListener;
EventTarget.prototype.addEventListener = function (...args) {
let hdl = args;
args = function (...iargs) {
let tp = {};
for (let p in iargs){
tp = iargs;
}
tp.isTrusted = true;
//tp.__proto__ = Event.prototype;
Object.setPrototypeOf(tp, Event.prototype)
iargs = tp;
//console.log(iargs instanceof Event)
//return hdl(...iargs);
return hdl.apply(this, iargs);
}
//return old(...args);
return old.apply(this, args);
}
setTimeout(()=>document.querySelector("#btn").click(), 3500)
```
本来忘记 `this` 了的,但没想到这样反而不会反复弹窗 😄 。
---
嗯,略微改了下代码。
cxxjackie 发表于 2021-11-26 18:20
看了一下是对addEventListener做了手脚,我直接还原addEventListener绕开检测感觉你应该把addEven ...
想了一下这种做法有点取巧,是以破坏原有事件监听为前提的,实战中对简单事件还好,复杂的事件就不太适用了,改成下面的做法伪造一个事件进去:
// ==UserScript==
// @name 网页点击大挑战!
// @description网页点击大挑战!
// @namespace Sency
// @author Sency
// @version 2.0
// @match http://110.42.220.200/test.html
// @grant none
// @run-at document-start
// ==/UserScript==
(function() {
'use strict';
const oldAddEv = window.EventTarget.prototype.addEventListener;
const oldOnload = window.onload;
window.onload = () => {
const btn = document.querySelector('#btn');
window.EventTarget.prototype.addEventListener = function(...args) {
const callback = args;
args = function(e) {
if (e.target === btn && e.type === 'click') {
//用Proxy代理的对象可以通过instanceof Event检测
const eProxy = new Proxy(e, {
get: function(target, property) {
if (property === 'isTrusted') {
return true;
} else {
return Reflect.get(target, property);
}
}
});
return callback.call(this, eProxy);
} else {
return callback.call(this, e);
}
}
return oldAddEv.apply(this, args);
};
oldOnload();
btn.click();
};
})();
ok,搞定了,嘻嘻,好了嗷 结贴
页:
[1]
2