⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sqlforwarder.java

📁 第三方的SQL Server and Sybase的jdbc dirver,速度更快
💻 JAVA
字号:
package net.sourceforge.jtds.tools;import java.io.IOException;import java.io.InputStream;import java.io.OutputStream;import java.net.ServerSocket;import java.net.Socket;public class SqlForwarder {    String host = "localhost";    String logfile = null;    int port = 1433;    int listenPort = 1444;    int lognum = 0;    byte[] readPacket(InputStream input) throws IOException {        byte[] hdr = new byte[8];        int len = input.read(hdr);        if (len < 8) {            return null;        }        int packetlen = ((((int) hdr[2]) & 0xff) << 8) + (((int) hdr[3]) & 0xff);        byte[] data = new byte[packetlen];        while (len < packetlen) {            len += input.read(data, len, packetlen - len);        }        for (int i = 0; i < 8; i++) {            data[i] = hdr[i];        }        return data;    }    class ConnectionThread extends Thread {        Socket client;        Socket server;        ConnectionThread(Socket client, Socket server) {            this.client = client;            this.server = server;        }        public void run() {            try {                InputStream input[] = new InputStream[2];                input[0] = client.getInputStream();                input[1] = server.getInputStream();                OutputStream output[] = new OutputStream[2];                output[0] = server.getOutputStream();                output[1] = client.getOutputStream();                PacketLogger log;                if (logfile == null) {                    log = new PacketLogger("filter" + lognum++ + ".log");                } else {                    log = new PacketLogger(logfile + lognum++ + ".log");                }                int direction = 0;                while (true) {                    byte[] data = readPacket(input[direction]);                    if (data == null) {                        break;                    }                    output[direction].write(data);                    log.log(data);                    if (data[1] != 0) {                        direction = 1 - direction;                    }                }                client.close();                server.close();            } catch (IOException unused) {            }        }    }    SqlForwarder() {    }    void run() throws IOException {        System.out.println("Listening on port " + listenPort + "; Connecting to " + host + " at port " + port);        ServerSocket srv = new ServerSocket(listenPort);        while (true) {            Socket client = srv.accept();            Socket server = new Socket(host, port);            ConnectionThread t = new ConnectionThread(client, server);            t.start();        }    }    void parseArgs(String args[]) throws NumberFormatException {        for (int i = 0; i < args.length; i++) {            String arg = args[i];            if (arg.equals("-server")) {                i++;                host = args[i];            } else if (arg.equals("-port")) {                i++;                port = Integer.parseInt(args[i]);            } else if (arg.equals("-listen")) {                i++;                listenPort = Integer.parseInt(args[i]);            } else if (arg.equals("-log")) {                i++;                logfile = args[i];            }        }    }    public static void main(String args[])            throws IOException {        SqlForwarder app = new SqlForwarder();        app.parseArgs(args);        app.run();    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -