faucet.py 3.6 KB

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