gpt4 book ai didi

ssl - 使sslmode = verify-ca后无法验证主机名

转载 作者:太空宇宙 更新时间:2023-11-03 14:23:07 26 4
gpt4 key购买 nike

我尝试连接我的RDS实例,但我不希望SSL证书检查主机名。
到目前为止,我知道使sslmode = verify-ca不会检查主机名,但是出于某种原因。以下是堆栈跟踪,以获取更多详细信息

十一月20,2019 6:06:11 PM org.postgresql.Driver连接
严重:连接错误:
org.postgresql.util.PSQLException:无法验证主机名。
        在org.postgresql.ssl.MakeSSL.convert(MakeSSL.java:93)
        在org.postgresql.core.v3.ConnectionFactoryImpl.enableSSL(ConnectionFactoryImpl.java:391)
        在org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:162)
        在org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:49)
        在org.postgresql.jdbc.PgConnection。(PgConnection.java:195)
        在org.postgresql.Driver.makeConnection(Driver.java:452)
        在org.postgresql.Driver.connect(Driver.java:254)
        在amazon.jdbc.driver.spi.PostgresqlConnectionProvider.getConnection(PostgresqlConnectionProvider.java:85)
        在amazon.cj.dbaccess.FallbackWorker.iteratePasswordStore(FallbackWorker.java:101)
        在amazon.cj.dbaccess.FallbackWorker.getConnection(FallbackWorker.java:59)
        在amazon.cj.dbaccess.CacheController.getConnection(CacheController.java:153)
        在amazon.jdbc.driver.SecureDriver.connect(SecureDriver.java:174)
        在org.apache.tomcat.jdbc.pool.PooledConnection.connectUsingDriver(PooledConnection.java:307)
        在org.apache.tomcat.jdbc.pool.PooledConnection.connect(PooledConnection.java:200)
        在org.apache.tomcat.jdbc.pool.ConnectionPool.createConnection(ConnectionPool.java:728)
        在org.apache.tomcat.jdbc.pool.ConnectionPool.borrowConnection(ConnectionPool.java:662)
        在org.apache.tomcat.jdbc.pool.ConnectionPool.init(ConnectionPool.java:480)
        在org.apache.tomcat.jdbc.pool.ConnectionPool。(ConnectionPool.java:154)
        在org.apache.tomcat.jdbc.pool.DataSourceProxy.pCreatePool(DataSourceProxy.java:115)
        在org.apache.tomcat.jdbc.pool.DataSourceProxy.createPool(DataSourceProxy.java:102)
        在org.apache.tomcat.jdbc.pool.DataSourceFactory.createDataSource(DataSourceFactory.java:559)
        在org.apache.tomcat.jdbc.pool.DataSourceFactory.getObjectInstance(DataSourceFactory.java:244)
        在org.apache.naming.factory.FactoryBase.getObjectInstance(FactoryBase.java:94)
        在javax.naming.spi.NamingManager.getObjectInstance(NamingManager.java:321)
        在org.apache.naming.NamingContext.lookup(NamingContext.java:848)
        在org.apache.naming.NamingContext.lookup(NamingContext.java:158)
        在org.apache.naming.NamingContext.lookup(NamingContext.java:835)
        在org.apache.naming.NamingContext.lookup(NamingContext.java:172)
        在org.apache.catalina.core.NamingContextListener.addResource(NamingContextListener.java:1091)
        在org.apache.catalina.core.NamingContextListener.createNamingContext(NamingContextListener.java:670)
        在org.apache.catalina.core.NamingContextListener.lifecycleEvent(NamingContextListener.java:258)
        在org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:95)
        在org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
        在org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5213)
        在org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145)
        在org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:753)
        在org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:729)
        在org.apache.catalina.core.StandardHost.addChild(StandardHost.java:717)
        在org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:976)
        在org.apache.catalina.startup.HostConfig $ DeployWar.run(HostConfig.java:1853)
        在java.util.concurrent.Executors $ RunnableAdapter.call(Executors.java:511)
        在java.util.concurrent.FutureTask.run(FutureTask.java:266)
        在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
        在java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:624)
        在java.lang.Thread.run(Thread.java:748)

数据库登录失败url:jdbc:postgresql://:8194 / fa_rhythm_db_dev?ssl = true; sslmode = verify-ca; sslrootcert = / apollo / env / RhythmTomcatBase / certs / rds-combined-ca-bundle.pem moduleName:null properties :{sslrootcert = / apollo / env / RhythmTomcatBase / certs / rds-combined-ca-bundle.pem} @ driver:class amazon.jdbc.driver.SecureDriver url:jdbc:amazon:postgresql:// hostname:8194 / fa_rhythm_db_dev? ssl = true; sslmode = verify-ca; sslrootcert = / apollo / env / RhythmTomcatBase / certs / rds-combined-ca-bundle.pem数据库:fa_rhythm用户:pega模块:空属性:{}

最佳答案

如果将参数sslmode设置为verify-ca,libpq将通过检查证书链直至受信任的证书颁发机构(CA)来验证服务器是否可信任。如果sslmode设置为verifyfull,libpq还将验证服务器主机名是否与其证书匹配。如果无法验证服务器证书,则SSL连接将失败。建议在大多数对安全性敏感的环境中使用“完全验证”。


documentation

如果您明确知道要连接到正确的主机并信任所述主机,则可以使用sslmode=require

关于ssl - 使sslmode = verify-ca后无法验证主机名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58968202/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com