Python反反爬系列(四)----前端JS进行AES加密,Python解密

将6位或者7位数字加密成22位数字字母大小写的加密方法。

采集数据时,遇到对Url进行加密的网站,大致加密情形如下

1.编译加密前的url

          在列表页的url如下

                           

2.加密后的Url

                   除了端口这块没了,还有就是其他地方也变了

               

3.仔细观察参数变化:

                  

4.第一步先初略过一遍所有的Js文件,排除后确定加密文件为下图的jquery.lyh-1.1.0.js

          

5.第二步查看js作用,

emmmmm,看了下,还是放弃吧,看不懂。。。复制一段代码网上查看,看到博客 https://www.cnblogs.com/libo0125ok/p/7668026.html

前端实现部分代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>测试加密</title>
    <script src="./files/jquery.min.js"></script>
    <script src="./files/jquery.cookie.js"></script>
    <script src="./files/jquery.hiSlider.js"></script>
    <script src="aes.min.js"></script>
</head>
<body>

<script>
        /**
         * 加密(需要先加载lib/aes/aes.min.js文件)
         * @param word
         * @returns {*}
         */
        function encrypt(word){
            var key = CryptoJS.enc.Utf8.parse("qnbyzzwmdgghmcnm");
            var srcs = CryptoJS.enc.Utf8.parse(word);
            var encrypted = CryptoJS.AES. encrypt(srcs, key, {mode:CryptoJS.mode.ECB,padding: CryptoJS.pad.Pkcs7});//加密方法加密

            console.log("加密结果揭晓阶段:");
            console.log("解密结果:",encrypted.toString().slice(0,22));
            alert(encrypted.toString().slice(0,22));
            return encrypted.toString();  //返回加密结果

        }

        /**
         * 解密
         * @param word
         * @returns {*}
         */
        function decrypt(word){
                var key = CryptoJS.enc.Utf8.parse("abcdefgabcdefg12");
                var decrypt = CryptoJS.AES.decrypt(word, key, {mode:CryptoJS.mode.ECB,padding: CryptoJS.pad.Pkcs7});
                return CryptoJS.enc.Utf8.stringify(decrypt).toString();
            }
       </script>
    <input type="button" onclick="encrypt(3187083)" value="点击测试加密效果">
</body>
</html>

结果

发现加密出的数据和我们要的很像,emmmm,就是一样的,抱歉我提前用了加密参数了。。。

确定了网站对数据的加密方式就是Aes,那么接下来就是借助Python复写实现解密了。

但是前提是我们找到了这个加密参数,就是参数key

6.第三步:js打断点

                             

一直调的话就会出现参数

 

7.Python代码实现

# -*- coding: UTF-8 -*-
'''
@Author :Jason
'''
from Crypto.Cipher import AES
import base64
import re

class Decrypt(object):
    def process_num_url(self,partUrl):
        while len(partUrl) % 16 != 0:#while
            partUrl += (16-len(partUrl) % 16) * chr(16-len(partUrl)%16)
        return str.encode(partUrl)

    def encrypt_num_url(self,partUrl,key):
        aes = AES.new(str.encode(key), AES.MODE_ECB)
        encrypted_partUrl = str(base64.encodebytes(aes.encrypt(self.process_num_url(partUrl))), encoding='utf8').replace('\n', '')  # 加密
        process_encrypted_partUrl = encrypted_partUrl.replace('/', "^")
        return process_encrypted_partUrl[:-2]

    def get_partUrl(self,url):
        need_url = re.findall(r'/(\d+)\.jhtml',url)
        if need_url:
            return need_url[0]
        else:
            return ""

    def encrypt_fullUrl(self,partUrl,url,encryptedpartUrl):
        return url.replace(str(partUrl),str(encryptedpartUrl))

    def main(self,url,key):

        partUrl = self.get_partUrl(url=url)
        encryptedpartUrl = self.encrypt_num_url(partUrl,key)
        encryptedfullUrl = self.encrypt_fullUrl(partUrl,url,encryptedpartUrl)
        print(encryptedfullUrl)


if __name__ == "__main__":
    url = "http://ggzyjy.shandong.gov.cn:80/jsgczbgg/3186567.jhtml?type=1"  # 原始链接
    key = "qnbyzzwmdgghmcnm"  # 加密参数
    decrypt = Decrypt()
    decrypt.main(url,key)

解决:

 参考

https://blog.csdn.net/hh775313602/article/details/78991340

https://www.cnblogs.com/libo0125ok/p/7668026.

html https://blog.csdn.net/qq_43500579/article/details/97615479


 

 

你可以使用python的cryptography库来实现AES加密解密,以及使用zeropadding进行填充。 首先,你需要安装cryptography库。可以使用以下命令来安装: ``` pip install cryptography ``` 接下来,你可以使用以下代码示例来实现AES加密解密,并使用zeropadding进行填充: ```python from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes from cryptography.hazmat.primitives import padding from cryptography.hazmat.backends import default_backend import os def aes_encrypt(plain_text, key): # 生成一个随机的初始化向量 iv = os.urandom(16) # 使用zeropadding进行填充 padder = padding.ZeroPadding(128).padder() padded_data = padder.update(plain_text) + padder.finalize() # 创建AES加密器对象 cipher = Cipher(algorithms.AES(key), modes.CBC(iv), backend=default_backend()) encryptor = cipher.encryptor() # 执行加密操作 cipher_text = encryptor.update(padded_data) + encryptor.finalize() return iv + cipher_text def aes_decrypt(cipher_text, key): # 提取初始化向量和密文 iv = cipher_text[:16] cipher_text = cipher_text[16:] # 创建AES解密器对象 cipher = Cipher(algorithms.AES(key), modes.CBC(iv), backend=default_backend()) decryptor = cipher.decryptor() # 执行解密操作 padded_data = decryptor.update(cipher_text) + decryptor.finalize() # 使用zeropadding进行取消填充 unpadder = padding.ZeroPadding(128).unpadder() plain_text = unpadder.update(padded_data) + unpadder.finalize() return plain_text # 测试代码 key = os.urandom(32) # 生成一个随机密钥 plain_text = b"Hello, AES!" # 原始文本 # 加密 cipher_text = aes_encrypt(plain_text, key) print("Cipher Text: ", cipher_text) # 解密 decrypted_text = aes_decrypt(cipher_text, key) print("Decrypted Text: ", decrypted_text) ``` 这段代码中,我们使用了AES加密算法和CBC模式来加密和解密数据。同时,我们使用了zeropadding进行填充,确保数据长度满足加密算法的要求。需要注意的是,密钥的长度必须符合AES算法的要求(16、24、或32字节)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值