faucet.py 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. # -*- coding: utf-8 -*-
  2. import re
  3. import httpx
  4. import asyncio
  5. import json
  6. import random
  7. import logging
  8. from typing import List
  9. from fake_useragent import UserAgent # 导入 fake_useragent 模块
  10. # 配置日志
  11. logging.basicConfig(
  12. level=logging.INFO,
  13. format='%(asctime)s - %(levelname)s - %(message)s'
  14. )
  15. logger = logging.getLogger(__name__)
  16. # 初始化 fake_useragent
  17. ua = UserAgent()
  18. async def send_post_request(wallet: str, timeout: float = 10.0) -> None:
  19. """
  20. 向目标网站发送 POST 请求以领取水。
  21. Args:
  22. wallet: 钱包地址
  23. timeout: 请求超时时间(秒)
  24. """
  25. url = "https://faucet.nerzo.xyz/monad"
  26. headers = {
  27. "accept": "text/x-component",
  28. "accept-encoding": "gzip, deflate, br, zstd",
  29. "accept-language": "zh-CN,zh;q=0.9",
  30. "content-type": "text/plain;charset=UTF-8",
  31. "next-action": "405d6e23437f844564e65cdd65851724c449d7f778",
  32. "next-router-state-tree": '["",{"children":["(faucet)",{"children":["monad",{"children":["__PAGE__",{},"/monad","refresh"]}]}]},null,null,true]',
  33. "origin": "https://faucet.nerzo.xyz",
  34. "priority": "u=1, i",
  35. "referer": "https://faucet.nerzo.xyz/monad",
  36. "sec-ch-ua": '"Chromium";v="130", "Google Chrome";v="130", "Not?A_Brand";v="99"',
  37. "sec-ch-ua-mobile": "?0",
  38. "sec-ch-ua-platform": '"Windows"',
  39. "sec-fetch-dest": "empty",
  40. "sec-fetch-mode": "cors",
  41. "sec-fetch-site": "same-origin",
  42. "user-agent": ua.random,
  43. "x-deployment-id": "dpl_DWgqqeB8V4ASD1aCKUqWZwcPwnVd"
  44. }
  45. payload = json.dumps([wallet])
  46. async with httpx.AsyncClient(timeout=timeout, proxy={'http://': 'http://127.0.0.1:7890'}) as client:
  47. retry = 3
  48. while retry > 0: # 修复了 retry 的逻辑错误
  49. try:
  50. response = await client.post(url, headers=headers, content=payload)
  51. # logger.info(f"Wallet: {wallet} | Status Code: {response.status_code} | Response: {response.text}")
  52. logger.info(f"Wallet: {wallet} | Status Code: {response.status_code}")
  53. if 'message' in response.text:
  54. message = re.findall(r'"message":"(.*?)"', response.text)[0]
  55. logger.info(f"Wallet: {wallet} | Message: {message}")
  56. return response
  57. except httpx.RequestError as e:
  58. logger.error(f"Wallet: {wallet} | Request failed: {e}")
  59. retry -= 1
  60. if retry <= 0:
  61. return None
  62. async def main(wallet_list: List[str], min_delay: float = 5.0, max_delay: float = 8.0) -> None:
  63. """
  64. 批量处理钱包地址,发送 POST 请求,并添加随机延时。
  65. Args:
  66. wallet_list: 钱包地址列表
  67. min_delay: 最小延时(秒)
  68. max_delay: 最大延时(秒)
  69. """
  70. for i, wallet in enumerate(wallet_list, 1):
  71. logger.info(f"Processing wallet {i}/{len(wallet_list)}: {wallet}")
  72. await send_post_request(wallet)
  73. # 在最后一个钱包之前添加随机延时
  74. if i < len(wallet_list):
  75. delay = random.uniform(min_delay, max_delay)
  76. logger.info(f"Waiting for {delay:.2f} seconds before next request")
  77. await asyncio.sleep(delay)
  78. if __name__ == "__main__":
  79. wallet_list = [
  80. '0xe50B77Cd771243b8Ae1d6ce33b4E13ECC5Fa28a6',
  81. '0x9ea2ECAD4090E32916e03b77d7C75CbF6C8E0A55',
  82. '0xE8A4b0C04300154DC9B1D0e565Ba70F996614690',
  83. '0x1b623c5d70c93b437d93c305bf2cfa389095f636',
  84. '0x06D25c3e0E1F753ac0486a3f8aaD7259149656cB',
  85. '0x15cFEE34Ca4541CAc9a1c4B6F6aB47A65877E240',
  86. '0x7aBF0dA8Ac07B6dE7206e467988455E1AD0b60B5',
  87. '0xF736f45d4663a8D8DfF7EFA55b1Cf6Fe38D026c8',
  88. '0x83173eECf3a6d9ABB79682568e16c2eAd361620e',
  89. '0xa401b85B4849Fc7610Bd180cc937859C78528F47',
  90. '0x10A43E7Fe77E2D84adBeC26cF0bFc6f403841266',
  91. '0x70D5EE1DfddD3726f0D71F4CD5a8Ef43aC651a75'
  92. ]
  93. random.shuffle(wallet_list)
  94. asyncio.run(main(wallet_list))
  95. print("done")