cari
RumahJavajavaTutorialPerkhidmatan Web SpringBoot - Bahagian Konfigurasi Awal

SpringBoot Web Service - Part  Initial Configuration

Dalam siaran ini, kami akan meneroka cara mengkonfigurasi OpenAPI dalam aplikasi Spring Boot anda dan menambah ubah hala yang mudah daripada URL akar ke UI Swagger. Persediaan ini akan menambah baik dokumentasi API anda dan menjadikannya lebih mudah diakses oleh pembangun.

Konfigurasi Kacang OpenAPI

Pertama, mari buat kelas konfigurasi untuk menyesuaikan dokumentasi OpenAPI kami:

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springframework.boot.info.GitProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class OpenAPIConfig {

    @Bean
    public OpenAPI customOpenAPI(GitProperties gitProperties) {
        return new OpenAPI()
                .info(new Info()
                        .title("Book Catalog API")
                        .description("REST API for managing a book catalog. Application version: "+ gitProperties.get("build.version"))
                        .version("1.0.0")
                        .contact(new Contact()
                                .name("Book Catalog Team")
                                .email("support@bookcatalog.com")
                                .url("https://github.com/vlaship/book-catalog"))
                        .license(new License()
                                .name("MIT License")
                                .url("https://opensource.org/licenses/MIT"))
                );
    }
}

Konfigurasi ini mencipta kacang OpenAPI tersuai dengan maklumat asas tentang API anda. Anda boleh menyesuaikannya lagi dengan menambahkan lebih banyak butiran, seperti maklumat hubungan, lesen atau dokumentasi luaran.
Kami boleh menggunakan GitProperties untuk memberikan butiran lanjut.

Pengawal Ubah Arah URL Root

Seterusnya, mari buat pengawal untuk mengubah hala pengguna daripada URL akar ke UI Swagger:

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class OpenApiController {
    @GetMapping("/")
    public String index() {
        return "redirect:swagger-ui.html";
    }
}

Pengawal mudah ini menggunakan @GetMapping untuk URL akar ("/") dan mengubah hala ke halaman HTML UI Swagger.

Mengemas kini aplikasi.yaml

Fail konfigurasi ini, sering dinamakan application.yml, memainkan peranan penting dalam menentukan pelbagai aspek gelagat aplikasi anda.

spring:
  application:
    name: book-catalog
    version: '@project.version@'
  mvc:
    problemdetails:
      enabled: true

management:
  endpoints:
    web:
      exposure:
        include: '*'
  info:
    git:
      mode: full

server:
  port: 8888
  servlet:
    context-path: /${spring.application.name}
  error:
    whitelabel:
      enabled: false

Konfigurasi YAML yang disediakan meliputi beberapa bahagian utama aplikasi Spring Boot anda:

  1. Sifat Aplikasi:

nama: Mentakrifkan nama aplikasi, di sini ditetapkan kepada katalog buku.

versi: Merujuk pemegang tempat, mungkin diisi semasa proses binaan, untuk menentukan versi aplikasi.

  1. Konfigurasi MVC:

problemdetails.enabled: Mendayakan laporan masalah terperinci dalam badan respons untuk pengecualian.

  1. Titik Akhir Pengurusan:

endpoints.web.exposure.include: '*':** Mendedahkan semua titik akhir penggerak untuk tujuan pemantauan dan pengurusan.

info.git.mode: penuh: Menyediakan maklumat Git terperinci dalam titik akhir /info.

  1. Konfigurasi Pelayan:

port: Menetapkan port di mana pelayan mendengar permintaan masuk (lalai 8080, di sini ditetapkan kepada 8888).

servlet.context-path: Mentakrifkan laluan konteks untuk aplikasi, memastikan permintaan dihalakan dengan betul.

error.whitelabel.enabled: false: Melumpuhkan halaman ralat label putih lalai, membenarkan mesej ralat yang lebih bermaklumat semasa pembangunan.

Menambah banner.txt

1. Cipta fail banner.txt

Buat fail baharu bernama banner.txt dalam direktori src/main/resources projek Spring Boot anda.

2. Tambahkan butiran perkhidmatan pada banner.txt

Anda boleh menambah sebarang teks atau seni ASCII pada fail ini. Berikut ialah contoh:

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Contact;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springframework.boot.info.GitProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class OpenAPIConfig {

    @Bean
    public OpenAPI customOpenAPI(GitProperties gitProperties) {
        return new OpenAPI()
                .info(new Info()
                        .title("Book Catalog API")
                        .description("REST API for managing a book catalog. Application version: "+ gitProperties.get("build.version"))
                        .version("1.0.0")
                        .contact(new Contact()
                                .name("Book Catalog Team")
                                .email("support@bookcatalog.com")
                                .url("https://github.com/vlaship/book-catalog"))
                        .license(new License()
                                .name("MIT License")
                                .url("https://opensource.org/licenses/MIT"))
                );
    }
}

Pendekatan ini menambah sentuhan profesional pada permulaan aplikasi anda dan memberikan maklumat berharga sepintas lalu.

Menambah Dockerfile

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

@Controller
public class OpenApiController {
    @GetMapping("/")
    public String index() {
        return "redirect:swagger-ui.html";
    }
}

