kali_Linux_2024安装frida==12.8.0

发布于:2025-03-07 ⋅ 阅读:(158) ⋅ 点赞:(0)

windows系统frida==12.8.0安装思路

陈桂林老师在《安卓Frida逆向与协议分析》这本书里面介绍的frida调试组合是:

python==3.8.0

frida==12.8.0
frida-tools==5.3.0
object==1.8.4

在这里插入图片描述

通过上面链接提供的思路,也就表示在Linux中也是类似的安装流程。

首先需要准备frida==12.8.0的源码包以及对应的egg文件

frida-12.8.0源码包

对应的egg文件

对应的下载链接是:
源码包
egg文件

当然,解压完之后需要修改源码包的setup.py文件,跳过xmlrpc的检查

//setup.py

# -*- coding: utf-8 -*-
from __future__ import print_function

import codecs
try:
    from io import BytesIO
except:
    try:
        from cStringIO import StringIO as BytesIO
    except:
        from StringIO import StringIO as BytesIO
import os
import platform
import re
from setuptools import setup
from setuptools.command.build_ext import build_ext
from setuptools.extension import Extension
import shutil
import struct
import sys
try:
    from urllib.request import urlopen, Request
except:
    from urllib2 import urlopen, Request
try:
    import xmlrpclib
except ImportError:
    import xmlrpc.client as xmlrpclib
import zipfile


package_dir = os.path.dirname(os.path.realpath(__file__))
pkg_info = os.path.join(package_dir, "PKG-INFO")
in_source_package = os.path.isfile(pkg_info)
if in_source_package:
    with codecs.open(pkg_info, "r", 'utf-8') as f:
        version_line = [line.rstrip("\r") for line in f.read().split("\n") if line.startswith("Version: ")][0]
        frida_version = version_line[9:]
    long_description = None
else:
    frida_version = os.environ['FRIDA_VERSION']
    long_description = codecs.open(os.path.join(package_dir, "README.md"), "r", 'utf-8').read()
    frida_extension = os.environ['FRIDA_EXTENSION']
frida_major_version = int(frida_version.split(".")[0])


class FridaPrebuiltExt(build_ext):
    def build_extension(self, ext):
        target = self.get_ext_fullpath(ext.name)
        target_extension = os.path.splitext(target)[1]
        target_dir = os.path.dirname(target)
        try:
            os.makedirs(target_dir)
        except:
            pass
        if in_source_package:
            python_version = sys.version_info[0:2]
            python_major_version = python_version[0]
            system = platform.system()
            arch = struct.calcsize('P') * 8
            if system == 'Windows':
                os_version = "win-amd64" if arch == 64 else "win32"
            elif system == 'Darwin':
                os_version = "macosx-10.6-intel" if python_major_version == 3 else "macosx-10.9-intel"
            elif system == 'Linux':
                machine = platform.machine()
                if machine == "" or "86" in machine:
                    os_version = "linux-x86_64" if arch == 64 else "linux-i686"
                else:
                    os_version = "linux-" + machine

            # 注释掉或删除以下网络查询部分
            # network_error = None
            # try:
            #     print("querying pypi for available prebuilds")
            #     client = xmlrpclib.ServerProxy("https://pypi.python.org/pypi", transport=UrllibTransport())
            #     urls = client.release_urls("frida", frida_version)
            #     ...
            # except Exception as e:
            #     network_error = e

            # 直接指定预构建扩展文件路径
            egg_filename = "frida-{}-py{}.{}-{}.egg".format(frida_version, python_version[0], python_version[1], os_version)
            egg_path = os.path.expanduser("~/{}".format(egg_filename))

            print("looking for prebuilt extension in home directory, i.e.", egg_path)
            try:
                with open(egg_path, "rb") as f:
                    egg_data = f.read()
            except:
                print("no prebuilt extension found in home directory")
                raise Exception("Please download the appropriate .egg file and place it in your home directory.")

            egg_file = BytesIO(egg_data)

            print("extracting prebuilt extension")
            egg_zip = zipfile.ZipFile(egg_file)
            extension_member = [info for info in egg_zip.infolist() if info.filename.endswith(target_extension)][0]
            extension_data = egg_zip.read(extension_member)
            if system == 'Windows' and python_major_version >= 3:
                extension_data = re.sub(b"python[3-9][0-9].dll", "python{0}{1}.dll".format(*python_version).encode('utf-8'), extension_data)
            with open(target, 'wb') as f:
                f.write(extension_data)
        else:
            shutil.copyfile(frida_extension, target)


setup(
    name="frida",
    version=frida_version,
    description="Dynamic instrumentation toolkit for developers, reverse-engineers, and security researchers",
    long_description=long_description,
    long_description_content_type="text/markdown",
    author="Frida Developers",
    author_email="oleavr@frida.re",
    url="https://www.frida.re",
    license="wxWindows Library Licence, Version 3.1",
    zip_safe=True,
    keywords="frida debugger dynamic instrumentation inject javascript windows macos linux ios iphone ipad android qnx",
    classifiers=[
        "Development Status :: 5 - Production/Stable",
        "Environment :: Console",
        "Environment :: MacOS X",
        "Environment :: Win32 (MS Windows)",
        "Intended Audience :: Developers",
        "Intended Audience :: Science/Research",
        "License :: OSI Approved",
        "Natural Language :: English",
        "Operating System :: MacOS :: MacOS X",
        "Operating System :: Microsoft :: Windows",
        "Operating System :: POSIX :: Linux",
        "Programming Language :: Python :: 2",
        "Programming Language :: Python :: 2.7",
        "Programming Language :: Python :: 3",
        "Programming Language :: Python :: 3.4",
        "Programming Language :: Python :: 3.5",
        "Programming Language :: Python :: 3.6",
        "Programming Language :: Python :: 3.7",
        "Programming Language :: Python :: Implementation :: CPython",
        "Programming Language :: JavaScript",
        "Topic :: Software Development :: Debuggers",
        "Topic :: Software Development :: Libraries :: Python Modules"
    ],
    packages=['frida'],
    ext_modules=[Extension('_frida', [])],
    cmdclass={
        'build_ext': FridaPrebuiltExt
    }
)

同样需要注意的地方是,egg文件的命名在上面的setup.py已经拼接成frida-12.8.0-py3.8-linux-x86_64.egg所以需要将文件名修改成这个。

最后执行:python setup.py install
在这里插入图片描述

另外两个objectionfrida-tools能够正常pip安装,所以随后这套环境成功搭建!

在这里插入图片描述


网站公告

今日签到

点亮在社区的每一天
去签到