百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

JS加密破解案例分享

bigegpt 2024-08-07 17:48 7 浏览

JS加密破解案例分享

我们在提取某个接口数据的时候,往往后端服务器需要进行身份认证。因此我们要提取数据的时候就有因为这个认证导致我们的接口不能够获取到想要的数据。这样我首先先分析一般登录的流程。

问题分析

界面输入用户名密码--》到后台服务器中验证--》服务器验证通过--》登录成功

服务器验证不通过--》登录失败

技术资源

在这里首先我们要引入python的requests库中的session对象。

会话对象让你能够跨请求保持某些参数。它也会在同一个 Session 实例发出的所有请求之间保持 cookie, 期间使用 urllib3 的 connection pooling 功能。所以如果你向同一主机发送多个请求,底层的 TCP 连接将会被重用,从而带来显著的性能提升。 (参见 HTTP persistent connection).这里利用这个特性,就能完成我们登录,之后再去获取信息。

示例分析

这里我拿一个示例网站来分析如何保持登录状态,在调研需要登录了之后才能提取到相应信息的接口。

解决过程: 查询登录接口---查找登录接口需要的参数信息---获取登录加密后的用户名和密码信息(python模拟加密过程)---组合登录接口请求信息--- 创建保持会话对象---进行登录 ---在进行其他接口获取。

首先打开网站的登录界面,我们使用F12定位到登录界面填写,用户名和密码的html界面,查看到登录源码如下

<div id="wrapper" class="clearfix">
  <div class="aw-login-wrap clearfix">
    <!-- 登陆框 -->
    <div class="aw-login-box pull-right">
      <div class="aw-mod">
        <div class="aw-mod-head">
          <a href="https://www.jisilu.cn/account/register/" class="aw-btn b-new-user pull-right">注册新用户</a>          <i class="aw-icon i-login-user-no-hover"></i>
          登录        </div>
        <div class="aw-mod-body">
          <form id="login_form" method="post" onsubmit="doLogin();return false;" action="https://www.jisilu.cn/account/ajax/login_process/">
            <input type="hidden" name="return_url" value="https://www.jisilu.cn/" />
            <ul>
                                                  <li>
                <label class="aw-label-icon pull-left" for="aw-login-user-name"><i class="aw-icon i-login-user-no-hover"></i></label>
                <input type="text" id="aw-login-user-name" placeholder="预留的手机号" name="user_name" value="server" />
              </li>
              <li>
                <label class="aw-label-icon pull-left" for="aw-login-user-password"><i class="aw-icon i-key"></i></label>
                <input type="password" id="aw-login-user-password" placeholder="密码" name="password" />
              </li>
              <li class="error error-message hide">
                <p><i class="aw-icon i-no"></i><em id="show_error_msg"></em></p>
              </li>
              <li class="last">
                <a href="javascript:;" onclick="doLogin(); return false;" id="login_submit" class="pull-right btn btn-large btn-success">登录</a>
                <input id="login-radio" type="checkbox" value="1" checked="true" name="net_auto_login" />
                <label for="login-radio">记住我</label>
                <a href="https://www.jisilu.cn/account/find_password/" style="color: #08c;">忘记密码</a>
              </li>
            </ul>
          </form>
        </div>
        <div class="aw-mod-footer">
          <a title="微信登录" class="js-bindwechat" href="/wx/open/login/" style="color: #08c;"><i class="sprite-index-icon-wechat"></i>微信登录</a>
                  </div>

通过分析上面的登录源代码,发现登录调用的是doLogin()函数,我们可以通过前端断点的方式定位到doLogin()函数的执行逻辑

var A397151C04723421F = '397151C04723421F';
function doLogin(){
    var data = $('#login_form').serializeObjectToJson();
    data['_post_type'] = 'ajax';
    data['aes'] = 1;
    data['user_name'] = jslencode(data['user_name'], A397151C04723421F);
    data['password'] = jslencode(data['password'], A397151C04723421F);
  $("body").css("cursor", "progress");
    $.post('/account/ajax/login_process/', data, function(rst){
      $("body").css("cursor", "default");
        on_login_error_processer(rst);
    }, 'json');
}

从这个位置就能够详细地查看到登录使用的后端接口和接口请求需要的参数。从上面的user_name和password两个参数看到,这个地方使用的一个自定义函数进行加密。

看到这个位置我们不难发现我们需要解决的问题就应该在这个位置。这里有两种方法解决:

  1. 可以查看 jslencode函数是如何实现的,找到python相关的库重写jslencode实现的业务逻辑。
  2. 直接断点获取加密后的请求参数数据,保存到自己的请求参数中。查看请求题中是否还有其他参数,一同添加上。同样的账号他加密后的结果是一样的。

