开发者

Java proxies connection to postgres

开发者 https://www.devze.com 2023-01-10 12:28 出处:网络
Could someo开发者_StackOverflowne help me or suggest a solution? I want to connect from a computer that has firewall to other where the postgres server run. The problem is that computer (client) has a

Could someo开发者_StackOverflowne help me or suggest a solution? I want to connect from a computer that has firewall to other where the postgres server run. The problem is that computer (client) has a firewall and I don't have access to configure it, or open ports, ping does not respond. The computer (server) where PostgreSQL has open ports but I cannot connect to it from another because of a firewall. I can only access the computer through proxy.

How I could with Java programming access remotely through proxy to postgres forgetting firewall?

Java has a connection with proxies. But I don't know how to put it together with postgres connection.

        System.getProperties().put( "proxySet", "true" );
        System.getProperties().put( "proxyHost", "67.210.82.198" );
        System.getProperties().put( "proxyPort", "80" );

        URL validateURL = new URL("http://domain.com");
        URLConnection urlConnection = validateURL.openConnection();

        //how put together ???

        Class.forName("org.postgresql.Driver");
        Connection connection =  DriverManager.getConnection("jdbc:postgresql://ipPublica:5432/DataBase","user", "pass"); 


That can't be done. PostgreSQL connections are not HTTP connections. Yo cannot use an HTTP proxy for PostgreSQL. Maybe a socks proxy will do the work.


Try

System.setProperty("http.proxyHost", "67.210.82.198");
System.setPropery("http.proxyPort", "80");

String url = "jdbc:postgresql://host:port/database";
Properties props = new Properties();
props.setProperty("user","myUsername");
props.setProperty("password","myPassword");
props.setProperty("ssl","true");

Class.forName("org.postgresql.Driver");
Connection conn = DriverManager.getConnection(url, props);

For more, see java networking & proxies.


This question is quite old. It also has been asked on the PostgreSQL mailing list:

http://archives.postgresql.org/pgsql-jdbc/2010-08/msg00021.php

The answers over there boils down to:

  • Use SOCKs

  • If (big IF!) you want to hack the JDBC driver source, you might (big "might"!) be able to make it work over a HTTP-Proxy using SSL.

  • Sidekick: Someone proposed an ssh tunnel.


You'll need a SOCKS proxy, rather than a HTTP proxy.

Then your code will look something like this:

System.setProperty("socksProxyHost", host);
System.setProperty("socksProxyPort", "1080");

Details: http://docs.oracle.com/javase/7/docs/technotes/guides/net/proxies.html

0

精彩评论

暂无评论...
验证码 换一张
取 消