serper-search-scrape-mcp-server Featured
Serper MCP Server supporting search and webpage scraping - marcopesani/mcp-server-serper
marcopesani
README
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 API- Rich 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 pages- Get plain text and optional markdown content
- Includes JSON-LD and head metadata
- Preserves document structure
Requirements
- Node.js >= 18
- Serper API key (set as
SERPER_API_KEY
environment variable)
Development
Install dependencies:
Build the server:
For development with auto-rebuild:
Run tests:
npm test # Run all tests npm run test:watch # Run tests in watch mode npm run test:coverage # Run tests with coverage npm run test:integration # Run integration tests
Environment Variables
Create a .env
file in the root directory:
SERPER_API_KEY=your_api_key_here
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:
npx -y @smithery/cli install @marcopesani/mcp-server-serper --client claude
Claude Desktop
Add the server config at:
- MacOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- Windows:
%APPDATA%/Claude/claude_desktop_config.json
{ "mcpServers": { "serper-search": { "command": "npx", "args": ["-y", "serper-search-scrape-mcp-server"], "env": { "SERPER_API_KEY": "your_api_key_here" } } } }
Cline
- Open the Cline extension settings
- Open "MCP Servers" tab
- Click on "Configure MCP Servers"
- Add the server config:
{ "mcpServers": { "github.com/marcopesani/mcp-server-serper": { "command": "npx", "args": ["-y", "serper-search-scrape-mcp-server"], "env": { "SERPER_API_KEY": "your_api_key_here" }, "disabled": false, "autoApprove": ["google_search", "scrape"] } } }
Additional Cline configuration options:
disabled
: Set tofalse
to 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:
env SERPER_API_KEY=your_api_key_here npx -y serper-search-scrape-mcp-server
Docker
You can also run the server using Docker. First, build the image:
docker build -t mcp-server-serper .
Then run the container with your Serper API key:
docker run -e SERPER_API_KEY=your_api_key_here mcp-server-serper
Alternatively, if you have your environment variables in a .env
file:
docker run --env-file .env mcp-server-serper
For development, you might want to mount your source code as a volume:
docker run -v $(pwd):/app --env-file .env mcp-server-serper
Note: Make sure to replace your_api_key_here
with your actual Serper API key.
Recommended Servers
playwright-mcp
A Model Context Protocol (MCP) server that provides browser automation capabilities using Playwright. This server enables LLMs to interact with web pages through structured accessibility snapshots, bypassing the need for screenshots or visually-tuned models.
Audiense Insights MCP Server
Audiense Insights MCP Server is a server based on the Model Context Protocol (MCP) that allows Claude and other MCP-compatible clients to interact with your Audiense Insights account - AudienseCo/mcp-audiense-insights
Kagi MCP Server
A Model Context Protocol (MCP) server for Kagi search. - kagisearch/kagimcp
graphlit-mcp-server
Model Context Protocol (MCP) Server for Graphlit Platform - graphlit/graphlit-mcp-server
Exa Search
Claude can perform Web Search | Exa with MCP (Model Context Protocol) - exa-labs/exa-mcp-server
Playwright MCP Server
Contribute to showfive/playwright-mcp-server development by creating an account on GitHub.
Apple MCP Server
Collection of apple-native tools for the model context protocol. - Dhravya/apple-mcp
@kazuph/mcp-fetch
Contribute to kazuph/mcp-fetch development by creating an account on GitHub.
Tavily MCP Server
An MCP server for Tavily's search API. Contribute to RamXX/mcp-tavily development by creating an account on GitHub.
MCP DuckDB Knowledge Graph Memory Server
MCP Memory Server with DuckDB backend. Contribute to IzumiSy/mcp-duckdb-memory-server development by creating an account on GitHub.