aezizhu/simple-mcp-fileserver
If you are the rightful owner of simple-mcp-fileserver and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
A lightweight Model Context Protocol (MCP) file system server enabling AI agents to interact with your local file system through a standardized JSON-RPC interface.
Simple MCP FileServer
A lightweight Model Context Protocol (MCP) file system server that enables AI agents (like Codeium, Claude, Windsurf, etc.) to interact with your local file system through a standardized JSON-RPC interface.
What is MCP?
The Model Context Protocol (MCP) is a standardized way for AI agents to interact with external systems. This implementation provides file system operations, allowing AI assistants to read, write, and manipulate files on your local machine in a controlled and secure manner.
How It Works
This server implements a JSON-RPC 2.0 API that AI agents can call to perform file operations:
- Communication Protocol: Uses HTTP with JSON-RPC 2.0 format for requests and responses
- Method Dispatching: Routes requests to appropriate file system operations
- Error Handling: Provides standardized error responses with meaningful codes
- Capability Discovery: Supports the
initializemethod for capability reporting
The server acts as a bridge between AI agents and your file system, translating JSON-RPC requests into actual file operations and returning the results.
Features
- File Operations:
- Read file content (
readFilemethod) - Write or overwrite file content (
writeFilemethod) - List directory contents (
listDirmethod)
- Read file content (
- MCP Protocol Compatibility:
- Full JSON-RPC 2.0 protocol compliance
- Supports
initializemethod with capability reporting - Detailed error handling and logging
- CORS Support: Built-in cross-origin support for web client integration
- Health Check: Provides a
/healthendpoint for monitoring and probing - Multimodal Image Outputs:
readFilereturns image results that include bothimage_urland base64/data URL forms to be consumed by MCP clients as model inputs
Installation
-
Clone the repository:
git clone https://github.com/yourusername/simple-mcp-fileserver.git cd simple-mcp-fileserver -
Install dependencies:
npm install
Configuration
The server configuration is flexible and supports the following environment variables:
PORTorMCP_PORT: Specify the server listening port (default: 8090)ROOT_DIRorMCP_ROOT_DIR: Restrict accessible files to this directory (optional; when set, paths outside are denied)MAX_FILE_BYTESorMCP_MAX_FILE_BYTES: Maximum allowed file size forreadFile(default: 26214400 bytes, i.e., 25 MiB)
Usage
Method 1: Direct Launch
Start the server directly from the command line:
node simple-mcp-fileserver.js
With custom port:
PORT=9000 node simple-mcp-fileserver.js
Method 2: Configure in MCP Orchestrator
Add to .codeium/windsurf/mcp_config.json to integrate with Codeium/Windsurf:
{
"mcpServers": {
"filesystem": {
"command": "node",
"args": [
"/path/to/simple-mcp-fileserver/simple-mcp-fileserver.js"
],
"env": {
"PORT": "9000"
}
}
}
}
Method 3: Use Official MCP Filesystem Server
If you encounter compatibility issues, you can use the official MCP filesystem server:
{
"mcpServers": {
"filesystem": {
"command": "npx",
"args": [
"-y",
"@modelcontextprotocol/server-filesystem",
"/path/to/allowed/directory"
]
}
}
}
Integration with AI Assistants
Once your MCP server is running, AI assistants that support the MCP protocol can interact with your file system. The assistant will:
- Connect to your MCP server
- Initialize the connection to discover capabilities
- Make requests to read, write, or list files as needed
- Process the responses to provide you with relevant information
This enables powerful workflows where AI assistants can help you with coding tasks that require file system access.
API Reference
initialize
Initialize connection and get server capabilities.
Request:
{
"jsonrpc": "2.0",
"method": "initialize",
"params": {},
"id": 1
}
Response:
{
"jsonrpc": "2.0",
"result": {
"capabilities": {
"readFile": { "supported": true, "description": "Read a file from disk" },
"writeFile": { "supported": true, "description": "Write a file to disk" },
"listDir": { "supported": true, "description": "List directory contents" }
},
"serverName": "simple-mcp-fileserver",
"version": "1.0.0",
"mcp": "filesystem"
},
"id": 1
}
readFile
Read file content. Supports text, base64, and Data URL encodings. For images, returns additional multimodal-friendly fields so clients can route the content into model inputs (not just thumbnails).
Request (text):
{
"jsonrpc": "2.0",
"method": "readFile",
"params": { "path": "/path/to/file.txt" },
"id": 2
}
Response (text):
{
"jsonrpc": "2.0",
"result": "file content...",
"id": 2
}
Request (binary, base64):
{
"jsonrpc": "2.0",
"method": "readFile",
"params": { "path": "/path/to/image.png", "encoding": "base64" },
"id": 22
}
Response (binary, base64):
{
"jsonrpc": "2.0",
"result": {
"content": "iVBORw0KGgo...",
"encoding": "base64",
"mimeType": "image/png",
"byteLength": 12345,
"uri": "http://localhost:8090/file?path=/abs/path/to/image.png",
"contentParts": [
{ "type": "image_url", "url": "http://localhost:8090/file?path=/abs/path/to/image.png" },
{ "type": "image_base64", "data": "iVBORw0KGgo...", "mimeType": "image/png" },
{ "type": "image_data_url", "dataUrl": "..." }
]
},
"id": 22
}
Request (binary, Data URL):
{
"jsonrpc": "2.0",
"method": "readFile",
"params": { "path": "/path/to/image.png", "encoding": "dataurl" },
"id": 23
}
Response (binary, Data URL):
{
"jsonrpc": "2.0",
"result": {
"content": "...",
"encoding": "dataurl",
"mimeType": "image/png",
"byteLength": 12345,
"uri": "http://localhost:8090/file?path=/abs/path/to/image.png",
"contentParts": [
{ "type": "image_url", "url": "http://localhost:8090/file?path=/abs/path/to/image.png" },
{ "type": "image_base64", "data": "iVBORw0KGgo...", "mimeType": "image/png" },
{ "type": "image_data_url", "dataUrl": "..." }
]
},
"id": 23
}
writeFile
Write file content.
Request:
{
"jsonrpc": "2.0",
"method": "writeFile",
"params": {
"path": "/path/to/file.txt",
"content": "content to write"
},
"id": 3
}
Response:
{
"jsonrpc": "2.0",
"result": "ok",
"id": 3
}
listDir
List directory contents.
Request:
{
"jsonrpc": "2.0",
"method": "listDir",
"params": { "path": "/path/to/directory" },
"id": 4
}
Response:
{
"jsonrpc": "2.0",
"result": ["file1.txt", "file2.js", "subdirectory"],
"id": 4
}
Health Check
The server provides a simple health check endpoint:
curl http://localhost:8090/health
# Returns: ok
Serving Files Directly
For LLMs that support image_url or want to fetch files via HTTP, the server exposes a direct file endpoint:
curl "http://localhost:8090/file?path=/absolute/path/to/image.png" --output image.png
This sets the correct Content-Type based on the file extension.
Image vs. Text/Binary Behavior
- Text files: returns a UTF-8 string as before.
- Non-image binaries (e.g., zip, pdf): return
{ content, encoding: "base64", mimeType, byteLength }or data URL if requested. - Images (png/jpg/webp and others): include additional
uriandcontentPartsfields to enable multimodal routing in MCP clients while keeping backward compatibility.
Errors and Limits
- Missing file: JSON-RPC error with code
-32004. - File too large: error with code
-32010and limit metadata. - Invalid parameters or outside
ROOT_DIR: error with code-32602.
Troubleshooting
Common Issues
-
Initialization Failure:
- Ensure the server is running
- Check if the port is in use
- Verify the
/healthendpoint returnsok
-
Port Conflicts:
- Use
lsof -i :<port>to check port usage - Start the service with a different port
- Use
-
Permission Issues:
- Ensure the server has permission to access requested file paths
Manual verification
Below are example cURL snippets to exercise the image behavior. Replace paths and ports as needed.
- LM Studio (or any MCP client using HTTP JSON-RPC):
curl -s http://localhost:8090/mcp -H 'Content-Type: application/json' -d '{
"jsonrpc":"2.0",
"method":"readFile",
"params": { "path": "/absolute/path/to/cat.png" },
"id": 10
}' | jq '.'
Expected: result contains mimeType: "image/png", content (base64 or data URL), and contentParts with an image_url. LM Studio should feed the image_url or base64 to the model input when the tool output is wired into prompts.
- Claude Desktop / Node/Python reference runtimes:
Use the uri in contentParts[0].url as an image input argument, or pass the data URL directly where supported. For example, a follow-up tool or prompt can include:
{
"type": "image",
"source": { "type": "url", "url": "http://localhost:8090/file?path=/absolute/path/to/cat.png" }
}
Expected: The model consumes the image, not just displays a thumbnail.
Security Considerations
This server provides direct access to your file system. Consider these security measures:
- Run the server only on trusted networks
- Limit the directories that can be accessed
- Consider implementing authentication for production use
- Monitor server logs for suspicious activity
Potential Future Enhancements
This MCP server could be extended with additional features:
- Authentication & Authorization: Add user authentication and path-based permissions
- File Watching: Implement methods to watch files for changes
- Advanced File Operations: Add support for file copying, moving, and deletion
- Metadata Operations: Add methods to get and set file metadata
- Search Capabilities: Implement file content search functionality
- Streaming Support: Add streaming for large file operations
- Compression: Support for compressed file operations
- Versioning: Add simple file versioning capabilities
- Batched Operations: Support for executing multiple operations in a single request
- Event Notifications: Implement WebSocket support for file system event notifications
Contributing
Pull Requests and Issues are welcome! Some areas where contributions would be particularly valuable:
- Additional file operations
- Enhanced error handling
- Performance optimizations
- Security improvements
- Documentation enhancements
License
MIT