312450352 发表于 2022-8-3 13:48:12

记一次潇湘书院静态字体反爬

网站链接:https://www.xxsy.net/chapter/3660424.html
思路:找到加密字体—>找到加密字体与字体文件的关系—>构建加密字体与原字体的关系—>把网站上加密的字体的数据替换成原数据
当我删除了网站<link href="//images.xxsy.net/css/pc/website/pagestatic.css?v=20210712" rel="stylesheet">这一行之后字体变了,说明字体反爬关键处在这个文件里

输入https://www.xxsy.net/Content/css/xxsyfont/xxsyfont.css便可直达css文件里面,可以看到里面的代码都是与字体有关的。那便取敌人首级,直接去拿字体文件。

抓包直接就能拿到字体文件

文件有了那么我们可以拿这个字体文件去解析字体的对应关系

接下来就是敲代码了
说下代码思路吧,先下载字体文件对其解析成我们所能理解的文件
然后获取字体的映射关系并且写字体字典
最重要的就是构建加密字体与字体字典的关系。网站源代码加密字体是这样子的—>的,字典文件里面的对应关系却是uniE800—>的
于是乎,把源代码的&#x替换成uni并把其他字符大写化
把被替换后的源代码里的uniE***替换成字典里面的uniE***—>*(*是所对应的字符的意思)
代码如下:
import re
import requests
from fontTools.ttLib import TTFont
headers={
    "User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.75 Safari/537.36"
}
#下载字体二进制文件—>微笑面对生活—^^—
font=requests.get("https://www.xxsy.net/Content/css/xxsyfont/yahei/font.ttf",headers=headers)
with open("font.ttf",mode="wb")as f:
    f.write(font.content)
#转换字体文件为我们能看得懂的文件—>微笑面对生活—^^—
fo = TTFont("font.ttf")
fo.saveXML('font.xml')
#获取字体的映射关系—>微笑面对生活—^^—
font_map = fo['cmap'].getBestCmap()
#替换字典
zd = {'uniE800':'的',
      'uniE801':'一',
      'uniE802':'是',
      'uniE803':'了',
      'uniE804': '我',
      'uniE805': '不',
      'uniE806': '人',
      'uniE807': '在',
      'uniE808': '他',
      'uniE809': '有',
      'uniE80A': '这',
      'uniE80B': '个',
      'uniE80C': '上',
      'uniE80D': '们',
      'uniE80E': '来',
      'uniE80F': '到',
      'uniE810': '时',
      'uniE811': '大',
      'uniE812': '地',
      'uniE813': '为',
      'uniE814': '子',
      'uniE815': '中',
      'uniE816': '你',
      'uniE817': '说',
      'uniE818': '生',
      'uniE819': '国',
      'uniE81A': '年',
      'uniE81B': '着',
      'uniE81C': '就',
      'uniE81D': '那',
      'uniE81E': '和',
      'uniE81F': '要',
      'uniE820': '她',
      'uniE821': '出',
      'uniE822': '也',
      'uniE823': '得',
      'uniE824': '里',
      'uniE825': '后',
      'uniE826': '自',
      'uniE827': '以',
      'uniE828': '会',
      'uniE829': '家',
      'uniE82A': '可',
      'uniE82B': '下',
      'uniE82C': '而',
      'uniE82D': '过',
      'uniE82E': '天',
      'uniE82F': '去',
      'uniE830': '能',
      'uniE831': '对',
      'uniE832': '小',
      'uniE833': '多',
      'uniE834': '然',
      'uniE835': '于',
      'uniE836': '心',
      'uniE837': '学',
      'uniE838': '么',
      'uniE839': '之',
      'uniE83A': '都',
      'uniE83B': '好',
      'uniE83C': '看',
      'uniE83D': '起',
      'uniE83E': '发',
      'uniE83F': '当',
      'uniE840': '没',
      'uniE841': '成',
      'uniE842': '只',
      'uniE843': '如',
      'uniE844': '事',
      'uniE845': '把',
      'uniE846': '还',
      'uniE847': '用',
      'uniE848': '第',
      'uniE849': '样',
      'uniE84A': '道',
      'uniE84B': '想',
      'uniE84C': '作',
      'uniE84D': '种',
      'uniE84E': '开',
      'uniE84F': '美',
      'uniE850': '总',
      'uniE851': '从',
      'uniE852': '无',
      'uniE853': '情',
      'uniE854': '已',
      'uniE855': '面',
      'uniE856': '最',
      'uniE857': '女',
      'uniE858': '但',
      'uniE859': '现',
      'uniE85A': '前',
      'uniE85B': '些',
      'uniE85C': '所',
      'uniE85D': '同',
      'uniE85E': '日',
      'uniE85F': '手',
      'uniE860': '又',
      'uniE861': '行',
      'uniE862': '意',
      'uniE863': '动'
      }
# 获取网页源码—>微笑面对生活—^^—
html = requests.get("https://www.xxsy.net/chapter/3660424.html")
html1 = html.text
# 将网页上的&#x替换成uni,目的是为了后面更好替换字体—>微笑面对生活—^^—
html1 = html1.replace('&#x','uni')
# 正则创建—>微笑面对生活—^^—
re1=re.compile('<d>uni(.*?);</d>',re.I|re.S)
re1=re1.findall(html1)
# 将网页上面的&#x后面的字体大写化—>微笑面对生活—^^—
for i in range(0,1000):
      try:
            html1 = html1.replace(re1, re1.upper(), i)
      except:
            break

# 替换网页上的加密字体—>微笑面对生活—^^—
for x,y in font_map.items():
      try:
            thq = '<d>' + fo['cmap'].getBestCmap() + ';</d>'
            thh = zd
            html1=html1.replace(thq,thh,i)
      except:
            break
# 通过正则找到需要爬取的内容(文章标题与文章内容)—>微笑面对生活—^^—
re3=re.compile('<span class="chapter-section" data-index=".*?">(.*?)</span>',re.I|re.S)
re3=re3.findall(html1)
with open(re3 + '.txt', mode="w", encoding='utf-8')as f:
      f.writelines(re3)

注意:文章仅供技术交流使用,如有侵权,联系我删除

夜莫离 发表于 2023-3-31 23:08:24

PYG18周年生日快乐!

ie12580 发表于 2023-6-25 09:12:15

给楼主点个赞!
页: [1]
查看完整版本: 记一次潇湘书院静态字体反爬