代码如下:
# !/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 * * *
''')
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', 'CHERWIN_TOOLS.py'):
print('脚本依赖下载完成请重新运行脚本')
import_Tools()
else:
print(
'脚本依赖下载失败')
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)
解析:
该脚本用于自动完成老板电器服务微商城小程序的每日签到、任务完成(如浏览商品、浏览文章等)和积分查询等操作。通过抓取用户登录信息,自动登录,并执行一系列的任务,同时记录任务完成情况。
1. make_request
- 功能:通用请求方法,支持 `GET` 和 `POST` 请求,用于与老板电器服务微商城服务器交互。
- 参数:
- url:请求的URL。
- method:请求方法,默认为 `POST`。
- params:请求参数,默认为 `None`。
- data:请求数据,默认为 `None`。
- headers:请求头,默认为类的默认头信息。
- 返回:返回服务器的响应数据。
2. gen_token
- 功能:生成基于当前时间戳和openid的token,用于认证请求。
- 返回:返回包含生成的token和其他参数的JSON数据。
3. get_user_info
- 功能:获取用户的基本信息,包括用户名、手机号和当前积分。
- 参数:`END`,用于标识是否为脚本结束时获取积分信息。
- 返回:`True` 表示获取成功;`False` 表示获取失败。
4. get_member_score_mission_list
- 功能:获取用户的任务列表。
- 返回:`True` 表示获取成功;`False` 表示获取失败。
5. get_sign_week
- 功能:获取用户的签到状态和签到详情。
- 返回:`True` 表示获取成功;`False` 表示获取失败。
6. user_sign
- 功能:执行签到操作,获取每日签到的积分。
- 返回:`True` 表示签到成功;`False` 表示签到失败。
7. get_sign_prize
- 功能:领取连续签到的奖励。
- 参数:`id`,奖励ID;`title`,奖励名称。
- 返回:`True` 表示领取成功;`False` 表示领取失败。
8. get_sign_prize_list
- 功能:获取连续签到的奖励列表。
- 返回:`True` 表示获取成功;`False` 表示获取失败。
9. get_detail
- 功能:浏览任务详情。
- 参数:`title`,任务名称;`id`,任务ID;`type`,任务类型;`ms_id`,秒杀任务ID。
- 返回:`True` 表示浏览成功;`False` 表示浏览失败。
10. get_list
- 功能:获取任务列表(如文章列表、秒杀列表、商品列表)。
- 参数:`type`,任务类型(默认是文章列表)。
- 返回:`True` 表示获取成功;`False` 表示获取失败。
11. main
- 功能:主执行逻辑,依次执行各个任务和签到操作,并发送任务完成通知。
- 返回:`True` 表示执行成功;`False` 表示执行失败。
12. sendMsg
- 功能:发送任务完成通知。
- 返回:无返回值。
13. random_delay
- 功能:在min_delay和max_delay之间产生一个随机的延时时间,然后暂停执行。
- 参数:
- min_delay:最小延时时间(秒),默认为1秒。
- max_delay:最大延时时间(秒),默认为5秒。
主要执行逻辑
- 通过抓取的 `openid` 自动登录并检测登录状态。
- 获取用户基本信息并检查当天的签到状态。
- 执行签到操作(如果当天未签到)。
- 获取用户的任务列表并执行对应的任务(如浏览商品、浏览文章等)。
- 获取用户当前的积分信息。
- 通过 wxpusher 发送通知消息。
脚本依赖
- requests: 用于发送 HTTP 请求。
- os: 用于文件操作和环境变量处理。
- hashlib: 用于生成签到请求的签名。
环境变量
- WXPUSHER: 用于配置 wxpusher 的推送功能,未设置则不启用一对一推送。
- ENV: 老板电器服务微商城小程序的 `openid` 信息。
- 定时任务:推荐配置为每天上午9点20分执行。
注意:
本文部分变量已做脱敏处理,仅用于测试和学习研究,禁止用于商业用途,不能保证其合法性,准确性,完整性和有效性,请根据情况自行判断。技术层面需要提供帮助,可以通过打赏的方式进行探讨。
推荐本站淘宝优惠价购买喜欢的宝贝:
本文链接:https://www.hqyman.cn/post/6924.html 非本站原创文章欢迎转载,原创文章需保留本站地址!
休息一下~~