DNS Rebinding Protection Disabled by Default in Model Context Protocol Go SDK for Servers Running on Localhost
High severity
GitHub Reviewed
Published
Mar 30, 2026
in
modelcontextprotocol/go-sdk
•
Updated Apr 1, 2026
Package
Affected versions
< 1.4.0
Patched versions
1.4.0
Description
Published to the GitHub Advisory Database
Apr 1, 2026
Reviewed
Apr 1, 2026
Last updated
Apr 1, 2026
The Model Context Protocol (MCP) Go SDK does not enable DNS rebinding protection by default for HTTP-based servers. When an HTTP-based MCP server is run on localhost without authentication with
StreamableHTTPHandlerorSSEHandler, a malicious website could exploit DNS rebinding to bypass same-origin policy restrictions and send requests to the local MCP server. This could allow an attacker to invoke tools or access resources exposed by the MCP server on behalf of the user in those limited circumstances.Note that running HTTP-based MCP servers locally without authentication is not recommended per MCP security best practices. This issue does not affect servers using stdio transport.
Servers created via
StreamableHTTPHandlerorSSEHandlernow have this protection enabled by default when binding tolocalhost. Users are advised to update to version1.4.0to receive this automatic protection.References