# Website Technology Stack Detector (`botflowtech/website-technology-stack-detector`) Actor

Detect CMS, JavaScript frameworks, analytics tools, CDN, and hosting from any website. Identifies WordPress, Shopify, React, Next.js, and 50+ technologies.

- **URL**: https://apify.com/botflowtech/website-technology-stack-detector.md
- **Developed by:** [BotFlowTech](https://apify.com/botflowtech) (community)
- **Categories:** SEO tools, Automation
- **Stats:** 45 total users, 6 monthly users, 100.0% runs succeeded, 1 bookmarks
- **User rating**: No ratings yet

## Pricing

$1.00 / 1,000 results

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## Website Technology Stack Detector

> **Detect CMS, JavaScript frameworks, analytics tools, CDN providers, hosting platforms, and 50+ technologies from any website URL — fast and at scale.**

### What does Website Technology Stack Detector do?

Website Technology Stack Detector is a powerful Apify actor that analyzes any website and identifies the technologies it uses. It scans HTML source code, response headers, script tags, meta tags, and link elements to detect content management systems, JavaScript frameworks, analytics tools, CDN providers, hosting platforms, e-commerce solutions, marketing tools, and CSS frameworks.

Think of it as your own **Wappalyzer alternative** or **BuiltWith alternative** — but running on Apify's infrastructure with full API access, bulk processing, and pay-per-event pricing.

**Perfect for:** sales prospecting, competitor analysis, market research, lead generation, technology auditing, and data enrichment.

### Key Features

- **50+ technologies detected** across 8 categories
- **Bulk processing** — analyze hundreds or thousands of websites in a single run
- **Fast & reliable** — built on Crawlee's CheerioCrawler for efficient HTML parsing
- **Auto-retry** — failed requests are retried automatically (up to 2 retries)
- **PPE monetization** — pay-per-event pricing support for Apify marketplace
- **Structured output** — clean JSON results organized by technology category
- **Header analysis** — detects server software, CDN, and hosting from HTTP headers
- **CSS framework detection** — identifies Bootstrap, Tailwind CSS, Bulma, Foundation

### Detectable Technologies

#### Content Management Systems (CMS)
WordPress, Shopify, Wix, Squarespace, Webflow, Drupal, Joomla, Magento, PrestaShop, BigCommerce

#### JavaScript Frameworks
React, Vue.js, Angular, Next.js, Nuxt.js, Svelte, jQuery

#### Analytics & Tracking
Google Analytics, Google Tag Manager, Facebook Pixel, Hotjar, Mixpanel, Segment

#### CDN & Infrastructure
Cloudflare, Fastly, Akamai, Amazon CloudFront, jsDelivr, unpkg

#### Hosting Providers
Vercel, Netlify, AWS, GitHub Pages, Heroku

#### E-commerce
WooCommerce, Stripe, PayPal

#### Marketing & CRM Tools
HubSpot, Mailchimp, Intercom, Drift, Zendesk

#### CSS Frameworks
Bootstrap, Tailwind CSS, Bulma, Foundation

#### Additional Metadata
- Server software (Apache, Nginx, etc.)
- X-Powered-By header
- Meta generator tag
- HTML language attribute
- Mobile responsiveness (viewport meta)
- HTTPS status
- External script count and top scripts

### Input

```json
{
    "urls": [
        "https://www.shopify.com",
        "https://www.apple.com",
        "https://www.stripe.com",
        "https://github.com"
    ],
    "maxRequestsPerCrawl": 1000
}
````

#### Input Parameters

| Parameter | Type | Required | Default | Description |
|-----------|------|----------|---------|-------------|
| `urls` | array | Yes | — | List of website URLs to analyze |
| `maxRequestsPerCrawl` | integer | No | 1000 | Maximum number of websites to process |

### Output

Each URL produces a detailed result object in the dataset:

```json
{
    "url": "https://www.shopify.com",
    "cms": ["Shopify"],
    "frameworks": ["React", "Next.js"],
    "analytics": ["Google Analytics", "Google Tag Manager"],
    "cdn": ["Cloudflare", "Amazon CloudFront"],
    "hosting": [],
    "ecommerce": ["Stripe"],
    "marketing": ["Intercom"],
    "cssFrameworks": [],
    "server": "cloudflare",
    "poweredBy": null,
    "generator": null,
    "language": "en",
    "isMobileResponsive": true,
    "isHttps": true,
    "scriptCount": 23,
    "topScripts": ["https://cdn.shopify.com/..."],
    "detectedCount": 7,
    "scrapedAt": "2026-03-16T12:00:00.000Z"
}
```

If a URL fails:

```json
{
    "url": "https://unreachable-site.com",
    "error": "Failed to fetch website",
    "cms": [],
    "frameworks": [],
    "analytics": [],
    "detectedCount": 0,
    "scrapedAt": "2026-03-16T12:00:00.000Z"
}
```

### Use Cases

- **Sales Prospecting** — Find all Shopify stores, WordPress sites, or companies using specific analytics tools in your target list
- **Competitor Analysis** — Discover which technologies your competitors are using and track adoption trends
- **Market Research** — Analyze technology market share across industries or geographies
- **Lead Generation** — Build targeted prospect lists based on technology stack (e.g., "all sites using HubSpot but not Intercom")
- **Technology Auditing** — Audit your own portfolio of websites for consistency and compliance
- **Data Enrichment** — Enrich CRM records with technology stack data for better segmentation
- **Migration Planning** — Identify sites still running legacy CMS or frameworks for upgrade opportunities
- **Agency Pitching** — Find potential clients using outdated technologies you can help them upgrade

### Pricing

This actor supports **Pay-Per-Event (PPE)** pricing on the Apify marketplace. You are charged per website analyzed. The actor automatically stops processing when your budget limit is reached, so you never overspend.

Free tier usage is also supported — the actor works the same way without PPE, storing all results in the dataset.

### FAQ

**Q: How accurate is the detection?**
A: The actor uses regex-based pattern matching on HTML source code and HTTP headers. It's highly accurate for technologies that leave clear signatures (like WordPress, React, Google Analytics). Some technologies may not be detected if they don't leave identifiable patterns in the initial HTML response.

**Q: Does it work with Single Page Applications (SPAs)?**
A: The actor fetches the initial HTML response using CheerioCrawler. Most meta tags, script sources, and link elements are present in the initial HTML even for SPAs. However, technologies loaded dynamically via JavaScript after page load may not be detected.

**Q: Can I analyze thousands of websites?**
A: Yes! The actor uses Crawlee's CheerioCrawler which efficiently processes URLs with automatic retries and concurrency management. Set `maxRequestsPerCrawl` to control the limit.

**Q: What if a website blocks the request?**
A: The actor uses a realistic browser User-Agent header. Failed requests are automatically retried up to 2 times. For heavily protected sites, consider using a proxy configuration.

**Q: How is PPE pricing calculated?**
A: Each URL analyzed (whether successful or failed) counts as one `tech-detected` event. You set your budget limit, and the actor stops gracefully when it's reached.

**Q: Is this a Wappalyzer alternative?**
A: Yes — it provides similar technology detection capabilities but runs on Apify's cloud infrastructure with full API access, bulk processing, and structured JSON output. It's ideal for automated pipelines and large-scale analysis.

### Keywords

website technology detector, tech stack analyzer, CMS detector, website technology checker, built with what, wappalyzer alternative, builtwith alternative, website profiler, technology fingerprinting, web technology scanner, framework detector, analytics detector, CDN detector, hosting detector, bulk technology detection

# Actor input Schema

## `urls` (type: `array`):

List of website URLs to analyze for technology stack detection

## `maxRequestsPerCrawl` (type: `integer`):

Maximum number of websites to process in a single run

## Actor input object example

```json
{
  "urls": [
    "https://www.shopify.com",
    "https://www.apple.com",
    "https://www.stripe.com"
  ],
  "maxRequestsPerCrawl": 1000
}
```

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "urls": [
        "https://www.shopify.com",
        "https://www.apple.com",
        "https://www.stripe.com"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("botflowtech/website-technology-stack-detector").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = { "urls": [
        "https://www.shopify.com",
        "https://www.apple.com",
        "https://www.stripe.com",
    ] }

# Run the Actor and wait for it to finish
run = client.actor("botflowtech/website-technology-stack-detector").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "urls": [
    "https://www.shopify.com",
    "https://www.apple.com",
    "https://www.stripe.com"
  ]
}' |
apify call botflowtech/website-technology-stack-detector --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=botflowtech/website-technology-stack-detector",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Website Technology Stack Detector",
        "description": "Detect CMS, JavaScript frameworks, analytics tools, CDN, and hosting from any website. Identifies WordPress, Shopify, React, Next.js, and 50+ technologies.",
        "version": "0.0",
        "x-build-id": "5FHNmfO0lGBNPiAVH"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/botflowtech~website-technology-stack-detector/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-botflowtech-website-technology-stack-detector",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/botflowtech~website-technology-stack-detector/runs": {
            "post": {
                "operationId": "runs-sync-botflowtech-website-technology-stack-detector",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/botflowtech~website-technology-stack-detector/run-sync": {
            "post": {
                "operationId": "run-sync-botflowtech-website-technology-stack-detector",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "urls"
                ],
                "properties": {
                    "urls": {
                        "title": "Website URLs",
                        "type": "array",
                        "description": "List of website URLs to analyze for technology stack detection",
                        "items": {
                            "type": "string"
                        }
                    },
                    "maxRequestsPerCrawl": {
                        "title": "Max websites to analyze",
                        "minimum": 1,
                        "type": "integer",
                        "description": "Maximum number of websites to process in a single run",
                        "default": 1000
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
