执行步骤
STEP1:打开抖音网页版
STEP2:在抖音网页页面打开浏览器的控制台,
STEP3:将下述代码粘贴到控制台中后回车执行代码
※执行成功后会在页面中间显示执行状态
let key = JSON.parse(localStorage.getItem('security-sdk/s_sdk_cert_key')).data.replace(/^pub\./, '')
let max_cursorTemp = 0;
let messageBox = undefined;
var count = 0
async function fetchAndCancelLikes(maxCursor = max_cursorTemp) {
try {
const response = await fetch(`https://www.douyin.com/aweme/v1/web/aweme/favorite?aid=6383&count=999&max_cursor=${max_cursorTemp}`, {
"referrerPolicy": "strict-origin-when-cross-origin",
"body": null,
"method": "GET",
"mode": "cors",
"credentials": "include"
});
const { aweme_list, max_cursor } = await response.json();
max_cursorTemp = max_cursor;
if (aweme_list != null) {
const idsToCancel = aweme_list.map(({ aweme_id }) => aweme_id);
let currCount = 0
await Promise.all(idsToCancel.map(id => {
cancelLike(id, key);
currCount++;
count++;
})).then(()=>{
if(messageBox!=undefined){
document.body.removeChild(messageBox);
}
messageBox = showMessageBox(`本次执行取消${currCount}个点赞,共取消${count}个点赞,四秒后继续执行,如果不需要执行直接关闭浏览器,当前时间${new Date()}`)
});
}
} catch (error) {
console.error('Error fetching and canceling likes:', error);
}
}
async function cancelLike(id, key) {
try {
await fetch("https://www.douyin.com/aweme/v1/web/commit/item/digg/?aid=6383", {
"headers": {
"accept": "application/json, text/plain, */*",
"accept-language": "zh-CN,zh;q=0.9",
"bd-ticket-guard-ree-public-key": key,
"content-type": "application/x-www-form-urlencoded; charset=UTF-8"
},
"referrer": "https://www.douyin.com/user/self?modal_id=7308336895358930212&showTab=like",
"referrerPolicy": "strict-origin-when-cross-origin",
"body": `aweme_id=${id}&item_type=0&type=0`,
"method": "POST",
"mode": "cors",
"credentials": "include"
});
} catch (error) {
}
}
setInterval(fetchAndCancelLikes, 4000);
function showMessageBox(mess) {
var messageBox = document.createElement('div');
messageBox.id = 'autoMessageBox';
messageBox.style.position = 'fixed';
messageBox.style.top = '50%';
messageBox.style.left = '50%';
messageBox.style.transform = 'translate(-50%, -50%)';
messageBox.style.padding = '20px';
messageBox.style.backgroundColor = '#3498db';
messageBox.style.color = 'white';
messageBox.style.borderRadius = '5px';
messageBox.style.zIndex = '1000';
messageBox.style.display = 'block';
messageBox.textContent = mess;
document.body.appendChild(messageBox);
return messageBox
}