okhttp源码导入及Maven构建文件pom.xml的格式

 

okhttp是一个非常强大的网络框架,封装了http及https的网络协议实现,向上层提供统一的网络访问接口,熟悉一个框架最直接的办法是用起来,而想用好,少不了要熟悉了解其源码,RTFSC(Read The Fuck Source Code),okhttp的github路径为:

https://github.com/square/okhttp

拉取代码以后,发现是maven项目,一直在做Android项目,所用到构建为ant及后来的gradle,没怎么接触过maven,试着编了一下,有错误,没有直接通过,汗!!错误如下:

[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Build Order:
[INFO] 
[INFO] OkHttp (Parent)                                                    [pom]
[INFO] OkHttp                                                             [jar]
[INFO] OkHttp test support classes                                        [jar]
[INFO] OkHttp Transport Layer Security (TLS)                              [jar]
[INFO] MockWebServer                                                      [jar]
[INFO] OkHttp URLConnection                                               [jar]
[INFO] OkHttp Logging Interceptor                                         [jar]
[INFO] OkHttp Tests                                                       [jar]
[INFO] OkHttp Android Platform Support                                    [jar]
[INFO] OkHttp Apache HttpClient                                           [jar]
[INFO] OkHttp Server-Sent Events                                          [jar]
[INFO] OkHttp DNS over HTTPS                                              [jar]
[INFO] OkCurl                                                             [jar]
[INFO] Samples (Parent)                                                   [pom]
[INFO] Sample: Guide                                                      [jar]
[INFO] Sample: Crawler                                                    [jar]
[INFO] Sample: Simple Client                                              [jar]
[INFO] Sample: Slack                                                      [jar]
[INFO] Sample: Static Server                                              [jar]
[INFO] Sample: UNIX domain sockets                                        [jar]
[INFO] Benchmarks                                                         [jar]
[INFO] 
[INFO] --------------------< com.squareup.okhttp3:parent >---------------------
[INFO] Building OkHttp (Parent) 3.12.0-SNAPSHOT                          [1/21]
[INFO] --------------------------------[ pom ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ parent ---
[INFO] 
[INFO] --- animal-sniffer-maven-plugin:1.15:check (default) @ parent ---
[INFO] Checking unresolved references to org.codehaus.mojo.signature:java16:1.1
[INFO] 
[INFO] --- maven-checkstyle-plugin:2.17:checkstyle (default) @ parent ---
[INFO] 
[INFO] --- maven-install-plugin:2.4:install (default-install) @ parent ---
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/pom.xml to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/parent/3.12.0-SNAPSHOT/parent-3.12.0-SNAPSHOT.pom
[INFO] 
[INFO] --------------------< com.squareup.okhttp3:okhttp >---------------------
[INFO] Building OkHttp 3.12.0-SNAPSHOT                                   [2/21]
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ okhttp ---
[INFO] 
[INFO] --- templating-maven-plugin:1.0-alpha-3:filter-sources (default) @ okhttp ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO] Source directory: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/generated-sources/java-templates added.
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ okhttp ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 2 resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.7.0:compile (default-compile) @ okhttp ---
[WARNING] Error injecting: org.apache.maven.plugin.compiler.CompilerMojo
java.lang.NoClassDefFoundError: Lorg/codehaus/plexus/languages/java/jpms/LocationManager;
	at java.lang.Class.getDeclaredFields0(Native Method)
	at java.lang.Class.privateGetDeclaredFields(Class.java:2583)
	at java.lang.Class.getDeclaredFields(Class.java:1916)
	at com.google.inject.spi.InjectionPoint.getInjectionPoints(InjectionPoint.java:675)
	at com.google.inject.spi.InjectionPoint.forInstanceMethodsAndFields(InjectionPoint.java:380)
	at com.google.inject.internal.ConstructorBindingImpl.getInternalDependencies(ConstructorBindingImpl.java:164)
	at com.google.inject.internal.InjectorImpl.getInternalDependencies(InjectorImpl.java:613)
	at com.google.inject.internal.InjectorImpl.cleanup(InjectorImpl.java:569)
	at com.google.inject.internal.InjectorImpl.initializeJitBinding(InjectorImpl.java:555)
	at com.google.inject.internal.InjectorImpl.createJustInTimeBinding(InjectorImpl.java:884)
	at com.google.inject.internal.InjectorImpl.createJustInTimeBindingRecursive(InjectorImpl.java:805)
	at com.google.inject.internal.InjectorImpl.getJustInTimeBinding(InjectorImpl.java:282)
	at com.google.inject.internal.InjectorImpl.getBindingOrThrow(InjectorImpl.java:214)
	at com.google.inject.internal.InjectorImpl.getProviderOrThrow(InjectorImpl.java:1006)
	at com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.java:1038)
	at com.google.inject.internal.InjectorImpl.getProvider(InjectorImpl.java:1001)
	at com.google.inject.internal.InjectorImpl.getInstance(InjectorImpl.java:1051)
	at org.eclipse.sisu.space.AbstractDeferredClass.get(AbstractDeferredClass.java:48)
	at com.google.inject.internal.ProviderInternalFactory.provision(ProviderInternalFactory.java:81)
	at com.google.inject.internal.InternalFactoryToInitializableAdapter.provision(InternalFactoryToInitializableAdapter.java:53)
	at com.google.inject.internal.ProviderInternalFactory$1.call(ProviderInternalFactory.java:65)
	at com.google.inject.internal.ProvisionListenerStackCallback$Provision.provision(ProvisionListenerStackCallback.java:115)
	at com.google.inject.internal.ProvisionListenerStackCallback$Provision.provision(ProvisionListenerStackCallback.java:133)
	at com.google.inject.internal.ProvisionListenerStackCallback.provision(ProvisionListenerStackCallback.java:68)
	at com.google.inject.internal.ProviderInternalFactory.circularGet(ProviderInternalFactory.java:63)
	at com.google.inject.internal.InternalFactoryToInitializableAdapter.get(InternalFactoryToInitializableAdapter.java:45)
	at com.google.inject.internal.InjectorImpl$2$1.call(InjectorImpl.java:1016)
	at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1092)
	at com.google.inject.internal.InjectorImpl$2.get(InjectorImpl.java:1012)
	at org.eclipse.sisu.inject.Guice4$1.get(Guice4.java:162)
	at org.eclipse.sisu.inject.LazyBeanEntry.getValue(LazyBeanEntry.java:81)
	at org.eclipse.sisu.plexus.LazyPlexusBean.getValue(LazyPlexusBean.java:51)
	at org.codehaus.plexus.DefaultPlexusContainer.lookup(DefaultPlexusContainer.java:263)
	at org.codehaus.plexus.DefaultPlexusContainer.lookup(DefaultPlexusContainer.java:255)
	at org.apache.maven.plugin.internal.DefaultMavenPluginManager.getConfiguredMojo(DefaultMavenPluginManager.java:519)
	at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:124)
	at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:208)
	at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:154)
	at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:146)
	at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:117)
	at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:81)
	at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:56)
	at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:128)
	at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:305)
	at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:192)
	at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:105)
	at org.apache.maven.cli.MavenCli.execute(MavenCli.java:956)
	at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:290)
	at org.apache.maven.cli.MavenCli.main(MavenCli.java:194)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289)
	at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229)
	at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415)
	at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356)
Caused by: java.lang.ClassNotFoundException: org.codehaus.plexus.languages.java.jpms.LocationManager
	at org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy.loadClass(SelfFirstStrategy.java:50)
	at org.codehaus.plexus.classworlds.realm.ClassRealm.unsynchronizedLoadClass(ClassRealm.java:271)
	at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:247)
	at org.codehaus.plexus.classworlds.realm.ClassRealm.loadClass(ClassRealm.java:239)
	... 57 more
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO] 
[INFO] OkHttp (Parent) 3.12.0-SNAPSHOT .................... SUCCESS [  1.289 s]
[INFO] OkHttp ............................................. FAILURE [  0.480 s]
[INFO] OkHttp test support classes ........................ SKIPPED
[INFO] OkHttp Transport Layer Security (TLS) .............. SKIPPED
[INFO] MockWebServer ...................................... SKIPPED
[INFO] OkHttp URLConnection ............................... SKIPPED
[INFO] OkHttp Logging Interceptor ......................... SKIPPED
[INFO] OkHttp Tests ....................................... SKIPPED
[INFO] OkHttp Android Platform Support .................... SKIPPED
[INFO] OkHttp Apache HttpClient ........................... SKIPPED
[INFO] OkHttp Server-Sent Events .......................... SKIPPED
[INFO] OkHttp DNS over HTTPS .............................. SKIPPED
[INFO] OkCurl ............................................. SKIPPED
[INFO] Samples (Parent) ................................... SKIPPED
[INFO] Sample: Guide ...................................... SKIPPED
[INFO] Sample: Crawler .................................... SKIPPED
[INFO] Sample: Simple Client .............................. SKIPPED
[INFO] Sample: Slack ...................................... SKIPPED
[INFO] Sample: Static Server .............................. SKIPPED
[INFO] Sample: UNIX domain sockets ........................ SKIPPED
[INFO] Benchmarks 3.12.0-SNAPSHOT ......................... SKIPPED
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 2.020 s
[INFO] Finished at: 2018-08-28T15:53:36+08:00
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:compile (default-compile) on project okhttp: Execution default-compile of goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:compile failed: A required class was missing while executing org.apache.maven.plugins:maven-compiler-plugin:3.7.0:compile: Lorg/codehaus/plexus/languages/java/jpms/LocationManager;
[ERROR] -----------------------------------------------------
[ERROR] realm =    plugin>org.apache.maven.plugins:maven-compiler-plugin:3.7.0
[ERROR] strategy = org.codehaus.plexus.classworlds.strategy.SelfFirstStrategy
[ERROR] urls[0] = file:/Users/wangguoqiang/.m2/repository/org/apache/maven/plugins/maven-compiler-plugin/3.7.0/maven-compiler-plugin-3.7.0.jar
[ERROR] urls[1] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-compiler-javac-errorprone/2.8.4/plexus-compiler-javac-errorprone-2.8.4.jar
[ERROR] urls[2] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-utils/3.0.22/plexus-utils-3.0.22.jar
[ERROR] urls[3] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/error_prone_core/2.3.1/error_prone_core-2.3.1.jar
[ERROR] urls[4] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/error_prone_annotation/2.3.1/error_prone_annotation-2.3.1.jar
[ERROR] urls[5] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/error_prone_type_annotations/2.3.1/error_prone_type_annotations-2.3.1.jar
[ERROR] urls[6] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/error_prone_check_api/2.3.1/error_prone_check_api-2.3.1.jar
[ERROR] urls[7] = file:/Users/wangguoqiang/.m2/repository/com/googlecode/java-diff-utils/diffutils/1.3.0/diffutils-1.3.0.jar
[ERROR] urls[8] = file:/Users/wangguoqiang/.m2/repository/com/github/kevinstern/software-and-algorithms/1.0/software-and-algorithms-1.0.jar
[ERROR] urls[9] = file:/Users/wangguoqiang/.m2/repository/com/github/stephenc/jcip/jcip-annotations/1.0-1/jcip-annotations-1.0-1.jar
[ERROR] urls[10] = file:/Users/wangguoqiang/.m2/repository/org/pcollections/pcollections/2.1.2/pcollections-2.1.2.jar
[ERROR] urls[11] = file:/Users/wangguoqiang/.m2/repository/com/google/guava/guava/23.5-jre/guava-23.5-jre.jar
[ERROR] urls[12] = file:/Users/wangguoqiang/.m2/repository/org/checkerframework/checker-qual/2.0.0/checker-qual-2.0.0.jar
[ERROR] urls[13] = file:/Users/wangguoqiang/.m2/repository/com/google/j2objc/j2objc-annotations/1.1/j2objc-annotations-1.1.jar
[ERROR] urls[14] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/mojo/animal-sniffer-annotations/1.14/animal-sniffer-annotations-1.14.jar
[ERROR] urls[15] = file:/Users/wangguoqiang/.m2/repository/com/google/auto/auto-common/0.10/auto-common-0.10.jar
[ERROR] urls[16] = file:/Users/wangguoqiang/.m2/repository/com/google/code/findbugs/jFormatString/3.0.0/jFormatString-3.0.0.jar
[ERROR] urls[17] = file:/Users/wangguoqiang/.m2/repository/com/google/code/findbugs/jsr305/3.0.0/jsr305-3.0.0.jar
[ERROR] urls[18] = file:/Users/wangguoqiang/.m2/repository/org/checkerframework/dataflow/2.5.0/dataflow-2.5.0.jar
[ERROR] urls[19] = file:/Users/wangguoqiang/.m2/repository/org/checkerframework/javacutil/2.5.0/javacutil-2.5.0.jar
[ERROR] urls[20] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/javac/9+181-r4173-1/javac-9+181-r4173-1.jar
[ERROR] urls[21] = file:/Users/wangguoqiang/.m2/repository/com/google/errorprone/error_prone_annotations/2.3.1/error_prone_annotations-2.3.1.jar
[ERROR] urls[22] = file:/Users/wangguoqiang/.m2/repository/org/sonatype/sisu/sisu-inject-bean/1.4.2/sisu-inject-bean-1.4.2.jar
[ERROR] urls[23] = file:/Users/wangguoqiang/.m2/repository/org/sonatype/sisu/sisu-guice/2.1.7/sisu-guice-2.1.7-noaop.jar
[ERROR] urls[24] = file:/Users/wangguoqiang/.m2/repository/org/sonatype/aether/aether-util/1.7/aether-util-1.7.jar
[ERROR] urls[25] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-interpolation/1.14/plexus-interpolation-1.14.jar
[ERROR] urls[26] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-component-annotations/1.6/plexus-component-annotations-1.6.jar
[ERROR] urls[27] = file:/Users/wangguoqiang/.m2/repository/org/sonatype/plexus/plexus-sec-dispatcher/1.3/plexus-sec-dispatcher-1.3.jar
[ERROR] urls[28] = file:/Users/wangguoqiang/.m2/repository/org/sonatype/plexus/plexus-cipher/1.4/plexus-cipher-1.4.jar
[ERROR] urls[29] = file:/Users/wangguoqiang/.m2/repository/org/apache/maven/shared/maven-shared-utils/3.1.0/maven-shared-utils-3.1.0.jar
[ERROR] urls[30] = file:/Users/wangguoqiang/.m2/repository/commons-io/commons-io/2.5/commons-io-2.5.jar
[ERROR] urls[31] = file:/Users/wangguoqiang/.m2/repository/org/apache/maven/shared/maven-shared-incremental/1.1/maven-shared-incremental-1.1.jar
[ERROR] urls[32] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-java/0.9.2/plexus-java-0.9.2.jar
[ERROR] urls[33] = file:/Users/wangguoqiang/.m2/repository/org/ow2/asm/asm/6.0_BETA/asm-6.0_BETA.jar
[ERROR] urls[34] = file:/Users/wangguoqiang/.m2/repository/com/thoughtworks/qdox/qdox/2.0-M7/qdox-2.0-M7.jar
[ERROR] urls[35] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-compiler-api/2.8.2/plexus-compiler-api-2.8.2.jar
[ERROR] urls[36] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-compiler-manager/2.8.2/plexus-compiler-manager-2.8.2.jar
[ERROR] urls[37] = file:/Users/wangguoqiang/.m2/repository/org/codehaus/plexus/plexus-compiler-javac/2.8.2/plexus-compiler-javac-2.8.2.jar
[ERROR] Number of foreign imports: 1
[ERROR] import: Entry[import  from realm ClassRealm[maven.api, parent: null]]
[ERROR] 
[ERROR] -----------------------------------------------------: org.codehaus.plexus.languages.java.jpms.LocationManager
[ERROR] -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginContainerException
[ERROR] 
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR]   mvn <goals> -rf :okhttp

关键位置:

问题出在maven-compiler-plugin这个插件上,好吧,找这个插件的最新版本是3.8.0,然后在pom.xml文件中设入,还是不行,报另一个错误:

[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.0:compile (default-compile) on project okhttp: Fatal error compiling: CompilerException: InvocationTargetException: com/google/common/collect/ImmutableSet: com.google.common.collect.ImmutableSet -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException
[ERROR] 
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR]   mvn <goals> -rf :okhttp

