302_full.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. import json
  2. import multiprocessing
  3. import random
  4. import re
  5. import threading
  6. import time
  7. import traceback
  8. from datetime import datetime
  9. from urllib import parse
  10. import requests
  11. from tools import loggerKit
  12. from tools.utils import get_random_browser, FileWriter, get_random_proxy_at_redis, get_external_ip
  13. def poc_2(account, passwd, target_url, log_name, single_proxy):
  14. """
  15. # 生成 5 到 10 秒之间的随机等待时间
  16. wait_time = random.uniform(5, 10)
  17. # 打印等待时间并等待
  18. loggerKit.info(f"等待 {wait_time:.2f} 秒...")
  19. time.sleep(wait_time)
  20. """
  21. # 开始业务逻辑
  22. lock = threading.Lock()
  23. with lock:
  24. loggerKit.info(f'account: {account}, passwd: {passwd}')
  25. writer = FileWriter(log_name)
  26. writer.write_to_file(f'------{account}, {passwd}------ \n')
  27. user_agent = get_random_browser()
  28. # single_proxy = 'rrehqcjf:33f90umk8x32@185.199.228.220:7300'
  29. proxies = {
  30. 'http': f'http://{single_proxy}',
  31. # 'https': f'https://{single_proxy}'
  32. }
  33. loggerKit.info(f'proxies: {proxies}')
  34. writer.write_to_file(f'account: {account}, passwd: {passwd}, proxies:{proxies} \n')
  35. # session
  36. """
  37. 模拟登录
  38. """
  39. # 定义请求地址
  40. login_url = "https://t.livepocket.jp/api/sessions/create?mytimestamp=" + str(int(time.time()))
  41. # 定义请求header
  42. headers = {'Content-Type': 'application/x-www-form-urlencoded;',
  43. 'Referer': 'https://t.livepocket.jp/login?acroot=header-new_p_u_nl',
  44. # 'Sec-Ch-Ua': 'Chromium',
  45. 'User-Agent': user_agent
  46. }
  47. # 通过字典方式定义请求body
  48. form_data = {"login": account,
  49. "password": passwd,
  50. "auto_login": "on",
  51. "login_password": f"{account}&{passwd}"
  52. }
  53. data = parse.urlencode(form_data)
  54. session = requests.session()
  55. content = session.post(url=login_url, headers=headers, data=data, proxies=proxies).text
  56. # loggerKit.info(f'login info: {content}')
  57. if 'token' not in content:
  58. loggerKit.info(f'login account:{account}, 本机出口IP:{get_external_ip()} 被封!!!')
  59. return
  60. cookie = session.cookies
  61. response_cookie = cookie.get_dict()
  62. login_resp = json.loads(content)
  63. token = login_resp['result']['token']
  64. login_session = response_cookie['ci_session']
  65. php_session = response_cookie['PHPSESSID']
  66. # event_id
  67. event_id = 0
  68. response = requests.get(target_url, proxies=proxies)
  69. if response.status_code == 200:
  70. html_string = response.content.decode('utf8')
  71. start_index = html_string.find('https://t.livepocket.jp/purchase/verify?event_id=')
  72. if start_index != -1:
  73. end_index = html_string.find("'", start_index)
  74. if end_index != -1:
  75. event_id = html_string[start_index + len('https://t.livepocket.jp/purchase/verify?event_id='):end_index]
  76. loggerKit.info(f'event_id: {event_id}')
  77. else:
  78. loggerKit.warning('End index not found.')
  79. else:
  80. loggerKit.warning('Substring not found.')
  81. else:
  82. loggerKit.error('Failed to fetch the page. Status code: {0}', response.status_code)
  83. # ticket_id
  84. ticket_id = 0
  85. response = requests.get(target_url, proxies=proxies)
  86. if response.status_code == 200:
  87. html_string = response.text
  88. match = re.search(r'id="js_order_limited_(\d+)"', html_string)
  89. if match:
  90. ticket_id = match.group(1)
  91. loggerKit.info(f'ticket_id: {ticket_id}')
  92. else:
  93. loggerKit.warning("未找到匹配的数值")
  94. # event_cname
  95. # url = 'https://t.livepocket.jp/e/lxyyc'
  96. sub_str = target_url.replace("https://t.livepocket.jp/", "")
  97. strs = sub_str.split('/')
  98. cname = strs[len(strs) - 1]
  99. # print(cname)
  100. # redirect_url1
  101. net_url = 'https://t.livepocket.jp/purchase?type=new'
  102. result = requests.Session()
  103. header = {
  104. 'Host': 't.livepocket.jp',
  105. 'User-Agent': "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) "
  106. "Chrome/69.0.3947.100 Safari/537.36",
  107. 'Content-Type': 'application/x-www-form-urlencoded',
  108. 'Referer': f'{target_url}',
  109. }
  110. # my_session = 'IN7u3uuP5WcizQkmRzF%2F3OsLuNNQePnxNBvnlPgqT6FPz2BgyKT2KCJaMvdj8ZSa6wNp2xZIL6VoA7Mj0R2zECMZkOKJOLbsNwUdXwvcsROxjfCzibxEaj4nG%2Bq29dCEUdiWI2TgUsKSFGRZaOP0p37ktl%2B1wSMqMAk918Nkt7APIxpQtZ%2BoLwId4PMOkN3oOIwT3CvsuDbgPQHIuokZXcnNe8uOAUuZBLW4nKOdYimLcSw6oTMt85UXkwm4OyTdxYR3%2B8crA0OfQCyfHXqY%2Bj0t9R0mmNSusRXRDuDBmOCFR58vHVuuwZ0AXNHYoYB0sdm28VL9xgHHrzkvm2M9cpLEIVWUWBWGaZgtO3xp2d8L70%2BfAKwyv6JPGcGmGf9wUQzBltssBpMmYqSfkws1%2Bp8BOhmXOqfljSYbWcxxVVSw%2B2dtoxBXsTf793mD9sVYRsrr8YPGz4JPVGWGU0outg%3D%3D'
  111. cookies = {
  112. 'ci_session': f'{login_session}',
  113. 'PHPSESSID': f'{php_session}',
  114. 'list_count': '{"success":true,"result":{"myticket_count":{"count":"0"},"today_event":{"total_count":0,"data_list":[]},"unread_count":5},"submit":true}',
  115. 'sns_status': '{"success":true,"result":{"facebook":0,"twitter":0,"mixi":0,"line":0,"yahoo":0,"plusid":1,"google":0},"submit":true}',
  116. 'display_init': '{"success":true,"result":{"purchased_tickets":{"total_count":0,"data_list":{"ticket_info":[]}},"lottery_tickets":{"total_count":0,"data_list":{"ticket_info":[]}},"order_limited_event_tickets":{"data_list":{"ticket_info":[]},"total_count":0},"event_order_limit":true},"submit":true}',
  117. }
  118. ticket_key = f'ticket_id_{ticket_id}'
  119. form_data = {
  120. 'redirect_url': 'https://t.livepocket.jp/purchase/',
  121. 'event_id': event_id,
  122. 'event_cname': f'{cname}',
  123. 'ticket_type': 'lottery',
  124. 'facebook_ticket_count': 0,
  125. 'twitter_ticket_count': 0,
  126. 'plusid_linkage_invalidation_flg': 0,
  127. ticket_key: 1
  128. }
  129. loggerKit.info('form_data: {0}', form_data)
  130. response = result.post(net_url, headers=header, cookies=cookies, data=form_data, allow_redirects=False,
  131. proxies=proxies)
  132. loggerKit.info('response.headers: {0}', response.headers)
  133. if 'Location' in response.headers:
  134. redirect_url1 = response.headers['Location']
  135. loggerKit.info('redirect_url1: {0}', redirect_url1)
  136. else:
  137. return
  138. # https://t.livepocket.jp/purchase/security?id=309887&type=new
  139. # redirect_url2
  140. response2 = result.get(redirect_url1, headers=header, cookies=cookies, allow_redirects=False, proxies=proxies)
  141. loggerKit.info('response2.headers: {0}', response2.headers)
  142. if 'Location' in response2.headers:
  143. redirect_url2 = response2.headers['Location']
  144. loggerKit.info('redirect_url2: {0}', redirect_url2)
  145. else:
  146. return
  147. # https://t.livepocket.jp/purchase/confirm?id=309887&reserved_session_id=423272
  148. # redirect_url3
  149. response3 = result.get(redirect_url2, headers=header, cookies=cookies, allow_redirects=False, proxies=proxies)
  150. print('response3.headers: ', response3.headers)
  151. if 'Location' in response3.headers:
  152. redirect_url3 = response3.headers['Location']
  153. loggerKit.info('redirect_url3: {0}', redirect_url3)
  154. else:
  155. loggerKit.warning('redirect_url3 is None')
  156. return
  157. # https://t.livepocket.jp/purchase/confirm?id=309887&reserved_session_id=794986&otoken=mMyZTgzMmQ4OWQ5ZjY5NWFlNGE2ZmJlMWM5Mm
  158. # drawing_tickets
  159. drawing_url = 'https://t.livepocket.jp/api/drawing_tickets/entry?mytimestamp=' + str(int(time.time()))
  160. region_string = redirect_url3.split('?')[1]
  161. params = region_string.split('&')
  162. reserve_session_id = params[1].split("=")[1]
  163. drawing_headers = {
  164. 'Host': 't.livepocket.jp',
  165. 'User-Agent': user_agent,
  166. 'Content-Type': 'application/x-www-form-urlencoded',
  167. 'Referer': f'{redirect_url3}',
  168. }
  169. drawing_cookies = {
  170. 'ci_session': f'{login_session}',
  171. 'PHPSESSID': f'{php_session}',
  172. }
  173. drawing_form_data = {
  174. 'utoken': f'{token}',
  175. 'onetime_token_name': 'buy_ticket',
  176. 'onetime_token_value': params[2].split('=')[1],
  177. 'url': f'https://t.livepocket.jp/purchase/confirm?id={event_id}&reserved_session_id={reserve_session_id}',
  178. 'payment_method': 0,
  179. 'reserve_session_id': reserve_session_id,
  180. 'event_id': event_id,
  181. 'reserve_ticket[0][ticket_id]': ticket_id,
  182. 'reserve_ticket[0][amount]': 1,
  183. 'payment_type': 'credit'
  184. }
  185. drawing_response = result.post(drawing_url, headers=drawing_headers, cookies=drawing_cookies,
  186. data=drawing_form_data, allow_redirects=False, proxies=proxies)
  187. loggerKit.info('drawing_response.text: {0}', drawing_response.text)
  188. drawing_data = json.loads(drawing_response.text)
  189. if drawing_data['success']:
  190. order_id = drawing_data['result']['order_id']
  191. onetime_token_name = drawing_data['result']['onetime_token_name']
  192. onetime_token_value = drawing_data['result']['onetime_token_value']
  193. loggerKit.info('account: {0}, order_id: {1}, onetime_token_name: {2}, onetime_token_value: {3}',
  194. account, order_id, onetime_token_name, onetime_token_value)
  195. writer.write_to_file(
  196. f'account:{account}, order_id:{order_id}, onetime_token_name:{onetime_token_name}, onetime_token_value:{onetime_token_value} \n')
  197. def process_account(account, log_name, single_proxy):
  198. try:
  199. run_poc(account.strip(), 'panyue666', 'https://t.livepocket.jp/e/0vapa', log_name, single_proxy)
  200. except Exception as ex:
  201. loggerKit.error(f'error: {traceback.format_exc()}, account:{account}')
  202. def process_running(max_threads):
  203. log_name = f"data_{datetime.now().strftime('%Y%m%d%H%M')}.txt"
  204. with open('account.txt', 'r') as accounts:
  205. account_list = accounts.readlines()
  206. threads = []
  207. for account in account_list:
  208. # 直接从redis中获取
  209. single_proxy = get_random_proxy_at_redis(max_threads)
  210. thread = threading.Thread(target=process_account, args=(account, log_name, single_proxy))
  211. threads.append(thread)
  212. thread.start()
  213. # 如果当前线程数达到上限,等待有线程结束后再创建新线程
  214. if len(threads) >= max_threads:
  215. for t in threads:
  216. t.join()
  217. threads.clear()
  218. # 等待所有线程执行完毕
  219. for thread in threads:
  220. thread.join()
  221. def run_poc(account, password, url, log_name, single_proxy):
  222. try:
  223. poc_2(account, password, url, log_name, single_proxy)
  224. except Exception as e:
  225. loggerKit.error(f'error: {traceback.format_exc()}, account:{account}')
  226. if __name__ == '__main__':
  227. # 新增下面一行代码即可打包多进程
  228. multiprocessing.freeze_support()
  229. while 1:
  230. process_running(max_threads=6)