日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

swagger core 和 swagger ui 如何关联【窥探】

發(fā)布時間:2023/12/20 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 swagger core 和 swagger ui 如何关联【窥探】 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

幾個片段:

?

package io.swagger.jaxrs.listing;import io.swagger.annotations.ApiOperation; import org.apache.commons.lang3.StringUtils;import javax.servlet.ServletConfig; import javax.servlet.ServletContext; import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.PathParam; import javax.ws.rs.Produces; import javax.ws.rs.core.*;@Path("/swagger.{type:json|yaml}") public class ApiListingResource extends BaseApiListingResource {@ContextServletContext context;@GET@Produces({MediaType.APPLICATION_JSON, "application/yaml"})@ApiOperation(value = "The swagger definition in either JSON or YAML", hidden = true)public Response getListing(@Context Application app,@Context ServletConfig sc,@Context HttpHeaders headers,@Context UriInfo uriInfo,@PathParam("type") String type) {if (StringUtils.isNotBlank(type) && type.trim().equalsIgnoreCase("yaml")) {return getListingYamlResponse(app, context, sc, headers, uriInfo);} else {return getListingJsonResponse(app, context, sc, headers, uriInfo);}}}

package io.swagger.jaxrs.listing;import io.swagger.models.Swagger; import io.swagger.util.Json; import io.swagger.util.Yaml; import org.slf4j.Logger; import org.slf4j.LoggerFactory;import javax.ws.rs.Produces; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MultivaluedMap; import javax.ws.rs.ext.MessageBodyWriter; import javax.ws.rs.ext.Provider; import java.io.IOException; import java.io.OutputStream; import java.lang.annotation.Annotation; import java.lang.reflect.Type;@Provider @Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML, "application/yaml"}) public class SwaggerSerializers implements MessageBodyWriter<Swagger> {static boolean prettyPrint = false;Logger LOGGER = LoggerFactory.getLogger(SwaggerSerializers.class);public static void setPrettyPrint(boolean shouldPrettyPrint) {SwaggerSerializers.prettyPrint = shouldPrettyPrint;}@Overridepublic boolean isWriteable(Class type, Type genericType, Annotation[] annotations,MediaType mediaType) {return Swagger.class.isAssignableFrom(type);}@Overridepublic long getSize(Swagger data, Class type, Type genericType, Annotation[] annotations, MediaType mediaType) {return -1;}@Overridepublic void writeTo(Swagger data,Class<?> type,Type genericType,Annotation[] annotations,MediaType mediaType,MultivaluedMap<String, Object> headers,OutputStream out) throws IOException {if (mediaType.isCompatible(MediaType.APPLICATION_JSON_TYPE)) {if (prettyPrint) {out.write(Json.pretty().writeValueAsString(data).getBytes("utf-8"));} else {out.write(Json.mapper().writeValueAsString(data).getBytes("utf-8"));}} else if (mediaType.toString().startsWith("application/yaml")) {headers.remove("Content-Type");headers.add("Content-Type", "application/yaml");out.write(Yaml.mapper().writeValueAsString(data).getBytes("utf-8"));} else if (mediaType.isCompatible(MediaType.APPLICATION_XML_TYPE)) {headers.remove("Content-Type");headers.add("Content-Type", "application/json");out.write(Json.mapper().writeValueAsString(data).getBytes("utf-8"));}} }

?

<!-- this scans the classes for resources --><bean id="swaggerConfig" class="io.swagger.jaxrs.config.BeanConfig"><property name="resourcePackage" value="io.swagger.sample.resource"/><property name="version" value="1.0.0"/><property name="host" value="localhost:8080/swagger-java-cxf-sample"/><property name="basePath" value="/api"/><property name="title" value="Swagger Petstore"/><property name="description" value="This is a app."/><property name="contact" value="apiteam@swagger.io"/><property name="license" value="Apache 2.0"/><property name="licenseUrl" value="http://www.apache.org/licenses/LICENSE-2.0.html"/><!-- <property name="filterClass" value="ApiAuthorizationFilterImpl"/> --><property name="scan" value="true"/></bean>

?

basePath 是定位到項目的前提下,訪問誰

var url = window.location.search.match(/url=([^&]+)/);if (url && url.length > 1) {url = decodeURIComponent(url[1]);} else {url = "http://localhost:8080/swagger-java-cxf-sample/api/swagger.json";}

訪問誰,訪問哪個路徑

!IMPORTANT

這個是基于jax-rs 項目整合的

轉(zhuǎn)載于:https://www.cnblogs.com/zno2/p/5550468.html

總結(jié)

以上是生活随笔為你收集整理的swagger core 和 swagger ui 如何关联【窥探】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。