SAS/CONNECT Driver 9.1.3 for Java |
A SAS/CONNECT driver for Java program communicates with the SAS/CONNECT server using a connection daemon (either the SAS spawner program or a telnet daemon). A tunneled SAS/CONNECT driver for Java program communicates with the tunnel feature's server programs, which in turn communicate with the SAS/CONNECT server using either the spawner program or a telnet daemon. This page describes the types of connection objects you can use, how to construct a connection object, and other topics related to managing the connection to a remote SAS server.
The SAS/CONNECT driver for Java class you use to construct the connection object depends on whether your program uses HTTP tunneling or the SAS/CONNECT protocol. For HTTP tunneling, you will use the TunneledConnectClient class to create the connection object. Otherwise, you will use the TelnetConnectClient class to create the connection object.
Connection objects are constructed using a set of properties that specify information that is required by the connection daemon. The properties represent the prompts and responses that are passed when the connection is established. The connection object waits for certain prompts from the connection daemon (or from the tunnel feature's server programs) and then responds. The properties are set from the values in a Properties object that is passed as an argument to the constructor of the connection object class you use.
For TelnetConnectClient and TunneledConnectClient, you must specify at least one property. If the property list is null, an exception is returned. The connection properties that you can specify for TelnetConnectClient and TunneledConnectClient objects are as follows:
response1
for the username and response2
for the password, you would specify response1
as the value for the userNameResponse property and response2
as the value for the passwordResponse property.
For non-tunneled programs, you need to use the userNameResponse and passwordResponse properties only if you want the program to prompt for the username and password. If you want to specify the username and password as values for responsex properties instead of having the user enter the information, do not use the userNameResponse and passwordResponse properties.
For tunneled programs, the userNameResponse and passwordResponse properties specify which responses are the username and password so the responses can be encrypted before they are sent to the tunnel feature's server programs. If you do not use the userNameResponse and passwordResponse properties, the username and password will not be encrypted when they are sent to the server.
The prompt/response pairs required for a successful connection may differ depending on the connection daemon you are using. Typically, you need only create three prompt/response pairs to pass the username, password, and command information, but you can create additional parameters to pass prompts and responses that your connection daemon requires. For further explanation of how the prompt/response properties relate to the connection information that is passed when manually establishing a connection, see Connection Properties and Telnet Connection Information.
Connection objects that use HTTP tunneling use the routerUrl property, which enables the Web server to locate the Message Router (shrcgi.exe
), one of the tunnel feature's server programs.
Note: The routerUrl property applies to TunneledConnectClient objects only.
shrcgi.exe
).To determine whether the connection process is continuing properly, the connection client allows a certain amount of time to pass waiting for a particular prompt. If the prompt is not received within the allotted time, the connection client assumes an error has occurred and throws a ConnectException. The connection client supports properties that enable a user to override the default timeout values. You can create as many Timeout properties as you need.
Note: Timeout properties apply only to TelnetConnectClient objects.
When communicating with a SAS server that is running the SAS System, Version 7 or later, messages passed to and received from both the SAS Spawner and the SAS/CONNECT Server can be encrypted using a variety of encryption algorithms. The tunnel feature server programs do not support this level of encryption. The only supported encryption in the tunnel server programs is to encrypt username and password.
Two properties control most of the encryption features in the SAS/CONNECT Driver for Java.
none
, then the connection client will not attempt to negotiate and use an encryption algorithm with the server. If the server requires encryption to be used, then the connection will fail. This is the default value. If the value of this property is optional
, then the connection client will attempt to negotiate and use an encryption algorithm with the server. If the negotiations fail, then the connection client will try to continue with an unencrypted connection. However, that will also fail if the server requires encryption. If the value of this property is required
, then the connection client will attempt to negotiate and use an encryption algorithm with the server. If the negotiations fail, then the connection fails.
sasproprietary
, a stream cipher developed at SAS Institute, RC2
, a block cipher developed by RSA Data Security, RC4
, a stream cipher developed by RSA Data Security, des
, a block cipher known as Data Encryption Standard, and TRIPLEDES
, DES applied three times with separate keys. To use RC2
, RC4
, DES
, or TRIPLEDES
, you must license SAS/SECURE on the server and install the Java component of SAS/SECURE (sasecjav.zip) in your code base. TRIPLEDES
can generally only be used in the United States and Canada due to export restrictions.
Because encryption is supported for connections to both the SAS Spawner and the SAS/CONNECT server, a property is sometimes needed to determine whether or not the encryption properties listed above apply to the telnet session or the SAS/CONNECT session. This property is named encryptionTarget. Its possible values are:
If the SAS Spawner was started with the -INHERITANCE option, then, in effect, the only possible value for this property is both
. Therefore, this property is ignored when the -INHERITANCE option is used.
The SAS Server and SAS Spawner both require similar properties to control encryption. These properties can be specified as command line options when starting the SAS Spawner or when specifying the responsex property that corresponds to the SAS command for TelnetConnectClient.
You may also want to use the following properties.
If you do not specify a value for this property, the default character encoding of the Java virtual machine is used. If the specified character encoding cannot be supported by the Java virtual machine, then the SAS/CONNECT Driver for Java throws an exception the first time it attempts a character conversion.
Notes:
Support for the Cp1047 code page is built into the SAS/CONNECT driver for Java because many current Java virtual machines do not provide support for this common character encoding.
If you use the textTransportFormat property, you may need to reconfigure your SAS/CONNECT server as well.
The SAS/SHARE driver for JDBC, which is included with the SAS/CONNECT driver for Java, transcodes character data, column names, column descriptions, and format names from this encoding when processing an SQL query.
TRUE
and FALSE
. The default behavior is FALSE, which does not attempt to determine if an error condition exists.An applet passes connection information through parameters, using the following format:
<param name=promptx value="prompt"> <param name=responsex value="response"> <param name=userNameResponse value="response1"> <param name=passwordResponse value="response2"> <param name=sasPortTag value="port_tag">
Where x is any number, and prompt
and
response
are the values associated with the prompt and connection information you want to pass, respectively. The userNameResponse and passwordResponse parameters are as described above. port_tag
uniquely identifies that the SAS session has completed initialization and allows the connection client to parse the port value from the response.
Note: You will use the getParameter method to pick up these values. Then, you construct a new Properties object and put
these values into the object.
Tunneling information is passed through a parameter using the following format:
<param name=routerURLx value="http://your_server/cgi-bin/shrcgi">
Where http://your_server/cgi-bin/shrcgi is a URL that corresponds to the location of the tunnel feature's server programs.
Timeout information is passed through parameters, using the following format:
<param name=promptTimeoutx value="nnn"> <param name=responseTimeoutx value="nnn"> <param name=sasPortTagTimeout value="nnn">
Where x is a number that corresponds to the prompt or response you want to time, and nnn is the number of seconds you want the connection client to wait.
If you want to use SAS/CONNECT protocol, instantiate the connection object using the TelnetConnectClient constructor, as follows:
import com.sas.net.connect.TelnetConnectClient; TelnetConnectClient tconnection = new TelnetConnectClient(info);
If you want to use HTTP tunneling, instantiate the connection object using the TunneledConnectClient constructor as follows:
import com.sas.net.connect.TunneledConnectClient; info.put("routerUrl","http://your_server/cgi-bin/shrcgi"); TunneledConnectClient tconnection = new TunneledConnectClient(info);
The TunneledConnectClient sends a request to the tunnel feature's server programs to start a SAS/CONNECT session and return the port number for communication with the Java client. Then, it passes connection properties to the Message Router.
The session ends differently depending on whether your using SAS/CONNECT protocol or HTTP tunneling.
If you're using SAS/CONNECT protocol, the connection client class (TelnetConnectClient) overrides the base class disconnect method, so it can destroy the telnet or spawner session in addition to ending the remote SAS session. The class first calls the base class disconnect method, which sends a shutdown message to SAS and receives a response that the SAS session has successfully shut down. The subclass disconnect method then closes the socket connection to the telnet or spawner session, which effectively ends the telnet or spawner session. The telnet or spawner session cannot be destroyed prior to ending the SAS session. The SAS session is started as a subprocess of the telnet or spawner session, and ending the telnet or spawner session prematurely will end the SAS session.
If you're using HTTP tunneling, the base class disconnect method requests that the tunnel feature's server programs end the remote SAS session. When the base class disconnect method is called, a shutdown message is sent to the SAS session and a response is returned indicating that the SAS session has successfully shut down. Then, the tunnel feature's server programs end the telnet or spawner session. The telnet or spawner session cannot be destroyed prior to ending the SAS session. The SAS session is started as a subprocess of the telnet or spawner session, and ending the telnet or spawner session prematurely will end the SAS session.
SAS/CONNECT Driver 9.1.3 for Java |