org.firebirdsql.gds.impl.wire.JavaGDSImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird-jdk17 Show documentation
Show all versions of jaybird-jdk17 Show documentation
JDBC Driver for the Firebird RDBMS
package org.firebirdsql.gds.impl.wire;
import java.io.IOException;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.ArrayList;
/**
* Implements JDK1.4+ specific socket creation.
*
* This is necessary because of a bug found in the JDK1.4 and is / will not be
* fixed until JDK7.0.
*
* See bug details:
* http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=5092063
*
* @author Steve Jardine
*/
public class JavaGDSImpl extends AbstractJavaGDSImpl {
/*
* (non-Javadoc)
*
* @see org.firebirdsql.gds.impl.wire.AbstractJavaGDSImpl#getSocket(java.lang.String,
* int)
*/
protected Socket getSocket(String server, int port) throws IOException,
UnknownHostException {
// Check for a valid ip address.
byte[] address = parseRawAddress(server);
// Create the socket using an instance of the InetAddress class if the
// ip address is a valid IPV4 or IPV6 address
if (address != null && address.length != 0)
return new Socket(InetAddress.getByAddress(address), port);
else
return new Socket(server, port);
}
/**
* Parses a string representation of a raw ip address. Only 4 byte (IPv4) or
* 16 byte (IPv6) are acceptable.
*
* @param server
* a string representation of the host server.
* @return a byte array representing the ip address
*/
public static byte[] parseRawAddress(String server) {
ArrayList result = new ArrayList();
String[] bytes = server.split("\\.|:");
try {
// Only 4 byte (IPv4) and 16 byte (IPv6) addresses are acceptable.
if (bytes.length == 4 ) {
// convert each string into a byte. If the string doesn't isn't in
// the range of 0 .. 255 return null.
for (int index = 0; index < bytes.length; index++) {
int value = Integer.parseInt(bytes[index]);
if (value >= 0 && value <= 255)
result.add((byte) value);
else
return null;
}
} else
if (bytes.length == 16 || bytes.length == 8) {
// convert each string into a byte. If the string doesn't isn't in
// the range of 0 .. 255 return null.
for (int index = 0; index < bytes.length; index++) {
bytes[index] = prependZeros(bytes[index], 4);
String hi = bytes[index].substring(0, 2);
String lo = bytes[index].substring(2);
int hiValue = Integer.parseInt(hi, 16);
int loValue = Integer.parseInt(lo, 16);
if (hiValue == -1 || loValue == -1)
return null;
result.add((byte)hiValue);
result.add((byte)loValue);
}
} else
return null;
} catch(NumberFormatException ex) {
return null;
}
byte[] address = new byte[result.size()];
for(int i = 0 ; i < result.size(); i++)
address[i] = result.get(i);
return address;
}
private static String prependZeros(String s, int totalLength) {
s= "000000000000"+s; // twelve zeros prepended
return s.substring(s.length()-totalLength); // keep the rightmost 13 chars
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy