Swagger は、RESTful インターフェイスの生成、記述、呼び出しに使用される Web サービスです。平たく言えば、Swagger は、プロジェクト内の (公開したい) すべてのインターフェイスをページ上に表示し、インターフェイスの呼び出しとテストを可能にするサービスです。
Swagger には次の 3 つの重要な機能があります: プロジェクト内のすべてのインターフェイスをページ上に表示するため、バックエンド プログラマーはフロントエンド ユーザー用の特別なインターフェイス ドキュメントを作成する必要がなくなります。インターフェイスが更新されると、コード内の Swagger の記述を変更するだけで、新しいインターフェイス ドキュメントをリアルタイムで生成できるため、インターフェイス ドキュメントが古くて使用できないという問題が回避されます。Swagger ページを通じてインターフェイスを直接呼び出して、開発を容易にすることができます。
1)
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency>
に依存します2) コントローラー クラスを作成します
import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class TestController { @PostMapping("/hello") public String hello(String str){ return "hello,"+str; } }
3) Swagger 構成を作成しますclass SwaggerConfig class
@Configuration @EnableSwagger2//开始Swagger2 public class SwaggerConfig { //配置了Swagger 的Docket的bean实例 @Bean public Docket docket(){ ParameterBuilder ticketPar = new ParameterBuilder(); List<Parameter> pars = new ArrayList<>(); ticketPar.name("Authorization").description("token")//Token 以及Authorization 为自定义的参数,session保存的名字是哪个就可以写成那个 .modelRef(new ModelRef("string")).parameterType("header") .required(false).build(); //header中的ticket参数非必填,传空也可以 pars.add(ticketPar.build()); //根据每个方法名也知道当前方法在设置什么参数 return new Docket(DocumentationType.SPRING_WEB) .apiInfo(apiInfo()) .select() //RequestHandlerSelectors, 配置要扫描接口的方式 //basePackage:指定要扫描的包 //any():扫描全部 //withClassAnnotation: 扫描类上的注解 //withMethodAnnotation: 扫描方法上的注解 .apis(RequestHandlerSelectors.basePackage("com.example.swagger.controller")) .build() .globalOperationParameters(pars); } //配置Swagger 信息=apiInfo private ApiInfo apiInfo(){ return new ApiInfo( "Logistics Api",//文檔命名 "test",//文檔描述 "v1.0",// "http:127.0.0.1/", null,//contact "Apache 2.0", "http://www.apache.org/licenses/LICENSE-2.0", new ArrayList() ); } }
注意! ######知らせ! ######知らせ!
apis(RequestHandlerSelectors.basePackage("com.example.swagger.controller")) に
"com.example.swagger.controller" パスを独自のコントローラー パッケージのパスとして記述します。
4. プロジェクトの全体構造
#5. URL から Web ページにアクセスします上記の手順を完了したら、 [実行] をクリックして操作が完了するまで待ち、ブラウザで次の URL にアクセスします:
ポートここを独自のポートに変更する必要があります。
効果は写真の通りです
##以上がSpringboot プロジェクトで Swagger を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。