Secara default, siapa pun yang menjalankan Claude Code dapat menghubungkan server MCP apa pun yang mereka pilih. Anthropic meninjau konektor terhadap kriteria pendaftarannya sebelum menambahkannya ke Direktori Anthropic, tetapi tidak melakukan audit keamanan atau mengelola server MCP apa pun. Sebagai administrator, Anda dapat membatasi server mana yang berjalan di organisasi Anda, mulai dari menerapkan set yang disetujui tetap hingga menonaktifkan MCP sepenuhnya. Halaman ini mencakup cara untuk:Documentation Index
Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
- Memilih pola yang sesuai dengan tingkat kontrol yang Anda butuhkan
- Menerapkan set server tetap dengan
managed-mcp.json, termasuk cara menonaktifkan MCP sepenuhnya - Mengontrol server dengan daftar izin dan daftar penolakan
- Memberitahu pengguna apa yang diharapkan ketika pembatasan memblokir server
- Memantau server mana yang benar-benar digunakan organisasi Anda
Halaman Security mencakup model ancaman MCP dan cara mengevaluasi server sebelum menyetujuinya. Tentukan apa yang akan diterapkan mencakup pembatasan MCP bersama dengan kontrol administratif lainnya.
Pilih pola
Claude Code mendukung berbagai tingkat pembatasan. Setiap pola menggunakan satu atau kedua mekanisme yang dibahas di bawah:managed-mcp.json untuk menerapkan set tetap, dan allowedMcpServers/deniedMcpServers untuk memfilter apa yang dikonfigurasi pengguna.
| Pola | Apa yang dilakukan | Konfigurasi |
|---|---|---|
| Nonaktifkan MCP | Tidak ada server yang dimuat di mana pun | managed-mcp.json dengan peta server kosong |
| Penerapan tetap | Setiap pengguna mendapatkan server yang sama dan tidak dapat menambah yang lain | managed-mcp.json dengan server yang Anda inginkan |
| Katalog yang disetujui | Publikasikan daftar server yang disetujui; pengguna menambahkan yang mereka inginkan, yang lain diblokir | allowedMcpServers + allowManagedMcpServersOnly: true |
| Server plugin saja | Server hanya dapat berasal dari plugin; pengguna tidak dapat menambah milik mereka sendiri | strictPluginOnlyCustomization dengan mcp dalam daftar |
| Daftar izin lunak | Terapkan daftar izin yang dapat diperluas pengguna dalam pengaturan mereka sendiri | allowedMcpServers tanpa allowManagedMcpServersOnly |
| Hanya daftar penolakan | Blokir server yang diketahui buruk, izinkan yang lain | deniedMcpServers |
| Tanpa pembatasan | Pengguna menambahkan apa pun | Jangan terapkan konfigurasi MCP yang dikelola |
Claude Code tidak memiliki registri server MCP bawaan yang dapat ditelusuri dan diinstal pengguna. Untuk pola katalog yang disetujui, bagikan daftar yang disetujui dan perintah
claude mcp add di tempat yang akan ditemukan pengguna Anda, seperti wiki internal, atau distribusikan server sebagai plugin melalui marketplace plugin yang dikelola sehingga pengguna dapat menelusuri dan menginstalnya dari /plugin.Kontrol eksklusif dengan managed-mcp.json
Jika Anda menerapkan filemanaged-mcp.json, Claude Code hanya memuat server yang didefinisikan file tersebut. Pengguna tidak dapat menambah, memodifikasi, atau menggunakan server MCP lain apa pun, termasuk server yang disediakan plugin dan konektor claude.ai.
Dua pengaturan lainnya dapat memfilter set yang dikelola lebih lanjut:
allowedMcpServersdandeniedMcpServersjuga berlaku untuk server yang dikelola, jadi server yang dikelola yang tidak melewati mereka tidak akan dimuat.deniedMcpServerspengguna sendiri digabungkan dari pengaturan mereka, jadi pengguna dapat memblokir server yang dikelola untuk diri mereka sendiri.
managed-mcp.json adalah file mandiri, jadi tidak dapat dikirimkan melalui pengaturan yang dikelola server. Proses apa pun yang dapat menulis ke jalur sistem dengan hak istimewa administrator dapat menerapkannya. Dalam skala besar, itu biasanya melalui alat manajemen perangkat, seperti Jamf atau profil konfigurasi di macOS, Group Policy atau Intune di Windows, atau manajemen armada pilihan Anda di Linux. Claude Code mencari file di salah satu jalur berikut:
| Platform | Jalur |
|---|---|
| macOS | /Library/Application Support/ClaudeCode/managed-mcp.json |
| Linux dan WSL | /etc/claude-code/managed-mcp.json |
| Windows | C:\Program Files\ClaudeCode\managed-mcp.json |
.mcp.json:
Autentikasi dengan kredensial per pengguna
Pengguna apa pun di mesin dapat membaca file ini, jadi jangan simpan kunci API atau kredensial lain dalam blokenv. Teruskan kredensial per pengguna dengan salah satu dari ini:
- Ekspansi
${VAR}untuk membaca rahasia dari lingkungan setiap pengguna. - OAuth atau header per pengguna sehingga setiap pengguna mengautentikasi sebagai diri mereka sendiri.
headersHelperuntuk menghasilkan kredensial pada waktu koneksi.
Validasi konfigurasi
Untuk mengonfirmasi file berlaku, jalankan dua pemeriksaan pada mesin yang dikelola:claude mcp listmenampilkan hanya server dimanaged-mcp.json. Jika server pengguna sendiri masih muncul, file tidak dibaca; periksa jalur dan izin.claude mcp add --transport http test https://example.com/mcpgagal denganCannot add MCP server: enterprise MCP configuration is active and has exclusive control over MCP servers. URL tidak perlu menjadi server nyata, karena pemeriksaan kebijakan menolak perintah sebelum apa pun dihubungi.
Nonaktifkan MCP sepenuhnya
Terapkanmanaged-mcp.json yang berisi peta server kosong untuk memblokir setiap server MCP:
/mcp, dan claude mcp add gagal dengan kesalahan kebijakan perusahaan di atas. Server yang dikonfigurasi pengguna sebelumnya berhenti dimuat saat mereka memulai sesi berikutnya, tanpa peringatan bahwa kebijakan adalah alasannya.
Kontrol berbasis kebijakan dengan daftar izin dan daftar penolakan
Daftar izin dan daftar penolakan memfilter server mana yang dikonfigurasi yang diizinkan untuk dimuat. Mereka bukan registri: server masih harus ditambahkan oleh pengguna, plugin, ataumanaged-mcp.json sebelum daftar izin atau daftar penolakan berlaku padanya. Untuk menerapkan server kepada pengguna, gunakan managed-mcp.json.
Untuk membuat daftar izin berwenang, atur allowedMcpServers dan allowManagedMcpServersOnly: true bersama-sama dalam sumber pengaturan yang dikelola, seperti pengaturan yang dikelola server atau file managed-settings.json yang diterapkan. Batasi daftar izin ke pengaturan yang dikelola saja menunjukkan konfigurasi. Tanpa allowManagedMcpServersOnly, daftar izin dari setiap sumber pengaturan digabungkan, termasuk ~/.claude/settings.json pengguna sendiri, jadi pengguna dapat memperluas apa yang diizinkan daftar izin Anda. Daftar penolakan digabungkan dari setiap sumber terlepas dari itu.
allowManagedMcpServersOnly terpisah dari allowManagedPermissionRulesOnly, yang mengunci aturan izin saja. Menetapkan bendera itu tidak menerapkan daftar izin MCP.Cocokkan server berdasarkan URL, perintah, atau nama
allowedMcpServers dan deniedMcpServers adalah daftar entri. Setiap entri adalah objek dengan satu kunci yang mengidentifikasi server berdasarkan URL, perintah, atau nama mereka:
| Kunci | Cocok | Gunakan untuk |
|---|---|---|
serverUrl | URL server jarak jauh, tepat atau dengan wildcard * | Server HTTP dan SSE |
serverCommand | Perintah dan argumen yang tepat yang memulai server stdio | Server stdio |
serverName | Label yang ditetapkan pengguna. Kecocokan tepat saja; wildcard tidak diperluas | Tipe apa pun, tetapi lihat Peringatan di bawah |
allowedMcpServers tidak diatur berbeda dari menetapkannya ke array kosong:
| Pengaturan | Tidak diatur (default) | Array kosong [] | Diisi |
|---|---|---|---|
allowedMcpServers | Semua server diizinkan | Tidak ada server yang diizinkan | Hanya server yang cocok diizinkan |
deniedMcpServers | Tidak ada server yang diblokir | Tidak ada server yang diblokir | Server yang cocok diblokir |
Bagaimana server dievaluasi
Sebelum memuat server, termasuk yang darimanaged-mcp.json, Claude Code menjalankan tiga pemeriksaan secara berurutan:
- Gabungkan daftarnya. Entri daftar izin dan daftar penolakan dari setiap sumber pengaturan digabungkan menjadi satu daftar izin dan satu daftar penolakan. Ketika
allowManagedMcpServersOnlyadalahtrue, hanya daftar izin yang dikelola yang disimpan; daftar penolakan selalu digabungkan dari setiap sumber. - Periksa daftar penolakan. Server yang cocok dengan entri daftar penolakan apa pun, berdasarkan URL, perintah, atau nama, diblokir. Tidak ada yang mengganti kecocokan daftar penolakan.
- Periksa daftar izin. Jika
allowedMcpServerstidak diatur di mana pun, setiap server yang melewati daftar penolakan dimuat. Jika diatur, apa yang harus cocok dengan server tergantung pada jenisnya, ditunjukkan dalam tabel di bawah.
| Jenis server | Diizinkan ketika cocok |
|---|---|
| Jarak jauh (HTTP atau SSE) | Entri serverUrl. Kecocokan serverName hanya dihitung ketika daftar izin tidak berisi entri serverUrl |
| Stdio | Entri serverCommand. Kecocokan serverName hanya dihitung ketika daftar izin tidak berisi entri serverCommand |
- Perintah cocok dengan tepat. Setiap argumen, dalam urutan.
["npx", "-y", "server"]tidak cocok dengan["npx", "server"]atau["npx", "-y", "server", "--flag"]. - URL mendukung wildcard
*di mana pun dalam pola, termasuk skema. Pencocokan nama host tidak peka huruf besar-kecil dan mengabaikan titik FQDN yang tertinggal, jadihttps://Mcp.Example.com/*cocok denganhttps://mcp.example.com/api. Jalur tetap peka huruf besar-kecil.
| Pola | Mengizinkan |
|---|---|
https://mcp.example.com/* | Semua jalur di domain tertentu |
https://mcp.example.com | Juga semua jalur di domain itu. Pola tanpa jalur cocok dengan jalur apa pun |
https://*.example.com/* | Subdomain apa pun dari example.com |
http://localhost:*/* | Port apa pun di localhost |
*://mcp.example.com/* | Skema apa pun ke domain tertentu |
Contoh konfigurasi
Konfigurasi di bawah menyiapkan daftar izin keras dengan daftar penolakan. Baris yang disorot mengubah cara sisa daftar dievaluasi, dan callout setelah blok menjelaskan masing-masing:- Baris 3: entri
serverUrlpertama. Setelah satu ada, setiap server jarak jauh harus cocok dengan pola URL, jadi pengguna tidak dapat mendapatkan server jarak jauh yang tidak terdaftar dengan memberikannya nama yang diizinkan. - Baris 5: entri
serverCommandpertama. Efek yang sama untuk server stdio, jadi setiap server lokal harus cocok dengan perintah yang terdaftar dengan tepat. - Baris 11: entri
serverNamedalam daftar penolakan. Entri daftar penolakan selalu berlaku, jadi server apa pun yang bernamadangerous-serverdiblokir terlepas dari URL atau perintahnya.
serverName dalam daftar izin ini tidak akan pernah cocok dengan apa pun, karena kedua jenis transportasi sudah memiliki entri yang lebih ketat.
Accordion di bawah menjelaskan cara server dievaluasi terhadap kombinasi daftar izin dan daftar penolakan lainnya.
Daftar izin hanya URL
Daftar izin hanya URL
| Server | Hasil |
|---|---|
Server HTTP di https://mcp.example.com/api | Diizinkan: cocok dengan pola URL |
Server HTTP di https://api.internal.example.com/mcp | Diizinkan: cocok dengan subdomain wildcard |
Server HTTP di https://external.example.com/mcp | Diblokir: tidak cocok dengan pola URL apa pun |
| Server stdio dengan perintah apa pun | Diblokir: tidak ada entri nama atau perintah untuk cocok |
Daftar izin hanya perintah
Daftar izin hanya perintah
| Server | Hasil |
|---|---|
Server stdio dengan ["npx", "-y", "approved-package"] | Diizinkan: cocok dengan perintah |
Server stdio dengan ["node", "server.js"] | Diblokir: tidak cocok dengan perintah |
Server HTTP bernama my-api | Diblokir: tidak ada entri nama untuk cocok |
Daftar izin nama dan perintah campuran
Daftar izin nama dan perintah campuran
| Server | Hasil |
|---|---|
Server stdio bernama local-tool dengan ["npx", "-y", "approved-package"] | Diizinkan: cocok dengan perintah |
Server stdio bernama local-tool dengan ["node", "server.js"] | Diblokir: entri perintah ada tetapi tidak cocok |
Server stdio bernama github dengan ["node", "server.js"] | Diblokir: server stdio harus cocok dengan perintah ketika entri perintah ada |
Server HTTP bernama github | Diizinkan: cocok dengan nama |
Server HTTP bernama other-api | Diblokir: nama tidak cocok |
Daftar izin hanya nama
Daftar izin hanya nama
| Server | Hasil |
|---|---|
Server stdio bernama github dengan perintah apa pun | Diizinkan: tidak ada pembatasan perintah |
Server stdio bernama internal-tool dengan perintah apa pun | Diizinkan: tidak ada pembatasan perintah |
Server HTTP bernama github | Diizinkan: cocok dengan nama |
Server apa pun bernama other | Diblokir: nama tidak cocok |
Daftar izin dengan penggantian daftar penolakan
Daftar izin dengan penggantian daftar penolakan
| Server | Hasil |
|---|---|
Server HTTP di https://mcp.example.com/api | Diizinkan: cocok dengan pola URL daftar izin, tidak ada kecocokan daftar penolakan |
Server HTTP di https://staging.example.com/api | Diblokir: cocok dengan keduanya, tetapi daftar penolakan memiliki prioritas |
Server HTTP di https://other.com/mcp | Diblokir: tidak cocok dengan daftar izin |
Batasi daftar izin ke pengaturan yang dikelola saja
Untuk membuat daftar izin yang dikelola satu-satunya yang berlaku, aturallowManagedMcpServersOnly dalam file pengaturan yang dikelola:
allowManagedMcpServersOnly adalah true, daftar izin dari pengaturan pengguna, proyek, dan lokal diabaikan. Daftar penolakan masih digabungkan dari semua sumber, jadi pengguna selalu dapat memblokir server untuk diri mereka sendiri.
Bagaimana pembatasan muncul kepada pengguna
Ketika pembatasan memblokir server, pengguna melihat kesalahan dariclaude mcp add atau server berhenti dimuat secara diam-diam. Gunakan tabel ini untuk mengenali laporan tersebut dan untuk memberitahu pengguna apa yang diharapkan sebelum Anda meluncurkan perubahan:
| Pembatasan | Apa yang dilihat pengguna |
|---|---|
managed-mcp.json ada dan pengguna menjalankan claude mcp add | Cannot add MCP server: enterprise MCP configuration is active and has exclusive control over MCP servers |
Server ada di daftar penolakan dan pengguna menjalankan claude mcp add | Cannot add MCP server "<name>": server is explicitly blocked by enterprise policy |
Server tidak ada di daftar izin dan pengguna menjalankan claude mcp add | Cannot add MCP server "<name>": not allowed by enterprise policy |
| Server yang dikonfigurasi sebelumnya sekarang diblokir oleh kebijakan | Server menghilang secara diam-diam dari /mcp dan claude mcp list tanpa peringatan |
Pantau penggunaan MCP
Ketika ekspor OpenTelemetry dikonfigurasi, Claude Code dapat merekam server MCP dan alat mana yang digunakan pengguna. AturOTEL_LOG_TOOL_DETAILS=1 untuk menyertakan nama server dan alat MCP dalam acara alat, kemudian agregasikan di kolektor Anda untuk melihat server mana yang benar-benar dihubungkan pengguna Anda. Lihat Monitoring untuk menyiapkan pengekspor dan untuk skema acara lengkap.
Ringkasan konfigurasi
Setiap file dan pengaturan yang dibahas halaman ini, apa yang dikontrolnya, dan cara mengirimkannya:| Permukaan | Apa yang dikontrol | Di mana itu berada | Cara mengirimkan |
|---|---|---|---|
managed-mcp.json | Set server tetap, kontrol eksklusif | Jalur sistem: /Library/Application Support/ClaudeCode/, /etc/claude-code/, atau C:\Program Files\ClaudeCode\ | MDM, GPO, manajemen armada, atau proses apa pun dengan hak istimewa administrator. Tidak dapat diatur melalui pengaturan yang dikelola server |
allowedMcpServers | Daftar izin server yang diizinkan | File pengaturan apa pun; entri dari setiap sumber digabungkan kecuali allowManagedMcpServersOnly diatur | Untuk penegakan, sumber pengaturan yang dikelola: pengaturan yang dikelola server, managed-settings.json, profil MDM, atau registri |
deniedMcpServers | Daftar penolakan server yang diblokir | File pengaturan apa pun; entri dari setiap sumber digabungkan | Sama seperti allowedMcpServers |
allowManagedMcpServersOnly | Mengunci daftar izin ke sumber yang dikelola saja | Hanya sumber pengaturan yang dikelola; pengaturan tidak berpengaruh di tempat lain | Sama seperti allowedMcpServers |
Sumber daya terkait
- Tentukan apa yang akan diterapkan: pembatasan MCP bersama dengan aturan izin, sandboxing, dan kontrol admin lainnya
- Hubungkan Claude Code ke alat melalui MCP: referensi MCP lengkap, termasuk transportasi, cakupan, dan autentikasi
- Pengaturan: hierarki pengaturan dan bagaimana pengaturan yang dikelola memiliki prioritas
- Pengaturan yang dikelola server: kirimkan
allowedMcpServersdandeniedMcpServersdari konsol admin Claude.ai - Keamanan: model ancaman yang dilindungi kontrol ini
- Panduan Administrator Perusahaan Claude: SSO, SCIM, manajemen kursi, dan playbook peluncuran