Ssl 如何在生成OpenAPI客户端时接受自签名证书?
我有一个用OpenAPI 2.0编写的rest服务。它通过自签名ssl证书进行保护,该证书无法替换,因为该服务极有可能在生产中运行于Ssl 如何在生成OpenAPI客户端时接受自签名证书?,ssl,ssl-certificate,self-signed,swagger-codegen,openapi,Ssl,Ssl Certificate,Self Signed,Swagger Codegen,Openapi,我有一个用OpenAPI 2.0编写的rest服务。它通过自签名ssl证书进行保护,该证书无法替换,因为该服务极有可能在生产中运行于localhost 我使用swagger codegen maven插件从OpenAPi规范生成了一个客户端。客户端似乎可以工作,但它拒绝自签名证书 底层http库是okhttp,它能够接受自签名证书,但由于这种情况,我需要能够随时重新生成客户端,我无法在生成的客户端中包含必要的更改 如何使okhttp接受我的证书 pom.xml <?xml version
localhost
我使用swagger codegen maven插件从OpenAPi规范生成了一个客户端。客户端似乎可以工作,但它拒绝自签名证书
底层http库是okhttp
,它能够接受自签名证书,但由于这种情况,我需要能够随时重新生成客户端,我无法在生成的客户端中包含必要的更改
如何使okhttp
接受我的证书
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.playground</groupId>
<artifactId>api-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<gson-fire.version>1.8.0</gson-fire.version>
<swagger-core.version>1.5.15</swagger-core.version>
<okhttp.version>2.7.5</okhttp.version>
<gson.version>2.8.1</gson.version>
<threetenbp.version>1.3.5</threetenbp.version>
<junit-version>4.12</junit-version>
<swagger-codegen-maven-plugin.version>2.3.1</swagger-codegen-maven-plugin.version>
</properties>
<dependencies>
<dependency>
<groupId>com.playground</groupId>
<artifactId>playground-api</artifactId>
<version>0.1.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<!-- Tag: Swagger SDK Dependencies -->
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-annotations</artifactId>
<version>${swagger-core.version}</version>
</dependency>
<dependency>
<groupId>com.squareup.okhttp</groupId>
<artifactId>okhttp</artifactId>
<version>${okhttp.version}</version>
</dependency>
<dependency>
<groupId>com.squareup.okhttp</groupId>
<artifactId>logging-interceptor</artifactId>
<version>${okhttp.version}</version>
</dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>${gson.version}</version>
</dependency>
<dependency>
<groupId>io.gsonfire</groupId>
<artifactId>gson-fire</artifactId>
<version>${gson-fire.version}</version>
</dependency>
<dependency>
<groupId>org.threeten</groupId>
<artifactId>threetenbp</artifactId>
<version>${threetenbp.version}</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit-version}</version>
<scope>test</scope>
</dependency>
<!-- End: Swagger SDK Dependencies -->
</dependencies>
<build>
<plugins>
<plugin>
<groupId>io.swagger</groupId>
<artifactId>swagger-codegen-maven-plugin</artifactId>
<version>${swagger-codegen-maven-plugin.version}</version>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
<configuration>
<inputSpec>${project.basedir}/src/main/resources/spec.json</inputSpec>
<language>java</language>
<generateApiTests>false</generateApiTests>
<configOptions>
<sourceFolder>src/gen/java/main</sourceFolder>
</configOptions>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
4.0.0
运动场
api客户端
0.0.1-快照
1.8
UTF-8
UTF-8
1.8.0
1.5.15
2.7.5
2.8.1
1.3.5
4.12
2.3.1
运动场
游乐场空气污染指数
0.1.1-快照
org.projectlombok
龙目
昂首阔步
招摇过市的注解
${swagger core.version}
com.squareup.okhttp
okhttp
${okhttp.version}
com.squareup.okhttp
日志拦截器
${okhttp.version}
com.google.code.gson
格森
${gson.version}
io.gsonfire
格森火灾
${gson fire.version}
三十
三个十个基点
${threetenbp.version}
朱尼特
朱尼特
${junit版本}
测试
昂首阔步
swagger codegen maven插件
${swagger codegen maven plugin.version}
生成
${project.basedir}/src/main/resources/spec.json
JAVA
假的
src/gen/java/main
如果问题出在客户机上,那么您可能应该发布使用该客户机的应用程序。可以在OpenApi codegen创建的ApiClient中替换HTTP客户端。您可以创建自己的okHttp客户端,配置为接受自签名证书,并将其提供给ApicClient对象。