From a1023157d07a0fddb2ad44be2e117dc23fd328d1 Mon Sep 17 00:00:00 2001 From: CHERWING <160421895+CHERWING@users.noreply.github.com> Date: Sat, 1 Jun 2024 03:15:52 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9E=20=E8=80=81=E6=9D=BF?= =?UTF-8?q?=E7=94=B5=E5=99=A8=E6=9C=8D=E5=8A=A1=E5=BE=AE=E5=95=86=E5=9F=8E?= =?UTF-8?q?=E5=B0=8F=E7=A8=8B=E5=BA=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- LBDQ.py | 471 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 471 insertions(+) create mode 100644 LBDQ.py diff --git a/LBDQ.py b/LBDQ.py new file mode 100644 index 0000000..f775290 --- /dev/null +++ b/LBDQ.py @@ -0,0 +1,471 @@ +# !/usr/bin/python3 +# -- coding: utf-8 -- +# cron "20 9 * * *" script-path=xxx.py,tag=匹配cron用 +# const $ = new Env('老板电器服务微商城小程序') +import hashlib +import json +import os +import random +import time +from datetime import datetime, time as times +import requests +from requests.packages.urllib3.exceptions import InsecureRequestWarning + +# 禁用安全请求警告 +requests.packages.urllib3.disable_warnings(InsecureRequestWarning) + +IS_DEV = False +if os.path.isfile('DEV_ENV.py'): + import DEV_ENV + + IS_DEV = True +if os.path.isfile('notify.py'): + from notify import send + + print("加载通知服务成功!") +else: + print("加载通知服务失败!") +send_msg = '' +one_msg = '' + + +def Log(cont=''): + global send_msg, one_msg + print(cont) + if cont: + one_msg += f'{cont}\n' + send_msg += f'{cont}\n' + + +class RUN: + def __init__(self, info, index): + global one_msg + one_msg = '' + split_info = info.split('@') + self.openid = split_info[0] + len_split_info = len(split_info) + last_info = split_info[len_split_info - 1] + self.send_UID = None + if len_split_info > 0 and "UID_" in last_info: + print('检测到设置了UID') + print(last_info) + self.send_UID = last_info + self.index = index + 1 + # print(self.access_token) + self.UA = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/116.0.0.0 Safari/537.36 MicroMessenger/7.0.20.1781(0x6700143B) NetType/WIFI MiniProgramEnv/Windows WindowsWechat/WMPF WindowsWechat(0x63090a1b) XWEB/9129" + + self.headers = { + "Host": "vip.foxech.com", + "xweb_xhr": "1", + "User-Agent": self.UA, + "Content-Type": "application/json", + "Accept": "*/*", + "Sec-Fetch-Site": "cross-site", + "Sec-Fetch-Mode": "cors", + "Sec-Fetch-Dest": "empty", + "Referer": "https://servicewechat.com/wxc8c90950cf4546f6/154/page-frame.html", + "Accept-Language": "zh-CN,zh;q=0.9" + } + self.s = requests.session() + self.s.verify = False + self.baseUrl = 'https://vip.foxech.com/index.php/api/' + + def make_request(self, url, method='post', headers={}, json_data={}, params=None, data=None): + if headers == {}: + headers = self.headers + try: + if method.lower() == 'get': + response = self.s.get(url, headers=headers, verify=False, params=params) + elif method.lower() == 'post': + response = self.s.post(url, headers=headers, json=json_data, data=data, params=params, verify=False) + else: + raise ValueError("不支持的请求方法❌: " + method) + return response.json() + except requests.exceptions.RequestException as e: + print("请求异常❌:", e) + except ValueError as e: + print("值错误或不支持的请求方法❌:", e) + except Exception as e: + print("发生了未知错误❌:", e) + + def gen_token(self): + current_timestamp_ms = int(time.time() * 1000) + raw_string = f'{current_timestamp_ms}wqewq{self.openid}' + md5_hash = hashlib.md5(raw_string.encode()) + token = md5_hash.hexdigest() + json_data = { + "is_need_sync": 1, + "timestamp": current_timestamp_ms, + "token": token, + "openid": self.openid + } + return json_data + + def get_user_info(self, END=False): + act_name = '获取用户信息' + Log(f'\n====== {act_name} ======') + url = f"{self.baseUrl}member/get_member_info" + json_data = self.gen_token() + response = self.make_request(url, json_data=json_data) + + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + info = data.get('info', {}) + nickname = info.get('nickname', '') + mobile = info.get('mobile', '') + score = info.get('score', '') + mobile = mobile[:3] + "*" * 4 + mobile[7:] + if END: + Log(f"> 执行后积分:{score}") + else: + Log(f"> 用户名:{nickname}\n> 手机号:{mobile}\n> 当前积分:{score}") + return True + elif not response: + print(f"> 账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_member_score_mission_list(self): + act_name = '获取任务列表' + Log(f'\n====== {act_name} ======') + url = f"{self.baseUrl}member/get_member_score_mission_list" + json_data = self.gen_token() + json_data['page'] = 1 + json_data['limit'] = 1000 + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + list = data.get('list', [{}]) + for tasks in list: + title = tasks.get('title', '') + type = tasks.get('type', '') + is_over = tasks.get('is_over', '') + id = tasks.get('id', '') + Log(f'>> 当前任务:【{title}】') + if is_over == 1: + Log(f'> 已完成✅') + continue + if id == 16: + self.user_sign() + elif id == 7: + self.get_list('get_goods_list') + # elif id == 8: + # self.get_list('get_ms_list') + elif id == 12: + self.get_list() + else: + Log('> 暂不支持,跳过❌') + return True + elif not response: + print(f">账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_sign_week(self): + act_name = '获取签到状态' + Log(f'\n====== {act_name} ======') + url = f"{self.baseUrl}member/get_sign_week" + json_data = self.gen_token() + + response = self.make_request(url, json_data=json_data) + + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + day = data.get('day', 0) + Log(f'> 累计签到:【{day}】天') + list = data.get('list', {}) + nowday = datetime.now().strftime("%Y%m%d") + # print(f'今天是:【{nowday}】') + for days in list: + date = days.get('date', '') + is_sign = days.get('is_sign', '') + if date == nowday and is_sign == 0: + Log(f'> 今日未签到!❌') + self.user_sign() + elif date == nowday and is_sign == 1: + Log(f'> 今日已签到!✅') + if day >= 7: + self.get_sign_prize_list() + return True + elif not response: + print(f">账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def user_sign(self): + act_name = '签到' + Log(f'\n====== {act_name} ======') + url = f"{self.baseUrl}member/user_sign" + json_data = self.gen_token() + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + score = data.get('score', '') + Log(f'> 获得【{score}】积分') + return True + elif not response: + print(f"> 账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_sign_prize(self, id, title): + act_name = f'领取[{title}]奖励' + Log(f'====== {act_name} ======') + url = f"{self.baseUrl}member/get_sign_prize" + json_data = self.gen_token() + json_data['id'] = id + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + score = data.get('score', '') + Log(f'> 获得【{score}】积分✅') + return True + elif not response: + print(f"> 账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_sign_prize_list(self): + act_name = '获取连续签到状态' + print(f'\n====== {act_name} ======') + url = f"{self.baseUrl}member/get_sign_prize_list" + json_data = self.gen_token() + + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + print(f'{act_name}成功!✅') + data = response.get('data', {}) + list = data.get('list', [{}]) + for li in list: + id = li.get('id', '') + title = li.get('title', '') + status = li.get('status', '') + if status == 1: + print(f'> 【{title}】未领取❌') + self.get_sign_prize(id, title) + elif status == 2: + print(f'> 【{title}】已领取✅') + elif status == 0: + print(f'> 【{title}】未达到指定天数❌') + return True + elif not response: + print(f">账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_detail(self, title, id, type='get_news_detail', ms_id=''): + act_name = f'浏览[{title}]' + print(f'====== {act_name} ======') + json_data = self.gen_token() + if 'goods' in type: + json_data['id'] = id + json_data['is_act'] = '' + elif 'ms' in type: + json_data['goods_id'] = id + json_data['ms_id'] = ms_id + else: + json_data['id'] = id + + url = f"{self.baseUrl}common/{type}" + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + data = response.get('data', {}) + info = data.get('info', False) + if info: + print(f'> {act_name}成功!✅') + return True + elif not response: + print(f"> 账号 {self.index}: ck过期 请重新抓取❌") + return False + else: + print(response) + return False + + def get_list(self, type='get_news_list'): + if 'news' in type: + act_name = '获取文章列表' + elif 'ms' in type: + act_name = '获取秒杀列表' + elif 'goods' in type: + act_name = '获取商品列表' + Log(f'====== {act_name} ======') + url = f"{self.baseUrl}common/{type}" + json_data = self.gen_token() + json_data['page'] = 1 + json_data['limit'] = 20 + if 'goods' in type: + json_data['category'] = '' + else: + json_data['category'] = 4 + + json_data['flag'] = 1 + + response = self.make_request(url, json_data=json_data) + if response.get('code', -1) == "200": + data = response.get('data', {}) + list = data.get('list', False) + if list == []: + print(f'{act_name}失败!❌') + return + print(f'{act_name}成功!✅') + for i in range(3): + random_post = random.choice(list) + postid = random_post['id'] + posttitle = random_post['title'] + ms_id = random_post.get('ms_id', '') + print(f'> 随机选择的文章:【{posttitle}】\n> ID【{postid}】') + if 'news' in type: + self.get_detail(posttitle, postid) + elif 'ms' in type: + self.get_detail(posttitle, postid, 'get_ms_goods_detail', ms_id=ms_id) + else: + self.get_detail(posttitle, postid, 'get_goods_detail') + random_delay() + return True + elif not response: + print(f">账号 {self.index}: ck过期 请重新抓取") + return False + else: + print(response) + return False + + def main(self): + Log(f"\n开始执行第{self.index}个账号--------------->>>>>") + if self.get_user_info(): + random_delay(1,30) + self.get_sign_week() + random_delay() + self.get_member_score_mission_list() + random_delay() + self.get_user_info(True) + self.sendMsg() + return True + else: + self.sendMsg() + return False + + def sendMsg(self): + if self.send_UID: + push_res = CHERWIN_TOOLS.wxpusher(self.send_UID, one_msg, APP_NAME) + print(push_res) + + +def random_delay(min_delay=1, max_delay=5): + """ + 在min_delay和max_delay之间产生一个随机的延时时间,然后暂停执行。 + 参数: + min_delay (int/float): 最小延时时间(秒) + max_delay (int/float): 最大延时时间(秒) + """ + delay = random.uniform(min_delay, max_delay) + print(f">本次随机延迟:【{delay:.2f}】 秒.....") + time.sleep(delay) + + +def down_file(filename, file_url): + print(f'开始下载:{filename},下载地址:{file_url}') + try: + response = requests.get(file_url, verify=False, timeout=10) + response.raise_for_status() + with open(filename + '.tmp', 'wb') as f: + f.write(response.content) + print(f'【{filename}】下载完成!') + + # 检查临时文件是否存在 + temp_filename = filename + '.tmp' + if os.path.exists(temp_filename): + # 删除原有文件 + if os.path.exists(filename): + os.remove(filename) + # 重命名临时文件 + os.rename(temp_filename, filename) + print(f'【{filename}】重命名成功!') + return True + else: + print(f'【{filename}】临时文件不存在!') + return False + except Exception as e: + print(f'【{filename}】下载失败:{str(e)}') + return False + + +def import_Tools(): + global CHERWIN_TOOLS, ENV, APP_INFO, TIPS, TIPS_HTML, AuthorCode + import CHERWIN_TOOLS + ENV, APP_INFO, TIPS, TIPS_HTML, AuthorCode = CHERWIN_TOOLS.main(APP_NAME, local_script_name, ENV_NAME, + local_version) + + +if __name__ == '__main__': + APP_NAME = '老板电器服务微商城小程序' + ENV_NAME = 'LBDQ' + CK_URL = 'vip.foxech.com请求头' + CK_NAME = 'openid' + CK_EX = 'oZXiL5b-xxxxxxxxxxxxx' + print(f''' +✨✨✨ {APP_NAME}脚本✨✨✨ +✨ 功能: + 积分签到 浏览商品 浏览文章 +✨ 抓包步骤: + 打开{APP_NAME} + 授权登陆 + 打开抓包工具 + 找{CK_URL}{CK_NAME} +参数示例:{CK_EX} +✨ ✨✨wxpusher一对一推送功能, + ✨需要定义变量export WXPUSHER=wxpusher的app_token,不设置则不启用wxpusher一对一推送 + ✨需要在{ENV_NAME}变量最后添加@wxpusher的UID +✨ 设置青龙变量: +export {ENV_NAME}='{CK_NAME}参数值'多账号#或&分割 +export SCRIPT_UPDATE = 'False' 关闭脚本自动更新,默认开启 +✨ ✨ 注意:抓完CK没事儿别打开小程序,重新打开小程序请重新抓包 +✨ 推荐cron:20 9 * * * +✨✨✨ @Author CHERWIN✨✨✨ +''') + local_script_name = os.path.basename(__file__) + local_version = '2024.06.01' + if IS_DEV: + import_Tools() + else: + if os.path.isfile('CHERWIN_TOOLS.py'): + import_Tools() + else: + if down_file('CHERWIN_TOOLS.py', 'https://github.com/CHERWING/CHERWIN_SCRIPTS/raw/main/CHERWIN_TOOLS.py'): + print('脚本依赖下载完成请重新运行脚本') + import_Tools() + else: + print( + '脚本依赖下载失败,请到https://github.com/CHERWING/CHERWIN_SCRIPTS/raw/main/CHERWIN_TOOLS.py下载最新版本依赖') + exit() + print(TIPS) + token = '' + token = ENV if ENV else token + if not token: + print(f"未填写{ENV_NAME}变量\n青龙可在环境变量设置 {ENV_NAME} 或者在本脚本文件上方将{CK_NAME}填入token =''") + exit() + tokens = CHERWIN_TOOLS.ENV_SPLIT(token) + # print(tokens) + if len(tokens) > 0: + print(f"\n>>>>>>>>>>共获取到{len(tokens)}个账号<<<<<<<<<<") + access_token = [] + for index, infos in enumerate(tokens): + run_result = RUN(infos, index).main() + if not run_result: continue + if send: send(f'{APP_NAME}挂机通知', send_msg + TIPS_HTML)