Skip to main content

The spider_fingerprint project for python.

Project description

spider_fingerprint_py

Python bindings for the spider_fingerprint Rust crate.

spider_fingerprint_py allows you to easily generate browser fingerprint and stealth scripts. It's ideal for effective automation, web scraping, bot-test evasion, and security testing workflows.


Installation

Install from PyPI:

pip install spider_fingerprint_py

Quick Start

Here's how to generate a stealth emulation JavaScript in a few lines of Python:

from spider_fingerprint_py import (
    PyViewport,
    PyTier,
    PyFingerprintMode,
    generate_emulation_script,
)

# if you set the user-agent to an empty string a random agent is used.
user_agent = (
    "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) "
    "AppleWebKit/537.36 (KHTML, like Gecko) "
    "Chrome/120.0.0.0 Safari/537.36"
)

# Random viewport simulating a real user
viewport = PyViewport.random()

# Generate the fingerprint spoofing script
script = generate_emulation_script(
    user_agent=user_agent,
    tier=PyTier.Full,
    fingerprint_mode=PyFingerprintMode.Basic,
    dismiss_dialogs=True,
    viewport=viewport,
    eval_script=None
)

print("Stealth Emulation JavaScript:\n")
print(script)

Documentation

Below you'll find complete reference documentation for classes, enums, and functions provided by the spider_fingerprint_py Python library:


PyViewport (class)

Represents viewport configurations for browser fingerprint emulation.

Attribute Type Description
width int Viewport width in pixels
height int Viewport height in pixels
device_scale_factor float or None Device pixel ratio (e.g., 2.0 for Retina)
emulating_mobile bool Enable emulation of mobile-device behavior
is_landscape bool Landscape (True) or Portrait (False) orientation
has_touch bool Simulate touch-enabled devices

Usage Example:

viewport = PyViewport(1280, 720)
viewport.emulating_mobile = True
viewport.device_scale_factor = 2.0
viewport.is_landscape = False
viewport.has_touch = True

PyTier (enum)

Controls the aggressiveness and scope of stealth applied through fingerprint spoofing.

Variant Description
Basic Basic stealth spoofing capabilities including GPU/WebGL spoofing.
BasicWithConsole Basic stealth mode combined with console output (for debugging).
BasicNoWebgl Basic stealth spoofing without WebGL spoofing techniques.
Mid Intermediate stealth protections with improved spoofing coverage.
Full Comprehensive stealth protections covering most fingerprinting.
None No spoofing; original browser fingerprint exposed fully.

Example:

tier = PyTier.Full

PyAgentOs (enum)

Defines operating system target profiles for browser fingerprint emulation.

Variant Description
Linux Linux operating system fingerprint and profile emulation.
Mac macOS fingerprint and browser environment emulation.
Windows Windows operating system fingerprint emulation.
Android Android device fingerprint and browser emulation.

Example:

agent_os = PyAgentOs.Mac

Testing

  1. maturin develop
  2. pytest -s test_spider_fingerprint.py

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

spider_fingerprint_py-0.0.3.tar.gz (20.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

spider_fingerprint_py-0.0.3-cp313-cp313-macosx_11_0_arm64.whl (253.7 kB view details)

Uploaded CPython 3.13macOS 11.0+ ARM64

File details

Details for the file spider_fingerprint_py-0.0.3.tar.gz.

File metadata

File hashes

Hashes for spider_fingerprint_py-0.0.3.tar.gz
Algorithm Hash digest
SHA256 dfad63c0175c56b7a5573829ca8f6419904a56b96d1499258dc78d5f12f08ba9
MD5 505b56ff8f04fb9166694472c8ded63e
BLAKE2b-256 065d1a79b7078d40d68b153bbad08c5909d789802773706d2836bb9ff681450a

See more details on using hashes here.

File details

Details for the file spider_fingerprint_py-0.0.3-cp313-cp313-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for spider_fingerprint_py-0.0.3-cp313-cp313-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 045ec3ccf3af52d973b90012a4ec35fec0064a0a5decf8534ce288bfc2a4c62c
MD5 ec7a0da32a3d602deff4004edbd90b76
BLAKE2b-256 d55f2697f8230a9e34f01a59928dfc827a574406df6c27b435ca82bb5ea1f42b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page