Ssl 如何在生成OpenAPI客户端时接受自签名证书?

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

我有一个用OpenAPI 2.0编写的rest服务。它通过自签名ssl证书进行保护,该证书无法替换,因为该服务极有可能在生产中运行于
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对象。