세이브
게시글 주소: https://dev.orbi.kr/00075398714
import asyncio
import aiohttp
import urllib.parse
import logging
from typing import Dict, Any
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(message)s')
logger = logging.getLogger(__name__)
USERNAME = ''
PASSWORD = ''
URL_TARGET = 'https://orbi.kr/amusement/lottery/buy_ticket'
URL_LOGIN = 'https://login.orbi.kr/login'
BATCH_SIZE = 30
WAIT_AFTER_BATCH_SEC = 70
LOGIN_REDIRECT_URL = 'https://orbi.kr/amusement/lottery'
batching_enabled = True
batch_counter = 0
global_session: aiohttp.ClientSession = None
async def perform_login(session: aiohttp.ClientSession) -> bool:
logger.info("Attempting login...")
login_data = {
'url': LOGIN_REDIRECT_URL,
'username': USERNAME,
'password': PASSWORD,
}
headers = {
'Accept': '*/*',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
'Referer': f'https://login.orbi.kr/login?url={urllib.parse.quote(LOGIN_REDIRECT_URL, safe="")}',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/138.0.0.0 Safari/537.36',
}
try:
async with session.post(URL_LOGIN, data=login_data, headers=headers) as response:
logger.info(f"Login response status: {response.status}")
if response.status in [200, 302]:
logger.info("Login successful.")
return True
else:
logger.error(f"Login failed. Status code: {response.status}")
return False
except Exception as e:
logger.error(f"Error during login: {e}")
return False
async def delay_next_cycle(from_batch: int):
global batching_enabled
if not batching_enabled:
return
logger.info(f"[CYCLE {from_batch}] Waiting {WAIT_AFTER_BATCH_SEC} seconds...")
await asyncio.sleep(WAIT_AFTER_BATCH_SEC)
if not batching_enabled:
return
logger.info(f"[CYCLE {from_batch}] Wait complete. Continuing...")
async def send_batch(session: aiohttp.ClientSession):
global batch_counter
global batching_enabled
if not batching_enabled:
return
batch_counter += 1
this_batch = batch_counter
logger.info(f"\n[CYCLE {this_batch}] Sending {BATCH_SIZE} parallel requests.")
request_headers = {
'Accept': '*/*',
'Referer': 'https://orbi.kr/amusement/lottery',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/138.0.0.0 Safari/537.36',
}
async def make_request(i):
try:
async with session.post(URL_TARGET, headers=request_headers, data={}) as resp:
return {'ok': resp.ok, 'status': resp.status}
except Exception as err:
return {'error': str(err)}
tasks = [make_request(i) for i in range(BATCH_SIZE)]
results = await asyncio.gather(*tasks, return_exceptions=False)
success_count = sum(1 for r in results if 'ok' in r and r['status'] == 200)
failed_count = sum(1 for r in results if 'error' in r or ('ok' in r and r['status'] != 200))
summary = {'Total': len(results), 'Success (200)': success_count, 'Failed/Error': failed_count}
logger.info(f"[CYCLE {this_batch}] Batch complete. Summary: {summary}")
await delay_next_cycle(this_batch)
async def main_execute():
global global_session
async with aiohttp.ClientSession() as session:
global_session = session
if not await perform_login(session):
logger.error("Login failed. Stopping routine.")
return
logger.info("Login successful. Starting loop.")
while batching_enabled:
await send_batch(session)
logger.info("Routine stopped by user command.")
if __name__ == "__main__":
try:
logger.info("sc/2 loaded. Starting routine.")
asyncio.run(main_execute())
except KeyboardInterrupt:
logger.info("Routine stopped by keyboard interrupt.")
except Exception as e:
logger.error(f"Unexpected error: {e}")
출처: 하량이
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
좋아요 1 답글 달기 신고 -
좋아요 1 답글 달기 신고 -
-
역대 수능에서 제일 어려운 지문 15 0
뭐라고 생각함? 전 에이어랑 헤겔같은 논리학이 ㄹㅇ 어려운듯
-
15년전까지만해도 I과목하고 II과목 격차 별로없었는데 4 1
달인1하고 달인2는 보는사람이 기립박수칠정도로 둘다어려웠던 추억이 있네요
-
11시 11분 0 0
11 11
-
카이사가 승진하면? 3 0
카상무
-
안녕하세요 올해 대학에 들어가는 N수생인데요. 홍익대 컴공과랑 차의과대...
-
~~~~~꿱꾸ㅖㄲ꾸ㅖㄲㄱ꿱꿱 리얼리틔~~
-
경인교대 가능할런지 ㅠㅠㅠ 6 0
평백94.5인데 가능할까요 ㅠㅠ 그나마 경쟁률이 낮아서 다행인데 ㅠㅠ 제발추합이라도 ㅠㅠㅠㅠㅠㅠㅠㅠ
-
3학년때 지금 내신으로 물2를 하는데 물1이랑 많이 겹치드라고요물1 내신하다 끝난지...
-
ㅇㅅㄷㄱㄴ????? 0 0
연세대////과는 상관없이 아무데나 가능??ㅠ
-
특기를 어떤것 쓰나요? 외부게 되는 걸로 아는데 혹시 그래도 교내 예를 들어 화학...
-
환산점수가 잘못된것같아요... 0 0
-
ㅠㅠ 0 0
저기요 인강을 스마트폰이나 테블릿피쉬로 다운받아서들을수잇죠 ?와이파이지역에서만되나요...
-
문과 어디정도 갈수있죠?? 0 0
표점 백분위 등급언어 123 92 2수리 142 100 1외국어 132 95 2한지 67 98
-
김동욱t,이성권t 찝어주신 자료좀 보내주실분 계신가요? ...삼수생 하나 살려주세요... 1 0
lincoln4@naver.com부탁드립니다....사정이 안좋아서 강좌같은건...
-
안뇽? 1 0
1113462419571