java jdbc使用SSH隧道连接mysql数据库demo

原文地址: https://blog.csdn.net/earbao/article/details/50216999,session.setPortForwardingL稍有改动
  1. import com.jcraft.jsch.JSch;  
  2. import com.jcraft.jsch.Session;  
  3.   
  4. import java.sql.*;  
  5.   
  6. //http://my.oschina.net/Thinkeryjgfn/blog/177283  
  7. //http://www.cnblogs.com/I-will-be-different/p/3925351.html?utm_source=tuicool&utm_medium=referral  
  8. //java jdbc使用SSH隧道连接mysql数据库demo  
  9. public class ChangeDB {  
  10.   
  11.   
  12.   
  13.     public static void go() {  
  14.         try {  
  15.             JSch jsch = new JSch();  
  16.             Session session = jsch.getSession("yunshouhu""192.168.0.102"22);  
  17.             session.setPassword("xxxx");  
  18.             session.setConfig("StrictHostKeyChecking""no");  
  19.             session.connect();  
  20.             System.out.println(session.getServerVersion());//这里打印SSH服务器版本信息  
  21.   
  22.             //ssh -L 192.168.0.102:5555:192.168.0.101:3306 yunshouhu@192.168.0.102  正向代理  
  23.            int assinged_port = session.setPortForwardingL((3306, mysqlurl, 3306);//端口映射 转发  数据库服务器地址url
  24.   
  25.            System.out.println("localhost:" + assinged_port);  
  26.   
  27.             //ssh -R 192.168.0.102:5555:192.168.0.101:3306 yunshouhu@192.168.0.102  
  28.             //session.setPortForwardingR("192.168.0.102",5555, "192.168.0.101", 3306);  
  29.            // System.out.println("localhost:  -> ");  
  30.         } catch (Exception e) {  
  31.             e.printStackTrace();  
  32.         }  
  33.     }  
  34.   
  35.   
  36.   
  37.     public static void main(String[] args) {  
  38.   
  39.   
  40.         try {  
  41.             //1、加载驱动  
  42.             Class.forName("com.mysql.jdbc.Driver");  
  43.         } catch (ClassNotFoundException e) {  
  44.             e.printStackTrace();  
  45.         }  
  46.         //2、创建连接  
  47.         Connection conn = null;  
  48.         Connection conn2 = null;  
  49.         try {  
  50.   
  51.             conn2 = DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql""hadoop""xxxx");  
  52.             getData(conn2);  
  53.         } catch (SQLException e) {  
  54.             System.out.println("未连接上数据库");  
  55.             e.printStackTrace();  
  56.         }  
  57.   
  58.         try{  
  59.             System.out.println("=============");  
  60.             go();  
  61.             conn = DriverManager.getConnection("jdbc:mysql://192.168.0.101:5555/mysql""hadoop""xxx");  
  62.             getData(conn);  
  63.   
  64.   
  65.         } catch (SQLException e) {  
  66.             e.printStackTrace();  
  67.         }  
  68.   
  69.   
  70.   
  71.     }  
  72.   
  73.     private static void getData(Connection conn) throws SQLException {  
  74.   
  75.         // 获取所有表名  
  76.         Statement statement = conn.createStatement();  
  77.         ResultSet resultSet = statement  
  78.                 .executeQuery("select * from help_keyword");  
  79.         // 获取列名  
  80.         ResultSetMetaData metaData = resultSet.getMetaData();  
  81.         for (int i = 0; i < metaData.getColumnCount(); i++) {  
  82.             // resultSet数据下标从1开始  
  83.             String columnName = metaData.getColumnName(i + 1);  
  84.             int type = metaData.getColumnType(i + 1);  
  85.             if (Types.INTEGER == type) {  
  86.                 // int  
  87.             } else if (Types.VARCHAR == type) {  
  88.                 // String  
  89.             }  
  90.             System.out.print(columnName + "\t");  
  91.         }  
  92.         System.out.println();  
  93.         // 获取数据  
  94.         while (resultSet.next()) {  
  95.             for (int i = 0; i < metaData.getColumnCount(); i++) {  
  96.                 // resultSet数据下标从1开始  
  97.                 System.out.print(resultSet.getString(i + 1) + "\t");  
  98.             }  
  99.             System.out.println();  
  100.   
  101.         }  
  102.         statement.close();  
  103.         conn.close();  
  104.     }  
  105.   
  106. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值