Pengeluaran Lapisan: Mencipta lapisan berasingan untuk kebergantungan, meningkatkan kecekapan binaan dan mengurangkan kemas kini saiz imej.
Binaan Berbilang peringkat: Menggunakan proses binaan berbilang peringkat untuk memisahkan persekitaran binaan daripada persekitaran masa jalan, menghasilkan imej akhir yang lebih kecil dan cekap.
Imej Asas Ringan: Menggunakan imej asas minimum seperti azul/zulu-openjdk-alpine:21-jre-tanpa kepala untuk mengurangkan lagi saiz imej.

Pendekatan ini membawa kepada binaan yang lebih pantas, saiz imej yang lebih kecil dan prestasi keseluruhan yang lebih baik untuk aplikasi Spring Boot anda dalam bekas Docker.

Atas ialah kandungan terperinci Perkhidmatan Web SpringBoot - Bahagian Konfigurasi Awal. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Bagaimanakah pengkomputeran awan mempengaruhi kepentingan kemerdekaan platform Java?Bagaimanakah pengkomputeran awan mempengaruhi kepentingan kemerdekaan platform Java?Apr 22, 2025 pm 07:05 PM

Pengkomputeran awan dengan ketara meningkatkan kemerdekaan platform Java. 1) Kod Java dikumpulkan ke dalam bytecode dan dilaksanakan oleh JVM pada sistem operasi yang berbeza untuk memastikan operasi silang platform. 2) Gunakan Docker dan Kubernet untuk menggunakan aplikasi Java untuk meningkatkan kebolehgunaan dan skalabiliti.

Apakah peranan yang dimainkan oleh kemerdekaan platform Java dalam penggunaannya yang meluas?Apakah peranan yang dimainkan oleh kemerdekaan platform Java dalam penggunaannya yang meluas?Apr 22, 2025 pm 06:53 PM

Java'splatformindependenceallowsdeveloperstowritecodeonceandrunitonanydeviceorOSwithaJVM.Thisisachievedthroughcompilingtobytecode,whichtheJVMinterpretsorcompilesatruntime.ThisfeaturehassignificantlyboostedJava'sadoptionduetocross-platformdeployment,s

Bagaimanakah teknologi kontena (seperti Docker) mempengaruhi kepentingan kemerdekaan platform Java?Bagaimanakah teknologi kontena (seperti Docker) mempengaruhi kepentingan kemerdekaan platform Java?Apr 22, 2025 pm 06:49 PM

Teknologi kontena seperti Docker meningkatkan daripada menggantikan kemerdekaan platform Java. 1) Memastikan konsistensi di seluruh persekitaran, 2) Menguruskan kebergantungan, termasuk versi JVM tertentu, 3) memudahkan proses penempatan untuk menjadikan aplikasi Java lebih mudah disesuaikan dan boleh diurus.

Apakah komponen utama Java Runtime Environment (JRE)?Apakah komponen utama Java Runtime Environment (JRE)?Apr 22, 2025 pm 06:33 PM

JRE adalah persekitaran di mana aplikasi Java dijalankan, dan fungsinya adalah untuk membolehkan program Java dijalankan pada sistem operasi yang berbeza tanpa mengulang semula. Prinsip kerja JRE termasuk JVM yang melaksanakan bytecode, perpustakaan kelas menyediakan kelas dan kaedah yang telah ditetapkan, fail konfigurasi dan fail sumber untuk menubuhkan persekitaran yang sedang berjalan.

Terangkan bagaimana JVM mengendalikan pengurusan memori, tanpa mengira sistem operasi yang mendasari.Terangkan bagaimana JVM mengendalikan pengurusan memori, tanpa mengira sistem operasi yang mendasari.Apr 22, 2025 pm 05:45 PM

JVM memastikan program Java yang cekap dijalankan melalui pengurusan memori automatik dan koleksi sampah. 1) Peruntukan Memori: Peruntukkan memori dalam timbunan untuk objek baru. 2) Kiraan Rujukan: Rujukan objek trek dan mengesan sampah. 3) Kitar Semula Sampah: Gunakan algoritma tag-jelas, tag-tidy atau salinan untuk mengitar semula objek yang tidak lagi dirujuk.

Bagaimanakah Idea IntelliJ mengenal pasti nombor port projek boot musim bunga tanpa mengeluarkan log?Bagaimanakah Idea IntelliJ mengenal pasti nombor port projek boot musim bunga tanpa mengeluarkan log?Apr 19, 2025 pm 11:45 PM

Mula musim bunga menggunakan versi IntelliJideaultimate ...

Bagaimana dengan elegan mendapatkan nama pemboleh ubah kelas entiti untuk membina keadaan pertanyaan pangkalan data?Bagaimana dengan elegan mendapatkan nama pemboleh ubah kelas entiti untuk membina keadaan pertanyaan pangkalan data?Apr 19, 2025 pm 11:42 PM

Apabila menggunakan Mybatis-Plus atau Rangka Kerja ORM yang lain untuk operasi pangkalan data, sering diperlukan untuk membina syarat pertanyaan berdasarkan nama atribut kelas entiti. Sekiranya anda secara manual setiap kali ...

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual