├── README.md ├── crack_encrypt.js ├── multibyte_trans_tool.py └── social_account_takover.py /README.md: -------------------------------------------------------------------------------- 1 | # hacker_tools 2 | this is my tools project ,welcome to start ... 3 | -------------------------------------------------------------------------------- /crack_encrypt.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name 一键Hook加密算法 3 | // @namespace By:亮亮 4 | // @version 1.2 5 | // @description 一键Hook Crypto RSA 几个基本的方法 AES DES 3DES Hmac SHA 6 | // @author liangliang 7 | // @match https://*/* 8 | // @match http://*/* 9 | // @icon  10 | // @grant none 11 | // ==/UserScript== 12 | 13 | (function() { 14 | 'use strict'; 15 | console.log("亮亮网页Hook脚本初始化成功"); 16 | //过dubugger 17 | var constructorEx = constructor; 18 | Function.prototype.constructor = function(s) { 19 | if (s == "debugger") { 20 | return null; 21 | } 22 | return constructorEx(s); 23 | } 24 | 25 | window.SHook = true 26 | window.IsDebugger = false 27 | function hex2b64(h) { 28 | var b64map = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; 29 | var i; 30 | var c; 31 | var ret = ""; 32 | for (i = 0; i + 3 <= h.length; i += 3) { 33 | c = parseInt(h.substring(i, i + 3), 16); 34 | ret += b64map.charAt(c >> 6) + b64map.charAt(c & 63); 35 | } 36 | if (i + 1 == h.length) { 37 | c = parseInt(h.substring(i, i + 1), 16); 38 | ret += b64map.charAt(c << 2); 39 | } else if (i + 2 == h.length) { 40 | c = parseInt(h.substring(i, i + 2), 16); 41 | ret += b64map.charAt(c >> 2) + b64map.charAt((c & 3) << 4); 42 | } 43 | while ((ret.length & 3) > 0) 44 | ret += "="; 45 | return ret; 46 | } 47 | if (window.CryptoJS != undefined) { 48 | var Crypto = window.CryptoJS 49 | //AES加解密 50 | if (Crypto.AES != undefined) { 51 | var AESencrypt = Crypto.AES.encrypt 52 | var AESdecrypt = Crypto.AES.decrypt 53 | window.CryptoJS.AES.encrypt = function() { 54 | var Data = arguments[0] 55 | if (Data == "" || window.SHook == false) { 56 | return AESencrypt(arguments[0], arguments[1], arguments[2]) 57 | } 58 | console.log('检测到AES加密:'); 59 | var AESKey = arguments[1] 60 | var AESIv = arguments[2]["iv"] 61 | console.log("EnData:" + CryptoJS.enc.Utf8.stringify(Data)) 62 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 63 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 64 | if (IsDebugger == true) { 65 | debugger ; 66 | } 67 | console.log("AES加密结果:" + AESencrypt(arguments[0], arguments[1], arguments[2])) 68 | return AESencrypt(arguments[0], arguments[1], arguments[2]) 69 | } 70 | window.CryptoJS.AES.decrypt = function() { 71 | var Data = arguments[0] 72 | if (Data == "" || window.SHook == false) { 73 | return AESdecrypt(arguments[0], arguments[1], arguments[2]) 74 | } 75 | console.log('检测到AES解密:'); 76 | var AESKey = arguments[1] 77 | var AESIv = arguments[2]["iv"] 78 | console.log("DeData:" + Data) 79 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 80 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 81 | if (IsDebugger == true) { 82 | debugger ; 83 | } 84 | console.log("AES解密结果:" + AESdecrypt(arguments[0], arguments[1], arguments[2])) 85 | return AESdecrypt(arguments[0], arguments[1], arguments[2]) 86 | } 87 | } 88 | //DES加解密 89 | if (Crypto.DES != undefined) { 90 | var DESencrypt = Crypto.DES.encrypt 91 | var DESdecrypt = Crypto.DES.decrypt 92 | window.CryptoJS.DES.encrypt = function() { 93 | var Data = arguments[0] 94 | if (Data == "" || window.SHook == false) { 95 | return DESencrypt(arguments[0], arguments[1], arguments[2]) 96 | } 97 | console.log('检测到DES加密:'); 98 | var AESKey = arguments[1] 99 | var AESIv = arguments[2]["iv"] 100 | console.log("EnData:" + CryptoJS.enc.Utf8.stringify(Data)) 101 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 102 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 103 | if (IsDebugger == true) { 104 | debugger ; 105 | } 106 | console.log("DES加密结果:" + AESencrypt(arguments[0], arguments[1], arguments[2])) 107 | return AESencrypt(arguments[0], arguments[1], arguments[2]) 108 | } 109 | window.CryptoJS.DES.decrypt = function() { 110 | var Data = arguments[0] 111 | if (Data == "" || window.SHook == false) { 112 | return AESdecrypt(arguments[0], arguments[1], arguments[2]) 113 | } 114 | console.log('检测到DES解密:'); 115 | var AESKey = arguments[1] 116 | var AESIv = arguments[2]["iv"] 117 | console.log("DeData:" + Data) 118 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 119 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 120 | if (IsDebugger == true) { 121 | debugger ; 122 | } 123 | console.log("DES解密结果:" + DESdecrypt(arguments[0], arguments[1], arguments[2])) 124 | return DESdecrypt(arguments[0], arguments[1], arguments[2]) 125 | } 126 | } 127 | //3DES加解密 128 | if (Crypto.TripleDES != undefined) { 129 | var TripleDESencrypt = Crypto.TripleDES.encrypt 130 | var TripleDESdecrypt = Crypto.TripleDES.decrypt 131 | window.CryptoJS.TripleDES.encrypt = function() { 132 | var Data = arguments[0] 133 | if (Data == "" || window.SHook == false) { 134 | return TripleDESencrypt(arguments[0], arguments[1], arguments[2]) 135 | } 136 | console.log('检测到TripleDES加密:'); 137 | var AESKey = arguments[1] 138 | var AESIv = arguments[2]["iv"] 139 | console.log("EnData:" + CryptoJS.enc.Utf8.stringify(Data)) 140 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 141 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 142 | if (IsDebugger == true) { 143 | debugger ; 144 | } 145 | console.log("TripleDES加密结果:" + AESencrypt(arguments[0], arguments[1], arguments[2])) 146 | return AESencrypt(arguments[0], arguments[1], arguments[2]) 147 | } 148 | window.CryptoJS.TripleDES.decrypt = function() { 149 | var Data = arguments[0] 150 | if (Data == "" || window.SHook == false) { 151 | return AESdecrypt(arguments[0], arguments[1], arguments[2]) 152 | } 153 | console.log('检测到TripleDES解密:'); 154 | var AESKey = arguments[1] 155 | var AESIv = arguments[2]["iv"] 156 | console.log("DeData:" + Data) 157 | console.log("AES Key:" + CryptoJS.enc.Utf8.stringify(AESKey)) 158 | console.log("AES Iv:" + CryptoJS.enc.Utf8.stringify(AESIv)) 159 | if (IsDebugger == true) { 160 | debugger ; 161 | } 162 | console.log("TripleDES解密结果:" + TripleDESdecrypt(arguments[0], arguments[1], arguments[2])) 163 | return TripleDESdecrypt(arguments[0], arguments[1], arguments[2]) 164 | } 165 | } 166 | //Hmac 167 | var HMAC_MD5encrypt = Crypto.HmacMD5 168 | var HMAC_SHA1encrypt = Crypto.HmacSHA1 169 | var HMAC_SHA256encrypt = Crypto.HmacSHA256 170 | var HMAC_SHA384encrypt = Crypto.HmacSHA384 171 | var HMAC_SHA512encrypt = Crypto.HmacSHA512 172 | 173 | if (Crypto.HmacMD5 != undefined) { 174 | window.CryptoJS.HmacMD5 = function() { 175 | var Data = arguments[0]; 176 | if (Data == "" || window.SHook == false) { 177 | return HMAC_MD5encrypt(arguments[0], arguments[1]); 178 | } 179 | ;console.log("检测到HmacMD5加密:"); 180 | var HmacKey = arguments[1]; 181 | console.log("EnData:" + Data); 182 | console.log("HmacKey:" + HmacKey); 183 | if (IsDebugger == true) { 184 | debugger ; 185 | } 186 | console.log("HmacMD5加密:" + HMAC_MD5encrypt(arguments[0], arguments[1])) 187 | return HMAC_MD5encrypt(arguments[0], arguments[1]); 188 | } 189 | } 190 | if (Crypto.HmacSHA1 != undefined) { 191 | window.CryptoJS.HmacSHA1 = function() { 192 | var Data = arguments[0]; 193 | if (Data == "" || window.SHook == false) { 194 | return HMAC_SHA1encrypt(arguments[0], arguments[1]); 195 | } 196 | ;console.log("检测到HmacSHA1加密:"); 197 | var HmacKey = arguments[1]; 198 | console.log("EnData:" + Data); 199 | console.log("HmacKey:" + HmacKey); 200 | if (IsDebugger == true) { 201 | debugger ; 202 | } 203 | console.log("HmacSHA1加密:" + HMAC_SHA1encrypt(arguments[0], arguments[1])) 204 | return HMAC_SHA1encrypt(arguments[0], arguments[1]); 205 | } 206 | } 207 | if (Crypto.HmacSHA256 != undefined) { 208 | window.CryptoJS.HmacSHA256 = function() { 209 | var Data = arguments[0]; 210 | if (Data == "" || window.SHook == false) { 211 | return HMAC_SHA256encrypt(arguments[0], arguments[1]); 212 | } 213 | ;console.log("检测到HmacSHA256加密:"); 214 | var HmacKey = arguments[1]; 215 | console.log("EnData:" + Data); 216 | console.log("HmacKey:" + HmacKey); 217 | if (IsDebugger == true) { 218 | debugger ; 219 | } 220 | console.log("HmacSHA256加密:" + HMAC_SHA256encrypt(arguments[0], arguments[1])) 221 | return HMAC_SHA256encrypt(arguments[0], arguments[1]); 222 | } 223 | } 224 | if (Crypto.HmacSHA384 != undefined) { 225 | window.CryptoJS.HmacSHA384 = function() { 226 | var Data = arguments[0]; 227 | if (Data == "" || window.SHook == false) { 228 | return HMAC_SHA384encrypt(arguments[0], arguments[1]); 229 | } 230 | ;console.log("检测到HmacSHA384加密:"); 231 | var HmacKey = arguments[1]; 232 | console.log("EnData:" + Data); 233 | console.log("HmacKey:" + HmacKey); 234 | if (IsDebugger == true) { 235 | debugger ; 236 | } 237 | console.log("HmacSHA384加密:" + HMAC_SHA384encrypt(arguments[0], arguments[1])) 238 | return HMAC_SHA384encrypt(arguments[0], arguments[1]); 239 | } 240 | } 241 | if (Crypto.HmacSHA512 != undefined) { 242 | window.CryptoJS.HmacSHA512 = function() { 243 | var Data = arguments[0]; 244 | if (Data == "" || window.SHook == false) { 245 | return HMAC_SHA512encrypt(arguments[0], arguments[1]); 246 | } 247 | ;console.log("检测到HmacSHA512加密:"); 248 | var HmacKey = arguments[1]; 249 | console.log("EnData:" + Data); 250 | console.log("HmacKey:" + HmacKey); 251 | if (IsDebugger == true) { 252 | debugger ; 253 | } 254 | console.log("HmacSHA512加密:" + HMAC_SHA512encrypt(arguments[0], arguments[1])) 255 | return HMAC_SHA512encrypt(arguments[0], arguments[1]); 256 | } 257 | } 258 | //Rabbit加解密 259 | if (Crypto.TripleDES != undefined) { 260 | var Rabbitencrypt = Crypto.Rabbit.encrypt 261 | var Rabbitdecrypt = Crypto.Rabbit.decrypt 262 | window.CryptoJS.Rabbit.encrypt = function() { 263 | var Data = arguments[0] 264 | if (Data == "" || window.SHook == false) { 265 | return Rabbitencrypt(arguments[0], arguments[1]) 266 | } 267 | console.log('检测到Rabbit加密:'); 268 | console.log("EnData:" + Data) 269 | console.log("Key:" + arguments[1]) 270 | if (IsDebugger == true) { 271 | debugger ; 272 | } 273 | console.log("Rabbit加密:" + Rabbitencrypt(arguments[0], arguments[1])) 274 | return Rabbitencrypt(arguments[0], arguments[1]) 275 | } 276 | window.CryptoJS.Rabbit.decrypt = function() { 277 | var Data = arguments[0] 278 | if (Data == "" || window.SHook == false) { 279 | return Rabbitdecrypt(arguments[0], arguments[1]) 280 | } 281 | console.log('检测到Rabbit解密:'); 282 | console.log("DeData:" + Data) 283 | console.log("Key:" + arguments[1]) 284 | if (IsDebugger == true) { 285 | debugger ; 286 | } 287 | console.log("Rabbit解密:" + Rabbitdecrypt(arguments[0], arguments[1])) 288 | return Rabbitdecrypt(arguments[0], arguments[1]) 289 | } 290 | } 291 | //PBKDF2加解密 292 | if (Crypto.PBKDF2 != undefined) { 293 | var PBKDF2encrypt = Crypto.PBKDF2 294 | window.CryptoJS.PBKDF2 = function() { 295 | var Data = arguments[0] 296 | if (Data == "" || window.SHook == false) { 297 | return PBKDF2encrypt(arguments[0], arguments[1], arguments[2]) 298 | } 299 | console.log('检测到PBKDF2加密:'); 300 | console.log("EnData:" + Data) 301 | console.log("Salt:" + arguments[1]) 302 | console.log("KeySize:" + arguments[2]['keySize']) 303 | console.log("iterations:" + arguments[2]['iterations']) 304 | if (IsDebugger == true) { 305 | debugger ; 306 | } 307 | console.log("PBKDF2加密:" + PBKDF2encrypt(arguments[0], arguments[1], arguments[2])) 308 | return PBKDF2encrypt(arguments[0], arguments[1], arguments[2]) 309 | } 310 | } 311 | //PBKDF2加解密 312 | if (Crypto.EvpKDF != undefined) { 313 | var EvpKDFencrypt = Crypto.EvpKDF 314 | window.CryptoJS.EvpKDF = function() { 315 | var Data = arguments[0] 316 | if (Data == "" || window.SHook == false) { 317 | return EvpKDFencrypt(arguments[0], arguments[1], arguments[2]) 318 | } 319 | console.log('检测到EvpKDF加密:'); 320 | console.log("EnData:" + Data) 321 | console.log("Salt:" + arguments[1]) 322 | console.log("KeySize:" + arguments[2]['keySize']) 323 | console.log("iterations:" + arguments[2]['iterations']) 324 | if (IsDebugger == true) { 325 | debugger ; 326 | } 327 | console.log("EvpKDF加密:" + EvpKDFencrypt(arguments[0], arguments[1], arguments[2])) 328 | return EvpKDFencrypt(arguments[0], arguments[1], arguments[2]) 329 | } 330 | } 331 | //Md5加密 332 | if (Crypto.MD5 != undefined) { 333 | var MD5encrypt = Crypto.MD5 334 | window.CryptoJS.MD5 = function() { 335 | var Data = arguments[0] 336 | if (Data == "" || window.SHook == false) { 337 | return MD5encrypt(arguments[0]) 338 | } 339 | console.log('检测到MD5加密:'); 340 | console.log("EnData:" + Data) 341 | if (IsDebugger == true) { 342 | debugger ; 343 | } 344 | console.log("MD5加密:" + MD5encrypt(arguments[0])) 345 | return MD5encrypt(arguments[0]) 346 | } 347 | } 348 | //SHA1加密 349 | if (Crypto.SHA1 != undefined) { 350 | var SHA1encrypt = Crypto.SHA1 351 | window.CryptoJS.SHA1 = function() { 352 | var Data = arguments[0] 353 | if (Data == "" || window.SHook == false) { 354 | return SHA1encrypt(arguments[0]) 355 | } 356 | console.log('检测到SHA1加密:'); 357 | console.log("EnData:" + Data) 358 | if (IsDebugger == true) { 359 | debugger ; 360 | } 361 | console.log("SHA1加密:" + SHA1encrypt(arguments[0])) 362 | return SHA1encrypt(arguments[0]) 363 | } 364 | } 365 | //SHA3加密 366 | if (Crypto.SHA3 != undefined) { 367 | var SHA3encrypt = Crypto.SHA3 368 | window.CryptoJS.SHA3 = function() { 369 | var Data = arguments[0] 370 | if (Data == "" || window.SHook == false) { 371 | return SHA3encrypt(arguments[0]) 372 | } 373 | console.log('检测到SHA3加密:'); 374 | console.log("EnData:" + Data) 375 | if (IsDebugger == true) { 376 | debugger ; 377 | } 378 | console.log("SHA3加密:" + SHA3encrypt(arguments[0])) 379 | return SHA3encrypt(arguments[0]) 380 | } 381 | } 382 | //SHA224加密 383 | if (Crypto.SHA224 != undefined) { 384 | var SHA224encrypt = Crypto.SHA224 385 | window.CryptoJS.SHA224 = function() { 386 | var Data = arguments[0] 387 | if (Data == "" || window.SHook == false) { 388 | return SHA224encrypt(arguments[0]) 389 | } 390 | console.log('检测到SHA224加密:'); 391 | console.log("EnData:" + Data) 392 | if (IsDebugger == true) { 393 | debugger ; 394 | } 395 | console.log("SHA224加密:" + SHA224encrypt(arguments[0])) 396 | return SHA224encrypt(arguments[0]) 397 | } 398 | } 399 | //SHA256加密 400 | if (Crypto.SHA256 != undefined) { 401 | var SHA256encrypt = Crypto.SHA256 402 | window.CryptoJS.SHA256 = function() { 403 | var Data = arguments[0] 404 | if (Data == "" || window.SHook == false) { 405 | return SHA256encrypt(arguments[0]) 406 | } 407 | console.log('检测到SHA256加密:'); 408 | console.log("EnData:" + Data) 409 | if (IsDebugger == true) { 410 | debugger ; 411 | } 412 | console.log("SHA256加密:" + SHA256encrypt(arguments[0])) 413 | return SHA256encrypt(arguments[0]) 414 | } 415 | } 416 | //SHA384加密 417 | if (Crypto.SHA384 != undefined) { 418 | var SHA384encrypt = Crypto.SHA384 419 | window.CryptoJS.SHA384 = function() { 420 | var Data = arguments[0] 421 | if (Data == "" || window.SHook == false) { 422 | return SHA384encrypt(arguments[0]) 423 | } 424 | console.log('检测到SHA384加密:'); 425 | console.log("EnData:" + Data) 426 | if (IsDebugger == true) { 427 | debugger ; 428 | } 429 | console.log("SHA384加密:" + SHA384encrypt(arguments[0])) 430 | return SHA384encrypt(arguments[0]) 431 | } 432 | } 433 | //SHA512加密 434 | if (Crypto.SHA512 != undefined) { 435 | var SHA512encrypt = Crypto.SHA512 436 | window.CryptoJS.SHA512 = function() { 437 | var Data = arguments[0] 438 | if (Data == "" || window.SHook == false) { 439 | return SHA512encrypt(arguments[0]) 440 | } 441 | console.log('检测到SHA512加密:'); 442 | console.log("EnData:" + Data) 443 | if (IsDebugger == true) { 444 | debugger ; 445 | } 446 | console.log("SHA512加密:" + SHA512encrypt(arguments[0])) 447 | return SHA512encrypt(arguments[0]) 448 | } 449 | } 450 | //RIPEMD160加密 451 | if (Crypto.RIPEMD160encrypt != undefined) { 452 | var RIPEMD160encrypt = Crypto.RIPEMD160 453 | window.CryptoJS.RIPEMD160 = function() { 454 | var Data = arguments[0] 455 | if (Data == "" || window.SHook == false) { 456 | return RIPEMD160encrypt(arguments[0]) 457 | } 458 | console.log('检测到RIPEMD160加密:'); 459 | console.log("EnData:" + Data) 460 | if (IsDebugger == true) { 461 | debugger ; 462 | } 463 | console.log("RIPEMD160加密:" + RIPEMD160encrypt(arguments[0])) 464 | return RIPEMD160encrypt(arguments[0]) 465 | } 466 | } 467 | } 468 | //RSA 加解密 469 | if (window.biToHex != undefined) { 470 | var ToHex = window.biToHex 471 | if (window.encryptedString != undefined) { 472 | var RsaEncrypt = window.encryptedString 473 | window.encryptedString = function() { 474 | var KeyPair = arguments[0]; 475 | var Data = arguments[1] 476 | if (Data == "" || window.SHook == false) { 477 | return RsaEncrypt(KeyPair, Data) 478 | } 479 | console.log('检测到RSA加密:'); 480 | var PublicKey = ToHex(KeyPair.e).substr(2) 481 | //取右边6位就是公钥了 482 | var Modulus = "00" + ToHex(KeyPair.m); 483 | //前面补俩个0 484 | console.log("EnData:" + Data); 485 | console.log("PublicKey:" + PublicKey); 486 | console.log("Modulus:" + Modulus); 487 | if (IsDebugger == true) { 488 | debugger ; 489 | } 490 | console.log("RSA加密:" + RsaEncrypt(KeyPair, Data)) 491 | return RsaEncrypt(KeyPair, Data) 492 | } 493 | } 494 | if (window.decryptedString != undefined) { 495 | var RsaDecrypt = window.decryptedString 496 | window.decryptedString = function() { 497 | var KeyPair = arguments[0]; 498 | var Data = arguments[1] 499 | if (Data == "" || window.SHook == false) { 500 | return RsaEncrypt(KeyPair, Data) 501 | } 502 | console.log('检测到RSA加密:'); 503 | var PublicKey = ToHex(KeyPair.e).substr(2) 504 | //取右边6位就是公钥了 505 | var Modulus = "00" + ToHex(KeyPair.m); 506 | //前面补俩个0 507 | console.log("EnData:" + Data); 508 | console.log("PublicKey:" + PublicKey); 509 | console.log("Modulus:" + Modulus); 510 | if (IsDebugger == true) { 511 | debugger ; 512 | } 513 | console.log("RSA加密:" + RsaDecrypt(KeyPair, Data)) 514 | return RsaDecrypt(KeyPair, Data) 515 | } 516 | } 517 | } 518 | if (window.JSEncrypt != undefined) { 519 | var RSA = window.JSEncrypt.prototype 520 | if (RSA.encrypt != undefined) { 521 | var RSA_encrypt = RSA.encrypt 522 | window.JSEncrypt.prototype.encrypt = function() { 523 | var Data = arguments[0] 524 | if (Data == "" || window.SHook == false) { 525 | return hex2b64(RSA.key.encrypt(Data)) 526 | } 527 | console.log('检测到RSA加密:'); 528 | console.log('EnData:' + Data); 529 | if (IsDebugger == true) { 530 | debugger ; 531 | } 532 | console.log("RSA加密:" + hex2b64(RSA.key.encrypt(Data))) 533 | return hex2b64(RSA.key.encrypt(Data)) 534 | } 535 | } 536 | if (RSA.decrypt != undefined) { 537 | var RSA_decrypt = RSA.decrypt 538 | window.JSEncrypt.prototype.decrypt = function() { 539 | var Data = arguments[0] 540 | if (Data == "" || window.SHook == false) { 541 | return hex2b64(RSA.key.decrypt(Data)) 542 | } 543 | console.log('检测到RSA解密:'); 544 | console.log('DeData:' + Data); 545 | if (IsDebugger == true) { 546 | debugger ; 547 | } 548 | console.log("RSA解密:" + hex2b64(RSA.key.decrypt(Data))) 549 | return hex2b64(RSA.key.decrypt(Data)) 550 | } 551 | } 552 | if (RSA.setPublicKey != undefined) { 553 | var RSA_setPublicKey = RSA.setPublicKey 554 | window.JSEncrypt.prototype.setPublicKey = function() { 555 | var Data = arguments[0] 556 | if (Data == "" || window.SHook == false) { 557 | return RSA.setKey(Data) 558 | return 559 | } 560 | console.log('检测到RSA设置公钥:'); 561 | console.log('PublicKey:' + Data); 562 | if (IsDebugger == true) { 563 | debugger ; 564 | } 565 | return RSA.setKey(Data) 566 | } 567 | } 568 | if (RSA.setPrivateKey != undefined) { 569 | var RSA_setPrivateKey = RSA.setPrivateKey 570 | window.JSEncrypt.prototype.setPrivateKey = function() { 571 | var Data = arguments[0] 572 | if (Data == "" || window.SHook == false) { 573 | return RSA.setKey(Data) 574 | } 575 | console.log('检测到RSA设置私钥:'); 576 | console.log('PrivateKey:' + Data); 577 | if (IsDebugger == true) { 578 | debugger ; 579 | } 580 | return RSA.setKey(Data) 581 | } 582 | } 583 | 584 | } 585 | } 586 | )(); 587 | -------------------------------------------------------------------------------- /multibyte_trans_tool.py: -------------------------------------------------------------------------------- 1 | # -*- coding: utf-8 -*- 2 | ''' 3 | @author : Captain0X 4 | @time : 2022/11/21 16:54 5 | ''' 6 | from string import punctuation 7 | 8 | def trans_multi_encoding(char_str): 9 | multi_char="" 10 | for char in char_str: 11 | if char in punctuation: 12 | multi_char+=bytes('\\u56' +'%02x' % ord(char),encoding="utf-8").decode('raw_unicode_escape') 13 | else: 14 | multi_char+=char 15 | print('-------------------------------\noutput:\n',multi_char) 16 | banner=""" 17 | input: 18 | <% =7 * 7 %> 19 | 20 | output: 21 | 嘼嘥 嘽7 嘪 7 嘥嘾 22 | you can copy this result to burp ,burp will trans to code auto~ 23 | tools_code_by_Captain0X 24 | 25 | """ 26 | print(banner) 27 | while True: 28 | code=input("please input your code(input 0 exit):") 29 | if code=='0': 30 | exit() 31 | trans_multi_encoding(code) 32 | -------------------------------------------------------------------------------- /social_account_takover.py: -------------------------------------------------------------------------------- 1 | # -*- coding: utf-8 -*- 2 | ''' 3 | @author : Captain0X 4 | @time : 2023/1/5 12:54 5 | #脚本逻辑参考:https://github.com/utkusen/socialhunter/blob/main/main.go 6 | 谷歌關鍵詞:intext:twitter.com site:hellosign.com 7 | fofa:body="tiktok.com/@" && domain="dropbox.com" 8 | ''' 9 | import re 10 | import threading 11 | import time 12 | from urllib.parse import urlparse 13 | import requests 14 | import warnings 15 | warnings.filterwarnings('ignore') 16 | 17 | 18 | unique_link = [] 19 | 20 | 21 | def output_msg(*args, color="green"): 22 | msg = "".join([f"{_}"for _ in args]) 23 | if color == "red": 24 | template = f'\033[1;31m[{time.strftime("%Y-%m-%d %H:%M:%S")}]{msg}\033[0m' 25 | else: 26 | template = f'\033[1;32m[{time.strftime("%Y-%m-%d %H:%M:%S")}]{msg}\033[0m' 27 | print(template) 28 | 29 | 30 | def get_thd_num(thd_keyword): 31 | '''根据线程名关键词获取线程数''' 32 | thd_pool = [] 33 | for td in threading.enumerate(): 34 | cur_api = td.getName() 35 | if cur_api.startswith(thd_keyword): 36 | thd_pool.append(cur_api) 37 | output_msg( 38 | f"[{time.strftime('%Y-%m-%d %H:%M:%S')}] current thd is {thd_pool} thd_num is {len(thd_pool)}") 39 | return thd_pool 40 | 41 | 42 | def send_req(idx, url, headers=None, use_replit=True): 43 | # File operations (such as logging) can block the 44 | # event loop: run them in a thread pool. 45 | try: 46 | output_msg("正在爬取:", url) 47 | if not headers: 48 | headers = { 49 | 'user-agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.221 Safari/537.36 SE 2.X MetaSr 1.0'} 50 | headers = {'sec-ch-ua': '"Not?A_Brand";v="8", "Chromium";v="108", "Google Chrome";v="108"', 51 | 'sec-ch-ua-mobile': '?0', 'sec-ch-ua-platform': '"Windows"', 'sec-fetch-dest': 'document', 52 | 'sec-fetch-mode': 'navigate', 'sec-fetch-site': 'none', 'sec-fetch-user': '?1', 53 | 'upgrade-insecure-requests': '1', 54 | 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36'} 55 | 56 | resp = requests.get(url, headers=headers, timeout=80, verify=False, 57 | # 设置小飞机代理 58 | # proxies={"http": "http:127.0.0.1:10809", 59 | # "https": "https://127.0.0.1:10809"}, 60 | ) 61 | print(resp.content) 62 | output_msg("爬取完成:", url) 63 | return resp 64 | except: 65 | return {} 66 | 67 | 68 | def get_all_links(url, task_que): 69 | # https://x.redditinc.com/ 樣本 70 | # https://kb.acronis.com/ 71 | if url == "finish": 72 | task_que.put(("finish", "finish", url)) 73 | denyList = ["js", "jpg", "jpeg", "png", "gif", "bmp", "svg", "mp4", "webm", "mp3", "csv", "ogg", "wav", "flac", 74 | "aac", "wma", "wmv", "avi", "mpg", "mpeg", "mov", "mkv", "zip", "rar", "7z", "tar", "iso", "doc", 75 | "docx", "xls", "xlsx", "ppt", "pptx", "pdf", "txt", "rtf", "odt", "ods", "odp", "odg", "odf", "odb", 76 | "odc", "odm", "avi", "mpg", "mpeg", "mov", "mkv", "zip", "rar", "7z", "tar", "iso", "doc", "docx", 77 | "xls", "xlsx", "ppt", "pptx", "pdf", "txt", "rtf", "odt", "ods", "odp", "odg", "odf", "odb", "odc", 78 | "odm", "mp4", "webm", "mp3", "ogg", "wav", "flac", "aac", "wma", "wmv", "avi", "mpg", "mpeg", "mov", 79 | "mkv", "zip", "rar", "7z", "tar", "iso", "doc", "docx", "xls", "xlsx", "ppt", "pptx", "pdf", "txt", 80 | "rtf", "odt", "ods", "odp", "odg", "odf", "odb", "odc", "odm", "mp4", "webm", "mp3", "ogg", "wav", 81 | "flac", "aac", "wma", "wmv", "avi", "mpg", "mpeg", "mov", "mkv", "zip", "rar", "7z", "tar", "iso", 82 | "doc", "docx", "xls", "xlsx", "ppt", "pptx", "pdf", "txt", "rtf", "odt"] 83 | if url.split(".")[-1] in denyList: 84 | return 85 | if url in unique_link: 86 | return 87 | # gov白嫖党封杀 88 | if urlparse(url).netloc.endswith(".gov"): 89 | return 90 | unique_link.append(url) 91 | res_body = send_req(url, url) 92 | if not hasattr(res_body, "text"): 93 | return 94 | 95 | html = res_body.text 96 | print(html) 97 | links = re.findall("""["']https?:\/\/.*?['"]""", html) 98 | for link in links: 99 | link = re.sub("""['\"]""", "", link) 100 | # output_msg(link) 101 | link_host = urlparse(link).netloc 102 | if len(link) > 60 or re.findall("intent/tweet", link) or re.findall("twitter.com/share", link) or re.findall( 103 | "twitter.com/privacy", link) or re.findall("facebook.com/home", link) or re.findall( 104 | "instagram.com/p/", link) or re.findall('sharer/sharer.php', link): 105 | continue 106 | if link in unique_link: 107 | continue 108 | unique_link.append(link) 109 | task_que.put((link, link_host, url)) 110 | # check_account_takover(link, link_host, url) 111 | 112 | # output_msg(html) 113 | 114 | 115 | def check_twitter_user(username): 116 | '''推特用户需要从浏览器中复制推特的cookie''' 117 | api = f"https://api.twitter.com/graphql/hVhfo_TquFTmgL7gYwf91Q/UserByScreenName?variables=%7B%22screen_name%22%3A%22{username}%22%2C%22withSafetyModeUserFields%22%3Atrue%2C%22withSuperFollowsUserFields%22%3Atrue%7D&features=%7B%22responsive_web_twitter_blue_verified_badge_is_enabled%22%3Atrue%2C%22verified_phone_label_enabled%22%3Afalse%2C%22responsive_web_graphql_timeline_navigation_enabled%22%3Atrue%7D" 118 | headers = {'accept': '*/*', 'accept-encoding': 'gzip, deflate, br', 119 | 'accept-language': 'en-US,en;q=0.9,zh-CN;q=0.8,zh;q=0.7', 120 | 'authorization': 'Bearer AAAAAAAAAAAI8xjhLTvJu4FA33AGWWjCpTnA', 121 | 'cache-control': 'no-cache', 'content-type': 'application/json', 122 | 'cookie': '_ga=GA1.2.2022108602.1578133858; remember_checked_on=1; guest_id_marketing=v1%3A160989111254248434; guest_id_ads=v1%3A160989111254248434; lang=zh-cn; _gid=GA1.2.299034402.1674529197; dnt=1; personalization_id="v1_5zROruDVi6R+V+sIn7hqYg=="; guest_id=v1%3A167498337570740111; _twitter_sess=BAh7CSIKZmxhc2hJQzonQWN0aW9uQ29udHJvbGxlcjo6Rmxhc2g6OkZsYXNo%250ASGFzaHsABjoKQHVzZWR7ADoPY3JlYXRlZF9hdGwrCL7TyvyFAToMY3NyZl9p%250AZCIlMGU1NzFjM2FmNzdkOTkzNDQ0OTNmOTcxNGVlZWI5ZGM6B2lkIiViOGIy%250AN2JhNTAzMWI0YjAyNDUzMWY1NjEzNTc0OTJmNg%253D%253D--abab13309670d6d2374a5691ab92ab34a4ea3f80; external_referer=padhuUp37zguL6FRibh2KjyphEsSyaM2|0|8e8t2xd8A2w%3D; gt=1619682955533910017; kdt=aEK47Gn43bCYyD0dzdOXULNncX1w2UFhIzcRxoII; auth_token=3a7b0164522ad967f2f5d5bf091b4039b3cf8831; twid=u%3D4246192519; att=1-QC2B6vF61vpCO6PF8Uxzjt9bdj799hm7NWXtQB6W; ct0=22bcca6d856183cd65916c6f4b77afb5f221a203a30218ffbc86b1d37046707e12c054bada8c8224ffe9c0e949bfeef8e13a429f37e854c927110e65d8dfc66b1b107dd156306bbc94cc6a6ce7441750', 123 | 'origin': 'https://twitter.com', 'pragma': 'no-cache', 'referer': 'https://twitter.com/', 124 | 'sec-ch-ua': '"Not_A Brand";v="99", "Google Chrome";v="109", "Chromium";v="109"', 125 | 'sec-ch-ua-mobile': '?0', 'sec-ch-ua-platform': '"Windows"', 'sec-fetch-dest': 'empty', 126 | 'sec-fetch-mode': 'cors', 'sec-fetch-site': 'same-site', 127 | 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/109.0.0.0 Safari/537.36', 128 | 'x-csrf-token': '22bc03a30218ffbc86b1d37046707e12c054bada8c8224ffe9c0e949bfeef8e13a429f37e854c927110e65d8dfc66b1b107dd156306bbc94cc6a6ce7441750', 129 | 'x-twitter-active-user': 'yes', 'x-twitter-auth-type': 'OAuth2Session', 130 | 'x-twitter-client-language': 'zh-cn'} 131 | resp = send_req("twitter", api, headers, use_replit=False) 132 | if hasattr(resp, "status_code"): 133 | if re.findall(username, str(resp.content), re.IGNORECASE): 134 | return False 135 | else: 136 | return True 137 | return "except" 138 | 139 | 140 | def check_account_takover(task_que, scan_result_path): 141 | while True: 142 | link, link_host, url = task_que.get() 143 | if link == "finish": 144 | break 145 | if re.findall("facebook\.com", link_host): 146 | # facebook存在反爬的情况,建议降低速度 147 | time.sleep(3) 148 | # https://www.facebook.com/reddit 149 | #