这个位置我使用的是第2种方法来解决。示例代码如下:

import requests

sess = requests.session()
login_in_url = 'https://www.jisilu.cn/account/ajax/login_process/'
data = {'aes': 1,
        'net_auto_login': "1",
        'password': "5b5c8ba28de211a7f358eb533345554",
        'return_url': "https://www.jisilu.cn/",
        'user_name': "97a468e9df2wweew2131a59c1a6b61c",
        '_post_type': "ajax"}
headers = {
    'X-Requested-With': 'XMLHttpRequest',
    'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
    'User-Agent': "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36",

}
res = sess.post(login_in_url, data=data, headers=headers)
print(res.json())

base_url = 'https://www.jisilu.cn/data/cbnew/cb_list/?___jsl=LST___t=1573193958081'
response = sess.get(base_url, headers=headers)
text = response.text
print(text)

到这里我们就解决的js这种加密问题。



相关推荐

pyproject.toml到底是什么东西?(py trim)

最近,在Twitter上有一个Python项目的维护者,他的项目因为构建失败而出现了一些bug(这个特别的项目不提供wheel,只提供sdist)。最终,发现这个bug是由于这个项目使用了一个pypr...

BDP服务平台SDK for Python3发布(bdp数据平台)

下载地址https://github.com/imysm/opends-sdk-python3.git说明最近在开发和bdp平台有关的项目,用到了bdp的python的sdk,但是官方是基于p...

Python-for-Android (p4a):(python-for-android p4a windows)

一、Python-for-Android(p4a)简介Python-for-Android(p4a),一个强大的开发工具,能够将你的Python应用程序打包成可在Android设备上运行...

Qt for Python—Qt Designer 概览

前言本系列第三篇文章(QtforPython学习笔记—应用程序初探)、第四篇文章(QtforPython学习笔记—应用程序再探)中均是使用纯代码方式来开发PySide6GUI应用程序...

Python:判断质数(jmu-python-判断质数)

#Python:判断质数defisPrime(n):foriinrange(2,n):ifn%i==0:return0re...

为什么那么多人讨厌Python(为什么python这么难)

Python那么棒,为什么那么多人讨厌它呢?我整理了一下,主要有这些原因:用缩进替代大括号许多人抱怨Python完全依赖于缩进来创建代码块,代码多一点就很难看到函数在哪里结束,那么你就需要把一个函数拆...

一文了解 Python 中带有 else 的循环语句 for-else/while-else

在本文中,我们将向您介绍如何在python中使用带有else的for/while循环语句。可能许多人对循环和else一起使用感到困惑,因为在if-else选择结构中else正常...

python的numpy向量化语句为什么会比for快?

我们先来看看,python之类语言的for循环,和其它语言相比,额外付出了什么。我们知道,python是解释执行的。举例来说,执行x=1234+5678,对编译型语言,是从内存读入两个shor...

开眼界!Python遍历文件可以这样做

来源:【公众号】Python技术Python对于文件夹或者文件的遍历一般有两种操作方法,一种是至二级利用其封装好的walk方法操作:import osfor root,d...

告别简单format()!Python Formatter类让你的代码更专业

Python中Formatter类是string模块中的一个重要类,它实现了Python字符串格式化的底层机制,允许开发者创建自定义的格式化行为。通过深入理解Formatter类的工作原理和使用方法,...

python学习——038如何将for循环改写成列表推导式

在Python里,列表推导式是一种能够简洁生成列表的表达式,可用于替换普通的for循环。下面是列表推导式的基本语法和常见应用场景。基本语法result=[]foriteminite...

详谈for循环和while循环的区别(for循环语句与while循环语句有什么区别)

初九,潜龙勿用在刚开始使用python循环语句时,经常会遇到for循环和while循环的混用,不清楚该如何选择;今天就对这2个循环语句做深入的分析,让大家更好地了解这2个循环语句以方便后续学习的加深。...

Python编程基础:循环结构for和while

Python中的循环结构包括两个,一是遍历循环(for循环),一是条件循环(while循环)。遍历循环遍历循环(for循环)会挨个访问序列或可迭代对象的元素,并执行里面的代码块。foriinra...

学习编程第154天 python编程 for循环输出菱形图

今天学习的是刘金玉老师零基础Python教程第38期,主要内容是python编程for循环输出菱形※。(一)利用for循环输出菱形形状的*号图形1.思路:将菱形分解为上下两个部分三角形图案,分别利用...

python 10个堪称完美的for循环实践

在Python中,for循环的高效使用能显著提升代码性能和可读性。以下是10个堪称完美的for循环实践,涵盖数据处理、算法优化和Pythonic编程风格:1.遍历列表同时获取索引(enumerate...