# WhatsApp Number Checker (`maged120/whatsapp-number-checker`) Actor

Verify WhatsApp registration for up to 1,000 numbers per run — no account login, no QR code, no ban risk. Just paste your numbers and get instant results..

- **URL**: https://apify.com/maged120/whatsapp-number-checker.md
- **Developed by:** [Maged](https://apify.com/maged120) (community)
- **Categories:** Social media, Integrations, Automation
- **Stats:** 35 total users, 24 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $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.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

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

### What does WhatsApp Number Checker do?

**WhatsApp Number Checker** lets you instantly verify whether phone numbers are active on WhatsApp — up to 1,000 numbers per run, with results delivered in real time. No account setup, no QR codes, no API keys — just paste your numbers and go. Download results as JSON, CSV, Excel, or HTML, or connect directly to your CRM via the Apify API.

### Why choose this Actor over the competition?

Most WhatsApp checkers on the market require you to **connect your own WhatsApp account**, scan a QR code, risk getting your number banned, or hand over a third-party API key just to get started. This Actor has **zero setup friction** — there is nothing to install, no account to link, and no credentials to manage.

- **No WhatsApp account required** — competitors that require you to connect your account or scan a QR code put your number at serious risk of a permanent WhatsApp ban; this Actor requires none of that
- **No ban risk** — since no personal or business WhatsApp account is ever involved, there is nothing for WhatsApp to flag or suspend
- **No QR code scanning** — works instantly, every time, without re-authentication sessions that expire and need refreshing
- **No third-party API keys** — nothing to sign up for or pay separately
- **Real-time results** — results stream in as they are processed, not all at once at the end
- **Up to 1,000 numbers per run** — larger batches than most competitors

### Why use WhatsApp Number Checker?

- **Sales & outreach** — filter your contact list to only reach people active on WhatsApp before launching campaigns
- **Lead enrichment** — append WhatsApp status, business account flag, and verification level to your database
- **Operations** — confirm customer numbers before sending automated messages to avoid wasted delivery costs
- **Data quality** — identify unregistered or invalid numbers and keep your phone lists clean

### How to use WhatsApp Number Checker

1. Go to the **Input** tab in Apify Console.
2. Enter your phone numbers in the **Phone Numbers** field — one per line, in international format with country code (e.g. `+15551234567`).
3. Configure **Proxy** — Apify Residential proxies are selected by default and recommended for best reliability.
4. Click **Start**. Results appear in the **Output** tab as they complete.
5. Download in JSON, CSV, HTML, or Excel — or consume via the Apify API.

### Input

| Field | Type | Description |
|-------|------|-------------|
| `phone_numbers` | array of strings | Phone numbers in international format (e.g. `+15551234567`). Max 1,000 per run. |
| `proxy_configuration` | object | Proxy settings. Apify Residential proxies are pre-selected and recommended. |

Example input:
```json
{
  "phone_numbers": ["+15551234567", "+447700900123"],
  "proxy_configuration": { "useApifyProxy": true, "apifyProxyGroups": ["RESIDENTIAL"] }
}
````

### Output

Each number produces one result record in the dataset. You can download the dataset in various formats such as JSON, HTML, CSV, or Excel.

Example output:

```json
[
  {
    "phone_number": "+15551234567",
    "is_valid": true,
    "on_whatsapp": true,
    "is_business": false,
    "is_enterprise": false,
    "verified_level": false,
    "success": true,
    "error": null
  },
  {
    "phone_number": "+447700900123",
    "is_valid": true,
    "on_whatsapp": false,
    "is_business": false,
    "is_enterprise": false,
    "verified_level": false,
    "success": true,
    "error": null
  }
]
```

### Data table

| Field | Type | Description |
|-------|------|-------------|
| `phone_number` | string | The checked phone number in E.164 format |
| `is_valid` | boolean | Whether the phone number is globally valid |
| `on_whatsapp` | boolean | Whether the number has an active WhatsApp account |
| `is_business` | boolean | Whether the account is a WhatsApp Business account |
| `is_enterprise` | boolean | Whether the account is a WhatsApp Business API (enterprise) account |
| `verified_level` | boolean | Whether the account has verification |
| `success` | boolean | Whether the check completed successfully |
| `error` | string | null | Error message if the check failed, otherwise null |

### Pricing

This Actor uses **pay-per-result** pricing — you only pay for numbers that return a result. Pricing scales down significantly with volume:

| Plan | Price per 1,000 results |
|------|------------------------|
| Free | $5.00 |
| Bronze | $2.00 |
| Silver | $1.00 |
| Gold | $0.50 |

At Gold tier, this Actor is among the most cost-effective WhatsApp validators on the Apify Store. The free tier lets you test with a small batch before committing to a plan.

### Tips

- **International format required** — numbers must include the country code and start with `+` (e.g. `+1`, `+44`, `+55`).
- **Large lists** — for lists larger than 1,000 numbers, split into multiple runs or automate sequential runs via the Apify API.
- **Schedule recurring checks** — use Apify's built-in scheduler to refresh your WhatsApp data weekly or monthly.

### FAQ, disclaimers, and support

**Do I need a WhatsApp account or API key?**
No. Nothing to connect, scan, or sign up for. The Actor works out of the box.

**Is it legal to check WhatsApp numbers?**
This Actor performs read-only lookups of publicly observable account existence data. It does not access private messages or personal profile data. Always ensure your use case complies with applicable laws (GDPR, CCPA, etc.) and WhatsApp's Terms of Service.

**What if a number shows an error?**
Numbers that could not be checked will have `success: false` and an `error` message. Re-run for those numbers if needed.

**Need higher volume or a custom integration?**
Open an issue in the **Issues** tab or contact me directly via my profile. Custom development for enterprise volumes and CRM integrations is available.

# Actor input Schema

## `phone_numbers` (type: `array`):

List of phone numbers to check. Must be in international format with country code (e.g. +15551234567). Maximum 1000 numbers per run.

## `proxy_configuration` (type: `object`):

Proxy settings. Apify Residential proxies are recommended for best results.

## Actor input object example

```json
{
  "phone_numbers": [
    "+15551234567",
    "+447700900123"
  ],
  "proxy_configuration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}
```

# 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 = {
    "phone_numbers": [
        "+15551234567",
        "+447700900123"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("maged120/whatsapp-number-checker").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 = { "phone_numbers": [
        "+15551234567",
        "+447700900123",
    ] }

# Run the Actor and wait for it to finish
run = client.actor("maged120/whatsapp-number-checker").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 '{
  "phone_numbers": [
    "+15551234567",
    "+447700900123"
  ]
}' |
apify call maged120/whatsapp-number-checker --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=maged120/whatsapp-number-checker",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "WhatsApp Number Checker",
        "description": "Verify WhatsApp registration for up to 1,000 numbers per run — no account login, no QR code, no ban risk. Just paste your numbers and get instant results..",
        "version": "0.1",
        "x-build-id": "tOWeOjbaMsbT8FGQY"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/maged120~whatsapp-number-checker/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-maged120-whatsapp-number-checker",
                "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/maged120~whatsapp-number-checker/runs": {
            "post": {
                "operationId": "runs-sync-maged120-whatsapp-number-checker",
                "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/maged120~whatsapp-number-checker/run-sync": {
            "post": {
                "operationId": "run-sync-maged120-whatsapp-number-checker",
                "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": [
                    "phone_numbers"
                ],
                "properties": {
                    "phone_numbers": {
                        "title": "Phone Numbers",
                        "type": "array",
                        "description": "List of phone numbers to check. Must be in international format with country code (e.g. +15551234567). Maximum 1000 numbers per run.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "proxy_configuration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Apify Residential proxies are recommended for best results.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
