


Panduan ini menunjukkan penyepaduan Swagger 3 (OpenAPI) dengan Spring Cloud Gateway untuk dokumentasi API perkhidmatan mikro yang diperkemas. Kami akan memanfaatkan Java 21, Spring Boot 3.2 dan Micronaut untuk mencipta penyelesaian yang mantap dan mesra pengguna.
Mengapa Pilih Swagger/OpenAPI?
Swagger, kini Spesifikasi OpenAPI (OAS), ialah piawaian dokumentasi API terkemuka. Khasiatnya termasuklah:
- Standard Industri: Diguna pakai secara meluas dan disokong oleh ekosistem alatan yang kaya.
- Dokumentasi Interaktif: Menjana dokumentasi mesra pengguna yang membolehkan pembangun meneroka dan menguji API secara langsung.
- Produktiviti Pembangun yang Dipertingkat: Ciri seperti penjanaan kod untuk SDK dan stub pelayan mempercepatkan pembangunan API.
- Kolaborasi Dipertingkat: Memberikan pemahaman bersama tentang fungsi API untuk pembangun, penguji dan pihak berkepentingan.
- Pengujian dan Nyahpepijat Ringkas: UI Swagger termasuk antara muka ujian untuk mengesahkan respons API.
- Sokongan Merentas Bahasa: Bersepadu dengan lancar merentas susunan teknologi yang pelbagai.
- Penyepaduan Mudah: Penyepaduan mudah dengan rangka kerja popular seperti Spring Boot dan Micronaut.
- Mesra Automasi: Menyokong automasi untuk pengurusan kitaran hayat API.
- Sumber Terbuka dengan Pilihan Perusahaan: Tersedia sebagai alat sumber terbuka percuma dengan pilihan perusahaan.
Spring Cloud Gateway: The Foundation
Spring Cloud Gateway, dibina pada Spring Framework 5, Spring Boot 2 dan Project Reactor, bertindak sebagai titik masuk pusat untuk penghalaan dan penapisan permintaan kepada perkhidmatan mikro anda.
Bagaimana Spring Cloud Gateway Berfungsi:
Rajah di bawah menggambarkan operasi Spring Cloud Gateway:
Permintaan pelanggan dinilai berdasarkan laluan yang ditetapkan. Permintaan padanan diproses oleh Pengendali Web Gateway, melaksanakan penapisan pra dan pasca sebelum dan selepas meminta proksi.
Membina Aplikasi:
Prasyarat:
- Jawa 21
- Gradle (atau Maven)
- Spring Boot 3.2 atau lebih baru
- Pemahaman Spring Cloud Gateway dan Swagger
- Micronaut
Pelaksanaan Langkah demi Langkah:
Langkah 1: Buat Aplikasi Micronaut (Pekerjaan, Perk, Perkhidmatan Tag)
Gunakan Pelancar Micronaut ([pautan ke pelancar]) untuk mencipta tiga aplikasi Micronaut: job-service
, perk-service
dan tag-service
. Pilih Java atau Kotlin, versi Micronaut stabil terkini, Swagger UI dan OpenAPI sebagai ciri. Gunakan Gradle atau Maven sebagai alat binaan. Setiap perkhidmatan akan mempunyai UI Swagger yang boleh diakses (mis., http://localhost:8081/swagger-ui/index.html
untuk job-service
). Anda juga boleh menggunakan CLI:
mn create-app --build=gradle_kotlin --jdk=21 --lang=java --test=junit --features=openapi,swagger-ui dev.job.job
(Ulang untuk perk-service
dan tag-service
, laraskan nama pakej dengan sewajarnya).
Langkah 2: Buat Gerbang API Spring Boot
Gunakan Spring Initializr ([pautan ke Spring Initializr]) untuk menjana projek Spring Boot. Sertakan kebergantungan berikut: Spring Cloud Gateway, Spring Boot Actuator dan Spring Web.
Langkah 3: Sepadukan Swagger ke dalam Gerbang API
Tambahkan kebergantungan Springdoc yang diperlukan pada pom.xml
(Maven) atau build.gradle
(Gradle) anda:
dependencies { implementation("org.springframework.cloud:spring-cloud-starter-gateway") implementation("org.springdoc:springdoc-openapi-starter-webmvc-api:2.8.3") implementation("org.springdoc:springdoc-openapi-starter-webflux-ui:2.8.3") }
Konfigurasikan application.yml
untuk mendayakan UI Swagger dan nyatakan URL untuk setiap fail Swagger YAML perkhidmatan mikro:
springdoc: api-docs: enabled: true swagger-ui: enabled: true path: /swagger-ui.html config-url: /v3/api-docs/swagger-config urls: - name: Job Service url: http://localhost:8081/swagger/job-service-0.0.yml - name: Perk Service url: http://localhost:8082/swagger/perk-0.0.yml - name: Tag Service url: http://localhost:8083/swagger/tag-0.0.yml
Tetapkan port Gateway API kepada 8080 dalam application.yml
:
server: port: 8080 spring: application: name: web-api-gateway
Langkah 4: Jalankan Aplikasi
Mulakan setiap satu daripada empat aplikasi (tiga perkhidmatan Micronaut dan Spring Boot Gateway). UI Swagger Gateway boleh diakses di http://localhost:8080/webjars/swagger-ui/index.html
.
Kesimpulan:
Pendekatan gabungan ini menyediakan seni bina perkhidmatan mikro yang berkuasa dan didokumentasikan dengan baik. Spring Cloud Gateway dengan cekap mengarahkan permintaan, manakala Swagger menawarkan pengalaman dokumentasi API terpusat dan interaktif. Persediaan ini meningkatkan produktiviti dan kerjasama pembangun dengan ketara. Ingat untuk menggantikan URL pemegang tempat dengan URL sebenar fail Swagger YAML perkhidmatan mikro anda.
Atas ialah kandungan terperinci Agregat Microservices Swagger UI daripada API Gateway Menggunakan Spring API Gateway dan Micronaut. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)