说明3.8.0的插件和该项目兼容还是有问题。在解决该问题的过程中,发现对maven项目构建过程不熟悉,导致解决问题非常缓慢,如此,抽时间研究下吧。(解决方案后面有讲到)

maven项目构建最关键的文件为pom.xml,从项目根部,构建工具找到第一个pom.xml文件,下面是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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <parent>
    <groupId>org.sonatype.oss</groupId>
    <artifactId>oss-parent</artifactId>
    <version>7</version>
  </parent>

  <groupId>com.squareup.okhttp3</groupId>
  <artifactId>parent</artifactId>
  <version>3.12.0-SNAPSHOT</version>
  <packaging>pom</packaging>

  <name>OkHttp (Parent)</name>
  <description>An HTTP+HTTP/2 client for Android and Java applications</description>
  <url>https://github.com/square/okhttp</url>

  <modules>
    <module>okhttp</module>
    <module>okhttp-tests</module>

    <module>okhttp-android-support</module>

    <module>okhttp-apache</module>
    <module>okhttp-sse</module>
    <module>okhttp-testing-support</module>
    <module>okhttp-tls</module>
    <module>okhttp-urlconnection</module>

    <module>okhttp-logging-interceptor</module>

    <module>okhttp-dnsoverhttps</module>

    <module>okcurl</module>
    <module>mockwebserver</module>
    <module>samples</module>
    <module>benchmarks</module>
  </modules>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

    <!-- Compilation -->
    <airlift.version>0.7</airlift.version>
    <!-- ALPN library targeted to Java 7 -->
    <alpn.jdk7.version>7.1.2.v20141202</alpn.jdk7.version>
    <android.version>4.1.1.4</android.version>
    <animal.sniffer.version>1.15</animal.sniffer.version>
    <apache.http.version>4.2.6</apache.http.version>
    <bouncycastle.version>1.60</bouncycastle.version>
    <guava.version>16.0</guava.version>
    <java.version>1.7</java.version>
    <moshi.version>1.1.0</moshi.version>
    <jnr-unixsocket.version>0.19</jnr-unixsocket.version>
    <okio.version>1.15.0</okio.version>
    <conscrypt.version>1.1.4</conscrypt.version>

    <!-- Test Dependencies -->
    <junit.version>4.12</junit.version>

    <!-- platform test mode -->
    <okhttp.platform>platform</okhttp.platform>
  </properties>

  <scm>
    <url>https://github.com/square/okhttp/</url>
    <connection>scm:git:https://github.com/square/okhttp.git</connection>
    <developerConnection>scm:git:git@github.com:square/okhttp.git</developerConnection>
    <tag>HEAD</tag>
  </scm>

  <issueManagement>
    <system>GitHub Issues</system>
    <url>https://github.com/square/okhttp/issues</url>
  </issueManagement>

  <licenses>
    <license>
      <name>Apache 2.0</name>
      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
    </license>
  </licenses>

  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>com.squareup.okio</groupId>
        <artifactId>okio</artifactId>
        <version>${okio.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.code.findbugs</groupId>
        <artifactId>jsr305</artifactId>
        <version>3.0.2</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
      </dependency>
      <dependency>
        <groupId>org.bouncycastle</groupId>
        <artifactId>bcprov-jdk15on</artifactId>
        <version>${bouncycastle.version}</version>
      </dependency>
      <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>${apache.http.version}</version>
      </dependency>
      <dependency>
        <groupId>io.airlift</groupId>
        <artifactId>airline</artifactId>
        <version>${airlift.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>${guava.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.android</groupId>
        <artifactId>android</artifactId>
        <version>${android.version}</version>
      </dependency>
      <dependency>
        <groupId>com.squareup.moshi</groupId>
        <artifactId>moshi</artifactId>
        <version>${moshi.version}</version>
      </dependency>
      <dependency>
        <groupId>com.github.jnr</groupId>
        <artifactId>jnr-unixsocket</artifactId>
        <version>${jnr-unixsocket.version}</version>
      </dependency>
      <dependency>
        <groupId>org.conscrypt</groupId>
        <artifactId>conscrypt-openjdk-uber</artifactId>
        <version>${conscrypt.version}</version>
      </dependency>
    </dependencies>
  </dependencyManagement>

  <build>
    <pluginManagement>
      <plugins>
        <!-- <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
          <configuration>
            <compilerId>javac-with-errorprone</compilerId>
            <forceJavacCompilerUse>true</forceJavacCompilerUse>
            <source>${java.version}</source>
            <target>${java.version}</target>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.codehaus.plexus</groupId>
              <artifactId>plexus-compiler-javac-errorprone</artifactId>
              <version>2.8.4</version>
            </dependency>
            <dependency>
              <groupId>com.google.errorprone</groupId>
              <artifactId>error_prone_core</artifactId>
              <version>2.3.1</version>
            </dependency>
          </dependencies>
        </plugin> -->
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.6.1</version>
          <configuration>
            <compilerId>javac-with-errorprone</compilerId>
            <forceJavacCompilerUse>true</forceJavacCompilerUse>
            <source>${java.version}</source>
            <target>${java.version}</target>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.codehaus.plexus</groupId>
              <artifactId>plexus-compiler-javac-errorprone</artifactId>
              <version>2.8.1</version>
            </dependency>
            <dependency>
              <groupId>com.google.errorprone</groupId>
              <artifactId>error_prone_core</artifactId>
              <version>2.0.16</version>
            </dependency>
          </dependencies>
        </plugin>

        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.21.0</version>
          <configuration>
            <systemPropertyVariables>
              <okhttp.platform>${okhttp.platform}</okhttp.platform>
            </systemPropertyVariables>
            <redirectTestOutputToFile>true</redirectTestOutputToFile>
            <properties>
              <!--
                Configure a listener for enforcing that no uncaught exceptions issue from OkHttp
                tests. Every test must have a <scope>test</scope> dependency on
                okhttp-testing-support.
                -->
              <property>
                <name>listener</name>
                <value>okhttp3.testing.InstallUncaughtExceptionHandlerListener</value>
              </property>
            </properties>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.apache.maven.surefire</groupId>
              <artifactId>surefire-junit47</artifactId>
              <version>2.21.0</version>
            </dependency>
          </dependencies>
        </plugin>

        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-javadoc-plugin</artifactId>
          <version>2.10.4</version>
        </plugin>
      </plugins>
    </pluginManagement>

    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-release-plugin</artifactId>
        <version>2.4.2</version>
        <dependencies>
          <dependency>
            <groupId>org.apache.maven.scm</groupId>
            <artifactId>maven-scm-provider-gitexe</artifactId>
            <version>1.9</version>
          </dependency>
        </dependencies>
        <configuration>
          <autoVersionSubmodules>true</autoVersionSubmodules>
        </configuration>
      </plugin>

      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-checkstyle-plugin</artifactId>
        <version>2.17</version>
        <dependencies>
          <dependency>
            <groupId>com.puppycrawl.tools</groupId>
            <artifactId>checkstyle</artifactId>
            <version>7.7</version>
          </dependency>
        </dependencies>
        <configuration>
          <failsOnError>true</failsOnError>
          <configLocation>checkstyle.xml</configLocation>
          <consoleOutput>true</consoleOutput>
          <excludes>**/CipherSuite.java</excludes>
        </configuration>
        <executions>
          <execution>
            <phase>verify</phase>
            <goals>
              <goal>checkstyle</goal>
            </goals>
          </execution>
        </executions>
      </plugin>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>animal-sniffer-maven-plugin</artifactId>
        <version>${animal.sniffer.version}</version>
        <executions>
          <execution>
            <phase>test</phase>
            <goals>
              <goal>check</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <signature>
            <groupId>org.codehaus.mojo.signature</groupId>
            <artifactId>java16</artifactId>
            <version>1.1</version>
          </signature>
        </configuration>
      </plugin>
    </plugins>
  </build>

  <profiles>
    <profile>
      <id>alpn-when-jdk7</id>
      <activation>
        <jdk>1.7</jdk>
      </activation>
      <properties>
        <bootclasspathPrefix>
          ${settings.localRepository}/org/mortbay/jetty/alpn/alpn-boot/${alpn.jdk7.version}/alpn-boot-${alpn.jdk7.version}.jar
        </bootclasspathPrefix>
        <okhttp.platform>jdk-with-jetty-boot</okhttp.platform>
      </properties>
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <configuration>
                <argLine>-Xbootclasspath/p:${bootclasspathPrefix} -Xms512m -Xmx512m</argLine>
              </configuration>
              <dependencies>
                <dependency>
                  <groupId>org.mortbay.jetty.alpn</groupId>
                  <artifactId>alpn-boot</artifactId>
                  <version>${alpn.jdk7.version}</version>
                </dependency>
              </dependencies>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </profile>
    <profile>
      <id>alpn-when-jdk8</id>
      <activation>
        <jdk>1.8</jdk>
      </activation>
      <properties>
        <bootclasspathPrefix>
          ${settings.localRepository}/org/mortbay/jetty/alpn/alpn-boot/${alpn.jdk8.version}/alpn-boot-${alpn.jdk8.version}.jar
        </bootclasspathPrefix>
        <okhttp.platform>jdk-with-jetty-boot</okhttp.platform>
      </properties>
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <configuration>
                <argLine>-Xbootclasspath/p:${bootclasspathPrefix} -Xms512m -Xmx512m</argLine>
              </configuration>
              <dependencies>
                <dependency>
                  <groupId>org.mortbay.jetty.alpn</groupId>
                  <artifactId>alpn-boot</artifactId>
                  <version>${alpn.jdk8.version}</version>
                </dependency>
              </dependencies>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </profile>
    <profile>
      <id>jdk9</id>
      <activation>
        <jdk>9</jdk>
      </activation>
      <properties>
        <okhttp.platform>jdk9</okhttp.platform>
      </properties>
    </profile>
    <profile>
      <id>conscrypt</id>
      <properties>
        <okhttp.platform>conscrypt</okhttp.platform>
      </properties>
      <dependencies>
        <dependency>
          <groupId>org.conscrypt</groupId>
          <artifactId>conscrypt-openjdk-uber</artifactId>
        </dependency>
      </dependencies>
    </profile>
    <!-- ALPN Versions targeted for each Java 8 minor release -->
    <!-- Check versions with this page: -->
    <!-- http://www.eclipse.org/jetty/documentation/current/alpn-chapter.html#alpn-chapterchapterversions -->
    <profile>
      <id>alpn-when-jdk8_05</id>
      <activation>
        <jdk>1.8.0_05</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_11</id>
      <activation>
        <jdk>1.8.0_11</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_20</id>
      <activation>
        <jdk>1.8.0_20</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_25</id>
      <activation>
        <jdk>1.8.0_25</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.2.v20141202</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_31</id>
      <activation>
        <jdk>1.8.0_31</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_40</id>
      <activation>
        <jdk>1.8.0_40</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_45</id>
      <activation>
        <jdk>1.8.0_45</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_51</id>
      <activation>
        <jdk>1.8.0_51</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.4.v20150727</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_60</id>
      <activation>
        <jdk>1.8.0_60</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.5.v20150921</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_65</id>
      <activation>
        <jdk>1.8.0_65</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.6.v20151105</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_66</id>
      <activation>
        <jdk>1.8.0_66</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.6.v20151105</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_71</id>
      <activation>
        <jdk>1.8.0_71</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_72</id>
      <activation>
        <jdk>1.8.0_72</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_73</id>
      <activation>
        <jdk>1.8.0_73</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_74</id>
      <activation>
        <jdk>1.8.0_74</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_77</id>
      <activation>
        <jdk>1.8.0_77</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_91</id>
      <activation>
        <jdk>1.8.0_91</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_92</id>
      <activation>
        <jdk>1.8.0_92</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.8.v20160420</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_101</id>
      <activation>
        <jdk>1.8.0_101</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.8.v20160420</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_102</id>
      <activation>
        <jdk>1.8.0_102</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_111</id>
      <activation>
        <jdk>1.8.0_111</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_112</id>
      <activation>
        <jdk>1.8.0_112</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_121</id>
      <activation>
        <jdk>1.8.0_121</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_131</id>
      <activation>
        <jdk>1.8.0_131</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_141</id>
      <activation>
        <jdk>1.8.0_141</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_144</id>
      <activation>
        <jdk>1.8.0_144</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_151</id>
      <activation>
        <jdk>1.8.0_151</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_152</id>
      <activation>
        <jdk>1.8.0_152</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_161</id>
      <activation>
        <jdk>1.8.0_161</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_162</id>
      <activation>
        <jdk>1.8.0_162</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_171</id>
      <activation>
        <jdk>1.8.0_171</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_172</id>
      <activation>
        <jdk>1.8.0_172</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_181</id>
      <activation>
        <jdk>1.8.0_181</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
  </profiles>
</project>

文件还是挺长的,但内容并不是很多,下面来分析下:

第一部分:

project:所有项目相关的均在此标签中

maven头:是声明maven的版本等信息,目前基本不会再变

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>

第二部分:

表示继承关系,即该pom.xml的父xml文件是什么,了解gradle的同学可以把它想成compile或api,通过parent关键字组织整个项目的依赖关系,上面这个文件的parent指向了一个maven中央仓库,用于代码提交

继承关系的下方为该工程的唯一标识,通过groupId、artifactId、version定义

  <parent>
    <groupId>org.sonatype.oss</groupId>
    <artifactId>oss-parent</artifactId>
    <version>7</version>
  </parent>

  <groupId>com.squareup.okhttp3</groupId>
  <artifactId>parent</artifactId>
  <version>3.12.0-SNAPSHOT</version>
  <packaging>pom</packaging>

对比看一下okhttp路径下的pom.xml文件中的该标签:

  <!-- okhttp的pom.xml文件 --> 
  <parent>
    <groupId>com.squareup.okhttp3</groupId>
    <artifactId>parent</artifactId>
    <version>3.12.0-SNAPSHOT</version>
  </parent>

由上面代码可以看出okhttp路径下的文件的parent所映射的刚好为parent(项目根路径)下的pom.xml中的工程定义。

第三部分:maven文档所用到的信息:名称、描述、项目主页的url

  <name>OkHttp (Parent)</name>
  <description>An HTTP+HTTP/2 client for Android and Java applications</description>
  <url>https://github.com/square/okhttp</url>

第四部分:项目所有的子模块

  <modules>
    <module>okhttp</module>
    <module>okhttp-tests</module>

    <module>okhttp-android-support</module>

    <module>okhttp-apache</module>
    <module>okhttp-sse</module>
    <module>okhttp-testing-support</module>
    <module>okhttp-tls</module>
    <module>okhttp-urlconnection</module>

    <module>okhttp-logging-interceptor</module>

    <module>okhttp-dnsoverhttps</module>

    <module>okcurl</module>
    <module>mockwebserver</module>
    <module>samples</module>
    <module>benchmarks</module>
  </modules>

映射下图中红框中的部分,模块为项目的组织单元,每一个独立的模块代表着项目的中的一个独立业务,在gradle中也如此划分。

第五部分:自定义属性,可以定义一些文档中用的变量及值存放于此,在文档的其他位置通过变量名进行索引

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

    <!-- Compilation -->
    <airlift.version>0.7</airlift.version>
    <!-- ALPN library targeted to Java 7 -->
    <alpn.jdk7.version>7.1.2.v20141202</alpn.jdk7.version>
    <android.version>4.1.1.4</android.version>
    <animal.sniffer.version>1.15</animal.sniffer.version>
    <apache.http.version>4.2.6</apache.http.version>
    <bouncycastle.version>1.60</bouncycastle.version>
    <guava.version>16.0</guava.version>
    <java.version>1.7</java.version>
    <moshi.version>1.1.0</moshi.version>
    <jnr-unixsocket.version>0.19</jnr-unixsocket.version>
    <okio.version>1.15.0</okio.version>
    <conscrypt.version>1.1.4</conscrypt.version>

    <!-- Test Dependencies -->
    <junit.version>4.12</junit.version>

    <!-- platform test mode -->
    <okhttp.platform>platform</okhttp.platform>
  </properties>

以airlift.version变量为列,使用的位置位于:

第六部分:SCM拉取代码或部署代码的设定,SCM用于项目中从服务器获取代码,或发布代码到服务器,定义了服务器的位置,同步的协议(本项目中为git),版本tag为HEAD(即最新的代码)

  <scm>
    <url>https://github.com/square/okhttp/</url>
    <connection>scm:git:https://github.com/square/okhttp.git</connection>
    <developerConnection>scm:git:git@github.com:square/okhttp.git</developerConnection>
    <tag>HEAD</tag>
  </scm>

第七部分:问题的报告及跟踪位置

  <issueManagement>
    <system>GitHub Issues</system>
    <url>https://github.com/square/okhttp/issues</url>
  </issueManagement>

第八部分:软件证书定义

  <licenses>
    <license>
      <name>Apache 2.0</name>
      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
    </license>
  </licenses>

第九部分:项目所依赖的工程或模块,这部分较为重要,没有这些依赖关程,项目构建过程中会提示有类文件或定义找不到位置

  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>com.squareup.okio</groupId>
        <artifactId>okio</artifactId>
        <version>${okio.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.code.findbugs</groupId>
        <artifactId>jsr305</artifactId>
        <version>3.0.2</version>
        <scope>provided</scope>
      </dependency>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>${junit.version}</version>
      </dependency>
      <dependency>
        <groupId>org.bouncycastle</groupId>
        <artifactId>bcprov-jdk15on</artifactId>
        <version>${bouncycastle.version}</version>
      </dependency>
      <dependency>
        <groupId>org.apache.httpcomponents</groupId>
        <artifactId>httpclient</artifactId>
        <version>${apache.http.version}</version>
      </dependency>
      <dependency>
        <groupId>io.airlift</groupId>
        <artifactId>airline</artifactId>
        <version>${airlift.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.guava</groupId>
        <artifactId>guava</artifactId>
        <version>${guava.version}</version>
      </dependency>
      <dependency>
        <groupId>com.google.android</groupId>
        <artifactId>android</artifactId>
        <version>${android.version}</version>
      </dependency>
      <dependency>
        <groupId>com.squareup.moshi</groupId>
        <artifactId>moshi</artifactId>
        <version>${moshi.version}</version>
      </dependency>
      <dependency>
        <groupId>com.github.jnr</groupId>
        <artifactId>jnr-unixsocket</artifactId>
        <version>${jnr-unixsocket.version}</version>
      </dependency>
      <dependency>
        <groupId>org.conscrypt</groupId>
        <artifactId>conscrypt-openjdk-uber</artifactId>
        <version>${conscrypt.version}</version>
      </dependency>
    </dependencies>
  </dependencyManagement>

在上面的标签中,各标签含义从标签名中即可获知,注意下scope这个属性,表示依赖范围,默认为compile即编译期,其他可能的值包括:

compile 默认范围,用于编译  

provided 类似于编译,但支持你期待jdk或者容器提供,类似于classpath     

runtime 在执行时需要使用     

test 用于test任务时使用     

system 需要外在提供相应的元素。通过systemPath来取得     

systemPath 仅用于范围为system。提供相应的路径     

optional 当项目自身被依赖时,标注依赖是否传递。用于连续依赖时使用

第十部分:build及插件,这一部分是maven构建的核心,所有编译期的动作都要向build中注册,而所有注册到的动作,会在编译期执行

<build>
    <pluginManagement>
      <plugins>
        <!-- <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.8.0</version>
          <configuration>
            <compilerId>javac-with-errorprone</compilerId>
            <forceJavacCompilerUse>true</forceJavacCompilerUse>
            <source>${java.version}</source>
            <target>${java.version}</target>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.codehaus.plexus</groupId>
              <artifactId>plexus-compiler-javac-errorprone</artifactId>
              <version>2.8.4</version>
            </dependency>
            <dependency>
              <groupId>com.google.errorprone</groupId>
              <artifactId>error_prone_core</artifactId>
              <version>2.3.1</version>
            </dependency>
          </dependencies>
        </plugin> -->
        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.6.1</version>
          <configuration>
            <compilerId>javac-with-errorprone</compilerId>
            <forceJavacCompilerUse>true</forceJavacCompilerUse>
            <source>${java.version}</source>
            <target>${java.version}</target>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.codehaus.plexus</groupId>
              <artifactId>plexus-compiler-javac-errorprone</artifactId>
              <version>2.8.1</version>
            </dependency>
            <dependency>
              <groupId>com.google.errorprone</groupId>
              <artifactId>error_prone_core</artifactId>
              <version>2.0.16</version>
            </dependency>
          </dependencies>
        </plugin>

        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.21.0</version>
          <configuration>
            <systemPropertyVariables>
              <okhttp.platform>${okhttp.platform}</okhttp.platform>
            </systemPropertyVariables>
            <redirectTestOutputToFile>true</redirectTestOutputToFile>
            <properties>
              <!--
                Configure a listener for enforcing that no uncaught exceptions issue from OkHttp
                tests. Every test must have a <scope>test</scope> dependency on
                okhttp-testing-support.
                -->
              <property>
                <name>listener</name>
                <value>okhttp3.testing.InstallUncaughtExceptionHandlerListener</value>
              </property>
            </properties>
          </configuration>
          <dependencies>
            <dependency>
              <groupId>org.apache.maven.surefire</groupId>
              <artifactId>surefire-junit47</artifactId>
              <version>2.21.0</version>
            </dependency>
          </dependencies>
        </plugin>

        <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-javadoc-plugin</artifactId>
          <version>2.10.4</version>
        </plugin>
      </plugins>
    </pluginManagement>

    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-release-plugin</artifactId>
        <version>2.4.2</version>
        <dependencies>
          <dependency>
            <groupId>org.apache.maven.scm</groupId>
            <artifactId>maven-scm-provider-gitexe</artifactId>
            <version>1.9</version>
          </dependency>
        </dependencies>
        <configuration>
          <autoVersionSubmodules>true</autoVersionSubmodules>
        </configuration>
      </plugin>

      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-checkstyle-plugin</artifactId>
        <version>2.17</version>
        <dependencies>
          <dependency>
            <groupId>com.puppycrawl.tools</groupId>
            <artifactId>checkstyle</artifactId>
            <version>7.7</version>
          </dependency>
        </dependencies>
        <configuration>
          <failsOnError>true</failsOnError>
          <configLocation>checkstyle.xml</configLocation>
          <consoleOutput>true</consoleOutput>
          <excludes>**/CipherSuite.java</excludes>
        </configuration>
        <executions>
          <execution>
            <phase>verify</phase>
            <goals>
              <goal>checkstyle</goal>
            </goals>
          </execution>
        </executions>
      </plugin>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>animal-sniffer-maven-plugin</artifactId>
        <version>${animal.sniffer.version}</version>
        <executions>
          <execution>
            <phase>test</phase>
            <goals>
              <goal>check</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <signature>
            <groupId>org.codehaus.mojo.signature</groupId>
            <artifactId>java16</artifactId>
            <version>1.1</version>
          </signature>
        </configuration>
      </plugin>
    </plugins>
  </build>

build由多个插件组成,各个插件又含有自身的设定,以下述插件为例:

        <plugin>
          <!-- 插件标识符及版本 -->
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>3.6.1</version>
          <!-- 插件所属的变量设定 -->
          <configuration>
            <compilerId>javac-with-errorprone</compilerId>
            <forceJavacCompilerUse>true</forceJavacCompilerUse>
            <source>${java.version}</source>
            <target>${java.version}</target>
          </configuration>
          <!-- 插件的所依赖的其他插件 -->
          <dependencies>
            <dependency>
              <groupId>org.codehaus.plexus</groupId>
              <artifactId>plexus-compiler-javac-errorprone</artifactId>
              <version>2.8.1</version>
            </dependency>
            <dependency>
              <groupId>com.google.errorprone</groupId>
              <artifactId>error_prone_core</artifactId>
              <version>2.0.16</version>
            </dependency>
          </dependencies>
        </plugin>

各插件的功能及配置项可以查看官方文档:

http://maven.apache.org/plugins/index.html

第十一部分:也是parent/pom.xml的最后一部分,profiles部分

  <profiles>
    <profile>
      <id>alpn-when-jdk7</id>
      <activation>
        <jdk>1.7</jdk>
      </activation>
      <properties>
        <bootclasspathPrefix>
          ${settings.localRepository}/org/mortbay/jetty/alpn/alpn-boot/${alpn.jdk7.version}/alpn-boot-${alpn.jdk7.version}.jar
        </bootclasspathPrefix>
        <okhttp.platform>jdk-with-jetty-boot</okhttp.platform>
      </properties>
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <configuration>
                <argLine>-Xbootclasspath/p:${bootclasspathPrefix} -Xms512m -Xmx512m</argLine>
              </configuration>
              <dependencies>
                <dependency>
                  <groupId>org.mortbay.jetty.alpn</groupId>
                  <artifactId>alpn-boot</artifactId>
                  <version>${alpn.jdk7.version}</version>
                </dependency>
              </dependencies>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </profile>
    <profile>
      <id>alpn-when-jdk8</id>
      <activation>
        <jdk>1.8</jdk>
      </activation>
      <properties>
        <bootclasspathPrefix>
          ${settings.localRepository}/org/mortbay/jetty/alpn/alpn-boot/${alpn.jdk8.version}/alpn-boot-${alpn.jdk8.version}.jar
        </bootclasspathPrefix>
        <okhttp.platform>jdk-with-jetty-boot</okhttp.platform>
      </properties>
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <configuration>
                <argLine>-Xbootclasspath/p:${bootclasspathPrefix} -Xms512m -Xmx512m</argLine>
              </configuration>
              <dependencies>
                <dependency>
                  <groupId>org.mortbay.jetty.alpn</groupId>
                  <artifactId>alpn-boot</artifactId>
                  <version>${alpn.jdk8.version}</version>
                </dependency>
              </dependencies>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </profile>
    <profile>
      <id>jdk9</id>
      <activation>
        <jdk>9</jdk>
      </activation>
      <properties>
        <okhttp.platform>jdk9</okhttp.platform>
      </properties>
    </profile>
    <profile>
      <id>conscrypt</id>
      <properties>
        <okhttp.platform>conscrypt</okhttp.platform>
      </properties>
      <dependencies>
        <dependency>
          <groupId>org.conscrypt</groupId>
          <artifactId>conscrypt-openjdk-uber</artifactId>
        </dependency>
      </dependencies>
    </profile>
    <!-- ALPN Versions targeted for each Java 8 minor release -->
    <!-- Check versions with this page: -->
    <!-- http://www.eclipse.org/jetty/documentation/current/alpn-chapter.html#alpn-chapterchapterversions -->
    <profile>
      <id>alpn-when-jdk8_05</id>
      <activation>
        <jdk>1.8.0_05</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_11</id>
      <activation>
        <jdk>1.8.0_11</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_20</id>
      <activation>
        <jdk>1.8.0_20</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_25</id>
      <activation>
        <jdk>1.8.0_25</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.2.v20141202</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_31</id>
      <activation>
        <jdk>1.8.0_31</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_40</id>
      <activation>
        <jdk>1.8.0_40</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_45</id>
      <activation>
        <jdk>1.8.0_45</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.3.v20150130</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_51</id>
      <activation>
        <jdk>1.8.0_51</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.4.v20150727</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_60</id>
      <activation>
        <jdk>1.8.0_60</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.5.v20150921</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_65</id>
      <activation>
        <jdk>1.8.0_65</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.6.v20151105</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_66</id>
      <activation>
        <jdk>1.8.0_66</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.6.v20151105</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_71</id>
      <activation>
        <jdk>1.8.0_71</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_72</id>
      <activation>
        <jdk>1.8.0_72</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_73</id>
      <activation>
        <jdk>1.8.0_73</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_74</id>
      <activation>
        <jdk>1.8.0_74</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_77</id>
      <activation>
        <jdk>1.8.0_77</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_91</id>
      <activation>
        <jdk>1.8.0_91</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.7.v20160121</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_92</id>
      <activation>
        <jdk>1.8.0_92</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.8.v20160420</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_101</id>
      <activation>
        <jdk>1.8.0_101</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.8.v20160420</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_102</id>
      <activation>
        <jdk>1.8.0_102</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_111</id>
      <activation>
        <jdk>1.8.0_111</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_112</id>
      <activation>
        <jdk>1.8.0_112</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.9.v20160720</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_121</id>
      <activation>
        <jdk>1.8.0_121</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_131</id>
      <activation>
        <jdk>1.8.0_131</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_141</id>
      <activation>
        <jdk>1.8.0_141</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_144</id>
      <activation>
        <jdk>1.8.0_144</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_151</id>
      <activation>
        <jdk>1.8.0_151</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_152</id>
      <activation>
        <jdk>1.8.0_152</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.11.v20170118</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_161</id>
      <activation>
        <jdk>1.8.0_161</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_162</id>
      <activation>
        <jdk>1.8.0_162</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_171</id>
      <activation>
        <jdk>1.8.0_171</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_172</id>
      <activation>
        <jdk>1.8.0_172</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
    <profile>
      <id>alpn-when-jdk8_181</id>
      <activation>
        <jdk>1.8.0_181</jdk>
      </activation>
      <properties>
        <alpn.jdk8.version>8.1.12.v20180117</alpn.jdk8.version>
      </properties>
    </profile>
  </profiles>

根据环境变量或者是命令所携带的参数信息,区分使用某个构建项,什么意思呢,就是在这里面含有许多的构建项,或者是build子项,或者是变量定义,使用那个项,取决于环境变量及输入命令,区分的标识为activation标签,以下述代码为例:

    <profile>
      <!-- 该profile的唯一标识 -->
      <id>alpn-when-jdk7</id>
      <!-- activation定义了识别标准,该profile生效的环境为jdk 1.7的版本 -->
      <activation>
        <jdk>1.7</jdk>
      </activation>
      <!-- 变量定义 -->
      <properties>
        <bootclasspathPrefix>
          ${settings.localRepository}/org/mortbay/jetty/alpn/alpn-boot/${alpn.jdk7.version}/alpn-boot-${alpn.jdk7.version}.jar
        </bootclasspathPrefix>
        <okhttp.platform>jdk-with-jetty-boot</okhttp.platform>
      </properties>
      <!-- 该环境下替换已有默认的插件设置 -->
      <build>
        <pluginManagement>
          <plugins>
            <plugin>
              <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-surefire-plugin</artifactId>
              <configuration>
                <argLine>-Xbootclasspath/p:${bootclasspathPrefix} -Xms512m -Xmx512m</argLine>
              </configuration>
              <dependencies>
                <dependency>
                  <groupId>org.mortbay.jetty.alpn</groupId>
                  <artifactId>alpn-boot</artifactId>
                  <version>${alpn.jdk7.version}</version>
                </dependency>
              </dependencies>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </profile>

再来看一下:

    <profile>
      <id>alpn-when-jdk8_05</id>
      <activation>
        <jdk>1.8.0_05</jdk>
      </activation>
      <!-- 在jdk为1.8.0_05版本下alpn.jdk8.version的值为8.1.0.v20141016 -->
      <properties>
        <alpn.jdk8.version>8.1.0.v20141016</alpn.jdk8.version>
      </properties>
    </profile>

弄清楚了pom.xml的配置项含义,再来解决下之前的问题,从报错信息可以看出,3.8.0的maven-compiler-plugin插件有问题,考虑到okhttp配置的更新时间较早,降一下该插件版本,更换为该插件的3.6.1版本,继续编译,得到如下信息:

[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Build Order:
[INFO] 
[INFO] OkHttp (Parent)                                                    [pom]
[INFO] OkHttp                                                             [jar]
[INFO] OkHttp test support classes                                        [jar]
[INFO] OkHttp Transport Layer Security (TLS)                              [jar]
[INFO] MockWebServer                                                      [jar]
[INFO] OkHttp URLConnection                                               [jar]
[INFO] OkHttp Logging Interceptor                                         [jar]
[INFO] OkHttp Tests                                                       [jar]
[INFO] OkHttp Android Platform Support                                    [jar]
[INFO] OkHttp Apache HttpClient                                           [jar]
[INFO] OkHttp Server-Sent Events                                          [jar]
[INFO] OkHttp DNS over HTTPS                                              [jar]
[INFO] OkCurl                                                             [jar]
[INFO] Samples (Parent)                                                   [pom]
[INFO] Sample: Guide                                                      [jar]
[INFO] Sample: Crawler                                                    [jar]
[INFO] Sample: Simple Client                                              [jar]
[INFO] Sample: Slack                                                      [jar]
[INFO] Sample: Static Server                                              [jar]
[INFO] Sample: UNIX domain sockets                                        [jar]
[INFO] Benchmarks                                                         [jar]
[INFO] 
[INFO] --------------------< com.squareup.okhttp3:parent >---------------------
[INFO] Building OkHttp (Parent) 3.12.0-SNAPSHOT                          [1/21]
[INFO] --------------------------------[ pom ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ parent ---
[INFO] 
[INFO] --- animal-sniffer-maven-plugin:1.15:check (default) @ parent ---
[INFO] Checking unresolved references to org.codehaus.mojo.signature:java16:1.1
[INFO] 
[INFO] --- maven-checkstyle-plugin:2.17:checkstyle (default) @ parent ---
[INFO] 
[INFO] --- maven-install-plugin:2.4:install (default-install) @ parent ---
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/pom.xml to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/parent/3.12.0-SNAPSHOT/parent-3.12.0-SNAPSHOT.pom
[INFO] 
[INFO] --------------------< com.squareup.okhttp3:okhttp >---------------------
[INFO] Building OkHttp 3.12.0-SNAPSHOT                                   [2/21]
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ okhttp ---
[INFO] 
[INFO] --- templating-maven-plugin:1.0-alpha-3:filter-sources (default) @ okhttp ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO] Source directory: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/generated-sources/java-templates added.
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ okhttp ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 2 resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.6.1:compile (default-compile) @ okhttp ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 101 source files to /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/classes
注: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/src/main/java/okhttp3/OkHttpClient.java使用或覆盖了已过时的 API。
注: 有关详细信息, 请使用 -Xlint:deprecation 重新编译。
注: 某些输入文件使用了未经检查或不安全的操作。
注: 有关详细信息, 请使用 -Xlint:unchecked 重新编译。
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ okhttp ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/src/test/resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.6.1:testCompile (default-testCompile) @ okhttp ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 1 source file to /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/test-classes
[INFO] 
[INFO] --- maven-surefire-plugin:2.21.0:test (default-test) @ okhttp ---
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-junit47/2.21.0/surefire-junit47-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-junit47/2.21.0/surefire-junit47-2.21.0.pom (6.4 kB at 3.6 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-providers/2.21.0/surefire-providers-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-providers/2.21.0/surefire-providers-2.21.0.pom (2.5 kB at 4.0 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit48/2.21.0/common-junit48-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit48/2.21.0/common-junit48-2.21.0.pom (3.3 kB at 7.9 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit4/2.21.0/common-junit4-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit4/2.21.0/common-junit4-2.21.0.pom (2.2 kB at 3.8 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit3/2.21.0/common-junit3-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit3/2.21.0/common-junit3-2.21.0.pom (1.6 kB at 3.8 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-api/2.21.0/surefire-api-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-api/2.21.0/surefire-api-2.21.0.pom (3.5 kB at 5.3 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-logger-api/2.21.0/surefire-logger-api-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-logger-api/2.21.0/surefire-logger-api-2.21.0.pom (2.0 kB at 2.1 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-java5/2.21.0/common-java5-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-java5/2.21.0/common-java5-2.21.0.pom (2.7 kB at 2.7 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/0.9/maven-shared-utils-0.9.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/0.9/maven-shared-utils-0.9.pom (6.2 kB at 10 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-components/21/maven-shared-components-21.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-components/21/maven-shared-components-21.pom (5.1 kB at 6.2 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-parent/25/maven-parent-25.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-parent/25/maven-parent-25.pom (37 kB at 21 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/apache/15/apache-15.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/apache/15/apache-15.pom (15 kB at 18 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-grouper/2.21.0/surefire-grouper-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-grouper/2.21.0/surefire-grouper-2.21.0.pom (2.7 kB at 2.6 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/maven-surefire-common/2.21.0/maven-surefire-common-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/maven-surefire-common/2.21.0/maven-surefire-common-2.21.0.pom (11 kB at 14 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-annotations/3.5/maven-plugin-annotations-3.5.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-annotations/3.5/maven-plugin-annotations-3.5.pom (1.7 kB at 1.7 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-tools/3.5/maven-plugin-tools-3.5.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-tools/3.5/maven-plugin-tools-3.5.pom (16 kB at 16 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-booter/2.21.0/surefire-booter-2.21.0.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-booter/2.21.0/surefire-booter-2.21.0.pom (7.4 kB at 8.5 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-java/0.9.3/plexus-java-0.9.3.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-java/0.9.3/plexus-java-0.9.3.pom (2.4 kB at 3.6 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-languages/0.9.3/plexus-languages-0.9.3.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-languages/0.9.3/plexus-languages-0.9.3.pom (2.2 kB at 2.0 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-junit47/2.21.0/surefire-junit47-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-junit47/2.21.0/surefire-junit47-2.21.0.jar (167 kB at 55 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit48/2.21.0/common-junit48-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit48/2.21.0/common-junit48-2.21.0.jar (22 kB at 53 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit4/2.21.0/common-junit4-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit4/2.21.0/common-junit4-2.21.0.jar (28 kB at 42 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit3/2.21.0/common-junit3-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-junit3/2.21.0/common-junit3-2.21.0.jar (12 kB at 19 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-java5/2.21.0/common-java5-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/common-java5/2.21.0/common-java5-2.21.0.jar (51 kB at 68 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/0.9/maven-shared-utils-0.9.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/0.9/maven-shared-utils-0.9.jar (172 kB at 128 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-grouper/2.21.0/surefire-grouper-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-grouper/2.21.0/surefire-grouper-2.21.0.jar (40 kB at 51 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-api/2.21.0/surefire-api-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-api/2.21.0/surefire-api-2.21.0.jar (185 kB at 127 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-logger-api/2.21.0/surefire-logger-api-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-logger-api/2.21.0/surefire-logger-api-2.21.0.jar (13 kB at 3.5 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/maven-surefire-common/2.21.0/maven-surefire-common-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/maven-surefire-common/2.21.0/maven-surefire-common-2.21.0.jar (521 kB at 52 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-annotations/3.5/maven-plugin-annotations-3.5.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/plugin-tools/maven-plugin-annotations/3.5/maven-plugin-annotations-3.5.jar (14 kB at 20 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-booter/2.21.0/surefire-booter-2.21.0.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/surefire/surefire-booter/2.21.0/surefire-booter-2.21.0.jar (273 kB at 234 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/1.5.15/plexus-utils-1.5.15.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/1.5.15/plexus-utils-1.5.15.jar (228 kB at 219 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-java/0.9.3/plexus-java-0.9.3.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-java/0.9.3/plexus-java-0.9.3.jar (32 kB at 69 kB/s)
[INFO] 
[INFO] --- animal-sniffer-maven-plugin:1.15:check (default) @ okhttp ---
[INFO] Checking unresolved references to org.codehaus.mojo.signature:java16:1.1
[INFO] 
[INFO] --- maven-jar-plugin:3.0.2:jar (default-jar) @ okhttp ---
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-archiver/3.1.1/maven-archiver-3.1.1.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-archiver/3.1.1/maven-archiver-3.1.1.pom (4.3 kB at 3.9 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/3.0.1/maven-shared-utils-3.0.1.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/3.0.1/maven-shared-utils-3.0.1.pom (4.6 kB at 9.2 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/commons-io/commons-io/2.4/commons-io-2.4.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/commons-io/commons-io/2.4/commons-io-2.4.pom (10 kB at 13 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-parent/25/commons-parent-25.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-parent/25/commons-parent-25.pom (48 kB at 46 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.3/plexus-archiver-3.3.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.3/plexus-archiver-3.3.pom (5.3 kB at 7.4 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/3.0.24/plexus-utils-3.0.24.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/3.0.24/plexus-utils-3.0.24.pom (4.1 kB at 5.7 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-io/2.7.1/plexus-io-2.7.1.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-io/2.7.1/plexus-io-2.7.1.pom (4.9 kB at 7.5 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-compress/1.11/commons-compress-1.11.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-compress/1.11/commons-compress-1.11.pom (13 kB at 16 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/iq80/snappy/snappy/0.4/snappy-0.4.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/iq80/snappy/snappy/0.4/snappy-0.4.pom (15 kB at 18 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/tukaani/xz/1.5/xz-1.5.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/tukaani/xz/1.5/xz-1.5.pom (1.9 kB at 2.4 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-interpolation/1.22/plexus-interpolation-1.22.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-interpolation/1.22/plexus-interpolation-1.22.pom (1.5 kB at 2.1 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.4/plexus-archiver-3.4.pom
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.4/plexus-archiver-3.4.pom (5.3 kB at 7.5 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-archiver/3.1.1/maven-archiver-3.1.1.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/maven-archiver/3.1.1/maven-archiver-3.1.1.jar (24 kB at 28 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/3.0.1/maven-shared-utils-3.0.1.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/maven/shared/maven-shared-utils/3.0.1/maven-shared-utils-3.0.1.jar (154 kB at 74 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.4/plexus-archiver-3.4.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-archiver/3.4/plexus-archiver-3.4.jar (187 kB at 149 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-io/2.7.1/plexus-io-2.7.1.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-io/2.7.1/plexus-io-2.7.1.jar (86 kB at 81 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-compress/1.11/commons-compress-1.11.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/apache/commons/commons-compress/1.11/commons-compress-1.11.jar (426 kB at 314 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/iq80/snappy/snappy/0.4/snappy-0.4.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/iq80/snappy/snappy/0.4/snappy-0.4.jar (58 kB at 147 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/tukaani/xz/1.5/xz-1.5.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/tukaani/xz/1.5/xz-1.5.jar (100 kB at 152 kB/s)
[INFO] Downloading from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/3.0.24/plexus-utils-3.0.24.jar
[INFO] Downloaded from : https://repo.maven.apache.org/maven2/org/codehaus/plexus/plexus-utils/3.0.24/plexus-utils-3.0.24.jar (247 kB at 236 kB/s)
[INFO] Building jar: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/okhttp-3.12.0-SNAPSHOT.jar
[INFO] 
[INFO] --- maven-checkstyle-plugin:2.17:checkstyle (default) @ okhttp ---
[INFO] Starting audit...
Audit done.
[WARNING] Unable to locate Source XRef to link to - DISABLED
[INFO] 
[INFO] --- maven-install-plugin:2.4:install (default-install) @ okhttp ---
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/target/okhttp-3.12.0-SNAPSHOT.jar to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/okhttp/3.12.0-SNAPSHOT/okhttp-3.12.0-SNAPSHOT.jar
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp/pom.xml to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/okhttp/3.12.0-SNAPSHOT/okhttp-3.12.0-SNAPSHOT.pom
[INFO] 
[INFO] ------------< com.squareup.okhttp3:okhttp-testing-support >-------------
[INFO] Building OkHttp test support classes 3.12.0-SNAPSHOT              [3/21]
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ okhttp-testing-support ---
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ okhttp-testing-support ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/src/main/resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.6.1:compile (default-compile) @ okhttp-testing-support ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 7 source files to /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/target/classes
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ okhttp-testing-support ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/src/test/resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.6.1:testCompile (default-testCompile) @ okhttp-testing-support ---
[INFO] No sources to compile
[INFO] 
[INFO] --- maven-surefire-plugin:2.21.0:test (default-test) @ okhttp-testing-support ---
[INFO] No tests to run.
[INFO] 
[INFO] --- animal-sniffer-maven-plugin:1.15:check (default) @ okhttp-testing-support ---
[INFO] Checking unresolved references to org.codehaus.mojo.signature:java16:1.1
[INFO] 
[INFO] --- maven-jar-plugin:3.0.2:jar (default-jar) @ okhttp-testing-support ---
[INFO] Building jar: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/target/okhttp-testing-support-3.12.0-SNAPSHOT.jar
[INFO] 
[INFO] --- maven-checkstyle-plugin:2.17:checkstyle (default) @ okhttp-testing-support ---
[INFO] Starting audit...
Audit done.
[WARNING] Unable to locate Source XRef to link to - DISABLED
[INFO] 
[INFO] --- maven-install-plugin:2.4:install (default-install) @ okhttp-testing-support ---
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/target/okhttp-testing-support-3.12.0-SNAPSHOT.jar to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/okhttp-testing-support/3.12.0-SNAPSHOT/okhttp-testing-support-3.12.0-SNAPSHOT.jar
[INFO] Installing /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-testing-support/pom.xml to /Users/wangguoqiang/.m2/repository/com/squareup/okhttp3/okhttp-testing-support/3.12.0-SNAPSHOT/okhttp-testing-support-3.12.0-SNAPSHOT.pom
[INFO] 
[INFO] ------------------< com.squareup.okhttp3:okhttp-tls >-------------------
[INFO] Building OkHttp Transport Layer Security (TLS) 3.12.0-SNAPSHOT    [4/21]
[INFO] --------------------------------[ jar ]---------------------------------
[INFO] 
[INFO] --- maven-enforcer-plugin:1.0:enforce (enforce-maven) @ okhttp-tls ---
[INFO] 
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ okhttp-tls ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-tls/src/main/resources
[INFO] 
[INFO] --- maven-compiler-plugin:3.6.1:compile (default-compile) @ okhttp-tls ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 3 source files to /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-tls/target/classes
/Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-tls/src/main/java/okhttp3/tls/HeldCertificate.java:425: 错误: [InsecureCryptoUsage] Insecure usage of a crypto API: the algorithm specification is not a compile-time constant expression.
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(keyAlgorithm, "BC");
                                                                        ^
    (see http://errorprone.info/bugpattern/InsecureCryptoUsage)
注: /Users/wangguoqiang/othercode/openproject/okhttp/okhttp/okhttp-tls/src/main/java/okhttp3/tls/HeldCertificate.java使用或覆盖了已过时的 API。
注: 有关详细信息, 请使用 -Xlint:deprecation 重新编译。
1 个错误
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO] 
[INFO] OkHttp (Parent) 3.12.0-SNAPSHOT .................... SUCCESS [  1.629 s]
[INFO] OkHttp ............................................. SUCCESS [01:11 min]
[INFO] OkHttp test support classes ........................ SUCCESS [  0.930 s]
[INFO] OkHttp Transport Layer Security (TLS) .............. FAILURE [  0.386 s]
[INFO] MockWebServer ...................................... SKIPPED
[INFO] OkHttp URLConnection ............................... SKIPPED
[INFO] OkHttp Logging Interceptor ......................... SKIPPED
[INFO] OkHttp Tests ....................................... SKIPPED
[INFO] OkHttp Android Platform Support .................... SKIPPED
[INFO] OkHttp Apache HttpClient ........................... SKIPPED
[INFO] OkHttp Server-Sent Events .......................... SKIPPED
[INFO] OkHttp DNS over HTTPS .............................. SKIPPED
[INFO] OkCurl ............................................. SKIPPED
[INFO] Samples (Parent) ................................... SKIPPED
[INFO] Sample: Guide ...................................... SKIPPED
[INFO] Sample: Crawler .................................... SKIPPED
[INFO] Sample: Simple Client .............................. SKIPPED
[INFO] Sample: Slack ...................................... SKIPPED
[INFO] Sample: Static Server .............................. SKIPPED
[INFO] Sample: UNIX domain sockets ........................ SKIPPED
[INFO] Benchmarks 3.12.0-SNAPSHOT ......................... SKIPPED
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 01:14 min
[INFO] Finished at: 2018-08-28T16:39:09+08:00
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.6.1:compile (default-compile) on project okhttp-tls: Compilation failure -> [Help 1]
[ERROR] 
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR] 
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException
[ERROR] 
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR]   mvn <goals> -rf :okhttp-tls

得到如下错误信息:

终于不是环境的问题,是代码有问题,应该是和旧插件兼容性有问题,根据提示,修改下代码,指定使用常量,修改的含义为,指定使用ECDSA进行公私钥生成

然后屏掉RSA算法的相关测试:

重新编译,终于成功了,获得了各个源码所编译得到的jar文件。

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值