标签搜索

猿人学第四题,雪碧图、样式干扰

Lan
Lan
2021-09-10 / 0 评论 / 29 阅读 / 正在检测是否收录...

解出来了
两分钟后:
通过截图
里面用到了类似于字体加密,但是是把数字用base64转成了图片,但是有个规律就是每个数字都是固定的base64,然后就可以取到很多数字,然后有一个class用到了MD5和base64加密,最后删除包含这个class的img,就得到了四位数,但是四位数顺序是乱的,然后就需要根据style里面的margin去换位置,最终就可以将正确的数字取出来,如上图,然后再整一整就是下图了
Python代码:

import base64
import hashlib

import parsel
import requests

pic2num = {
    '': 1,
    '': 2,
    '': 3,
    '': 4,
    '': 5,
    '': 6,
    '': 7,
    '': 8,
    '': 9,
    '': 0,
}
margin2num = {
    'left:11.5px': 1,
    'left:-11.5px': -1,
    'left:-23.0px': -2,
    'left:23.0px': 2,
    'left:34.5px': 3,
    'left:-34.5px': -3,
    'left:0.0px': 0,
    'left:0px': 0,
}
headers = {
    'user-agent': 'yuanrenxue.project'
}
result = 0
for page in range(1, 6):
    response = requests.get(f'https://match.yuanrenxue.com/api/match/4?page={page}', headers=headers).json()
    delElClass = hashlib.md5(base64.b64encode(f"{response['key']}{response['value']}".encode('utf-8')).decode()
                             .replace('=', '').encode('utf-8')).hexdigest()
    tds = parsel.Selector(response['info'])
    for td in tds.xpath('//td'):
        imageClass = td.xpath('img/@class').extract()
        imageSrc = td.xpath('img/@src').extract()
        imageStyle = td.xpath('img/@style').extract()
        num = []
        change = []
        for index, value in enumerate(imageClass):
            if delElClass not in value:
                change.append(margin2num[imageStyle[index]])
                num.append(str(pic2num[imageSrc[index]]))
        source = num.copy()
        for i, c in enumerate(change):
            if c != 0:
                num[i + c] = source[i]
        result += int(''.join(num))
print(result)
1

评论 (0)

取消