解决方案就是获取到swagger自带的doc,重新进行排序
我可真是个小天才~~~~
RestTemplate配置
import org.apache.http.client.HttpClient;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.config.Registry;
import org.apache.http.config.RegistryBuilder;
import org.apache.http.conn.socket.ConnectionSocketFactory;
import org.apache.http.conn.socket.PlainConnectionSocketFactory;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.client.ClientHttpRequestFactory;
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
import org.springframework.web.client.RestTemplate;
@Configuration
public class RestTemplateConfig {
@Bean
public RestTemplate restTemplate() {
return new RestTemplate(httpRequestFactory());
}
public ClientHttpRequestFactory httpRequestFactory() {
return new HttpComponentsClientHttpRequestFactory(httpClient());
}
public HttpClient httpClient() {
Registry<ConnectionSocketFactory> registry = RegistryBuilder.<ConnectionSocketFactory>create()
.register("http", PlainConnectionSocketFactory.getSocketFactory())
.register("https", SSLConnectionSocketFactory.getSocketFactory())
.build();
PoolingHttpClientConnectionManager connectionManager = new PoolingHttpClientConnectionManager(registry);
//设置整个连接池最大连接数 根据自己的场景决定
connectionManager.setMaxTotal(100);
//路由是对maxTotal的细分
connectionManager.setDefaultMaxPerRoute(100);
RequestConfig requestConfig = RequestConfig.custom()
//服务器返回数据(response)的时间,超过该时间抛出read timeout
.setSocketTimeout(10000)
//连接上服务器(握手成功)的时间,超出该时间抛出connect timeout
.setConnectTimeout(5000)
//从连接池中获取连接的超时时间,超过该时间未拿到可用连接,
// 会抛出org.apache.http.conn.ConnectionPoolTimeoutException: Timeout waiting for connection from pool
.setConnectionRequestTimeout(1000)
.build();
return HttpClientBuilder.create()
.setDefaultRequestConfig(requestConfig)
.setConnectionManager(connectionManager)
.build();
}
}
//@author Sorber
//获取json文档
@ApiOperation(value = "4.获取json文档")
@ApiOperationSupport(order = 40)
@GetMapping("/getDoc")
public JSONObject getDoc(String group) {
JSONObject jsonInit = restTemplate.getForObject("http://localhost:7010/v2/api-docs?group=" + group, JSONObject.class);
if (jsonInit == null) {
return null;
}
// 获取paths节点内容
JSONObject paths = jsonInit.getJSONObject("paths");
List<Map.Entry<String, Object>> list = new ArrayList<>(paths.entrySet());
list = list.stream().sorted(Comparator.comparingInt(pp -> {
Map.Entry<String, Object> res = (Map.Entry<String, Object>) pp;
LinkedHashMap hashMap = (LinkedHashMap) res.getValue();
List<Object> objects = Arrays.asList(hashMap.values().toArray());
LinkedHashMap obj = (LinkedHashMap) objects.get(0);
Object objres = obj.get("tags");
if (objres != null) {
ArrayList<String> arrayList = (ArrayList) objres;
String tags = arrayList.get(0);
if (tags.contains(".")) {
String re = tags.substring(0, tags.indexOf("."));
return Integer.parseInt(re);
}
if (tags.contains(" ")) {
String re = tags.substring(0, tags.indexOf(" "));
return Integer.parseInt(re);
}
if (tags.contains("、")) {
String re = tags.substring(0, tags.indexOf("、"));
return Integer.parseInt(re);
}
return 999999;
}
return 999999;
}).thenComparingInt(pp -> {
Map.Entry<String, Object> res = (Map.Entry<String, Object>) pp;
LinkedHashMap hashMap = (LinkedHashMap) res.getValue();
List<Object> objects = Arrays.asList(hashMap.values().toArray());
LinkedHashMap obj = (LinkedHashMap) objects.get(0);
// 获取到order内容
Object objres = obj.get("x-order");
if (objres != null) {
return Integer.parseInt(objres.toString());
}
return 99999;
})).collect(Collectors.toList());
JSONObject jsonObject = new JSONObject(new LinkedHashMap<>());
list.forEach(res -> {
jsonObject.put(res.getKey(), res.getValue());
});
jsonInit.put("paths", jsonObject);
return jsonInit;
}