Provides tools to perform web searches using the Serper API, returning organic results, knowledge graph data, and related searches with support for advanced filters and operators.
Extracts content from web pages and transforms it into structured markdown, including support for metadata and JSON-LD extraction.
Serper Search and Scrape MCP Server
A TypeScript-based MCP server that provides web search and webpage scraping capabilities using the Serper API. This server integrates with Claude Desktop to enable powerful web search and content extraction features.
Features
Tools
google_search- Perform web searches via Serper APIRich search results including organic results, knowledge graph, "people also ask", and related searches
Supports region and language targeting
Optional parameters for location, pagination, time filters, and autocorrection
Supports advanced search operators:
site: Limit results to specific domainfiletype: Limit to specific file types (e.g., 'pdf', 'doc')inurl: Search for pages with word in URLintitle: Search for pages with word in titlerelated: Find similar websitescache: View Google's cached version of a specific URLbefore: Date before in YYYY-MM-DD formatafter: Date after in YYYY-MM-DD formatexact: Exact phrase matchexclude: Terms to exclude from search resultsor: Alternative terms (OR operator)
scrape- Extract content from web pagesGet plain text and optional markdown content
Includes JSON-LD and head metadata
Preserves document structure
Related MCP server: Search MCP Server
Requirements
Node.js >= 18
Serper API key (set as
SERPER_API_KEYenvironment variable)
Development
Install dependencies:
Build the server:
For development with auto-rebuild:
Run tests:
Environment Variables
Create a .env file in the root directory:
Debugging
Since MCP servers communicate over stdio, debugging can be challenging. We recommend using the MCP Inspector, which is available as a package script:
The Inspector will provide a URL to access debugging tools in your browser.
Installation
Installing via Smithery
To install Serper Search and Scrape for Claude Desktop automatically via Smithery:
Claude Desktop
Add the server config at:
MacOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%/Claude/claude_desktop_config.json
Cline
Open the Cline extension settings
Open "MCP Servers" tab
Click on "Configure MCP Servers"
Add the server config:
Additional Cline configuration options:
disabled: Set tofalseto enable the serverautoApprove: List of tools that don't require explicit approval for each use
Cursor
Open the Cursor settings
Open "Features" settings
In the "MCP Servers" section, click on "Add new MCP Server"
Choose a name, and select "command" as "Type"
In the "Command" field, enter the following:
Docker
You can also run the server using Docker. First, build the image:
Then run the container with your Serper API key:
Alternatively, if you have your environment variables in a .env file:
For development, you might want to mount your source code as a volume:
Note: Make sure to replace your_api_key_here with your actual Serper API key.