Java
Sisukord
Sissejuhatus
Siin palas ei tule juttu mitte Tsehhis toodetud mootorrattast vaid ühest keelest.
- JRE: Java Runtime Environment. Tegemist on java virtuaalmasinaga kus java programmid töötavad. Ühtlasi sisaldab see browseri pluginat ja appleti käivitamist.
- JDK: Täielik tarkvara arenduskomplekt javale, sisaldades ühtlasi ka jre-d, kompilaarorit ja töövahendeid (näiteks JavaDoc, Java Debugger) selleks, et luua ja kompileerida programme.
Java paigaldamine
Esiteks on olemas Oracle JDK ja Open JDK
- Oracle (varasemalt Sun) JDK, suletud koodiga java, koos kommertsiaalse toega oracle enda asjadele.
- OpenJDK, avatud koodiga java. Oracle poolt vabaks antud osa koodist.
Java kasutamine
Lähtetekst
$ cat HelloWorld.java
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello, World");
}
}
Kompileerimine, tekib fail HelloWorld.class
$ javac HelloWorld.java
Käivitamine
$ java HelloWorld Hello, World
Java paketid
$ find . -ls 8212 4 drwxr-xr-x 3 root root 4096 Apr 8 11:27 . 8214 4 drwxr-xr-x 2 root root 4096 Apr 8 11:27 ./ee/tartu/loomaaed 8217 4 -rw-r--r-- 1 root root 127 Apr 8 11:24 ./ee/tartu/loomaaed/HelloWorld.java 8219 4 -rw-r--r-- 1 root root 428 Apr 8 11:27 ./ee/tartu/loomaaed/HelloWorld.class
Kompileerimiseks
$ javac ee/tartu/loomaaed/HelloWorld.java
Käivitamiseks
$ java ee.tartu.loomaaed.HelloWorld Hello World
Klassid
package ee.tartu.loomaaed;
public class HelloWorld {
public static void main(String[] args) {
arvutaja arvuti = new arvutaja();
int summa = arvuti.liitja(4,3);
int vahe = arvuti.lahutaja(4,3);
System.out.println(summa);
System.out.println(vahe);
}
}
class arvutaja {
public int liitja(int a, int b) {
return a + b;
}
public int lahutaja(int a, int b) {
return a - b;
}
}
kus
- class arvutaja { ... } - klass, milles on kirjeldatud kaks funktsiooni, ehk õigemini meetodit, liitja ja lahutaja
- arvutaja arvuti = new arvutaja(); - moodustatakse arvutaja alusel uus objekt nimega arvuti
- arvuti.liitja(4,3); - kasutatajase objekti arvuti meetodit liitja argumentidega 4 ja 3
Kompileerimine ja kasutamine toimub nagu eelmisel juhul.
Ühendus Oracle andmebaasiga
Nt Oracle andmebaasiga suhtlemiseks on vajalik draiver ojdbc14.jar (v. 10.2) või ojdbc6.jar (v. 11.2)
$ cat HelloOracle.java
import java.sql.*;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.net.*;
public class HelloOracle
{
public static void main(String args[]) throws SQLException {
Connection con = null;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
con = DriverManager.getConnection("jdbc:oracle:thin:@192.168.13.64:1521:loom", \
"mart", "mardiparool");
Statement st = con.createStatement();
ResultSet rs = st.executeQuery("select BANNER from SYS.V_$VERSION");
while(rs.next()) {
System.out.println(rs.getString(1));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if(con != null) {
con.close();
}
}
}
}
kus
- loom - oracle baasi SID
Kompileerimiseks
$ export CLASSPATH=ojdbc14.jar:. $ javac HelloOracle.java
ja käivitamiseks
$ java HelloOracle
Kasulikud lisamaterjalid
Ühendus PostgreSQL andmebaasiga
$ cat HelloPostgresql.java
import java.sql.*;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.net.*;
public class HelloPostgresql
{
public static void main(String args[]) throws SQLException {
Connection con = null;
try {
Class.forName("org.postgresql.Driver");
con = DriverManager.getConnection("jdbc:postgresql://127.0.0.1/test", "priit", "parool");
Statement st = con.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM priit.inimene");
while(rs.next()) {
System.out.println(rs.getString("nimi"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if(con != null) {
con.close();
}
}
}
}
Kompileerimiseks
$ export CLASSPATH=postgresql-8.4-701.jdbc3.jar:. $ javac HelloPostgresql.java
Käivitamiseks
$ java HelloPostgresql
Ühendus MySQL andmebaasiga
Kopeerida draiver aadressilt http://dev.mysql.com/downloads/connector/j/
$ tar zxf mysql-connector-java-5.1.12.tar.gz
Näiteks selline programm esitab andmebaasi test tabeli inimene tulba nimi väärtused
$ cat HelloMySQL.java
import java.sql.*;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.net.*;
public class HelloMySQL
{
public static void main(String args[]) throws SQLException {
Connection con = null;
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
con = DriverManager.getConnection("jdbc:mysql://127.0.0.1/baasinimi?" + \
"user=kasutajanimi& password=parool");
Statement st = con.createStatement();
ResultSet rs = st.executeQuery("SELECT * FROM inimene");
while(rs.next()) {
System.out.println(rs.getString("nimi"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if(con != null) {
con.close();
}
}
}
}
Kompileerimiseks
$ export CLASSPATH=mysql-connector-java-5.1.12-bin.jar:. $ javac HelloMySQL.java
Käivitamiseks
$ java HelloMySQL
SMTP
Plaintext
Selleks, et saata läbi postirelee välja kirja sobib kasutada JavaMail API't http://java.sun.com/products/javamail/, mis tuleb kopeerida ja lahti pakkida sobivasse kataloogi, nt /opt/javamail. Praktiliselt on vajalik kasutada sealt arhiivist ainult mail.jar teeki.
import java.util.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;
// Send a simple, single part, text/plain e-mail
public class Kirjasaatja {
public static void main(String[] args) {
String to = "mart@loomaaed.tartu.ee";
String from = "priit@loomaaed.tartu.ee";
// meilirelee aadress
String host = "192.168.1.250";
Properties props = new Properties();
props.put("mail.smtp.host", host);
// debugimise sisselülitamine
props.put("mail.debug", "false");
Session session = Session.getInstance(props);
try {
Message msg = new MimeMessage(session);
msg.setFrom(new InternetAddress(from));
InternetAddress[] address = {new InternetAddress(to)};
msg.setRecipients(Message.RecipientType.TO, address);
msg.setSubject("Test kiri");
msg.setSentDate(new Date());
msg.setText("See on test kiri. " +
"Ja kirja sisu\n");
Transport.send(msg);
}
catch (MessagingException mex) {
mex.printStackTrace();
}
}
}
Kompileerimiseks ja kasutamiseks sobib öelda
$ export CLASSPATH=/opt/javamail/mail.jar:. $ javac Kirjasaatja.java $ java Kirjasaatja
Märkused
- Selleks, et java.sun.com võrk töötaks Debian Squeeze 20100402 seisuga, tuleb öelda, http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=560044
# sysctl -w net.ipv6.bindv6only=0
