Wykład dla studentów Informatyki Stosowanej i Fizyki
Komputerowej
UJ
2005/2006
Michał Cieśla
pok. 440a, email: ciesla@if.uj.edu.pl
konsultacje: poniedziałki 13-15
http://users.uj.edu.pl/~ciesla/
1
1. Rozpowszechnianie programów napisanych w Javie.
2. Narzędzie przydatne w trakcie tworzenia aplikacji (ant, junit, log4j).
3. Java i bazy danych.
4. Bibliotekiprzydatne przy tworzeniu aplikacji komercyjnych.
5. Serializacja i Java Beans.
6. Wybrane elementy wprowadzone w wersji JDK 1.5.
.
2
2. http://www.apache.org/, http://jakarta.apache.org/.
3. Czasopisma:
● Software Developer Journal (http://www.sdjournal.org/),
● Java Developers Journal (http://jdj.sys-con.com/).
4. Inne zasoby internetowe (http://www.jguru.com/).
3
Rozpowszechnianie programów w Javie
1. Format jar
- podpisywanie archiwów
- narzędzia keytool i jarsigner
2. Applety
- uruchamianie dowolnej aplikacji jako applet.
3. Java Web Start
- protokół jnlp
4. Tworzenie wersji instalacyjnych
- IzPack
- IzPack-launcher
4
Format JAR pozwala umieścić wiele plików w pojedynczym archiwum. Zwykle archiwa JAR zawierają pliki klas wraz z dodatkowymi zasobami potrzebnymi do działania apletu czy aplikacji. Podstawowe zalety dystrybucji programów w postaci plików jar to:
● bezpieczeństwo: archiwa mogą być cyfrowo podpisywane – użytkownicy akceptujący podpis mogą dać aplikacji dodatkowe prawa, które w innym przypadku nie zostałyby udostępnione,
● kompresja: skrócenie czasu ładowania apletu lub aplikacji,
● zarządzanie zawartością archiwów z poziomu języka programowania,
● zarządzanie wersjami na poziomie pakietów oraz archiwów (Package Sealing, Package Versioning),
● przenośność.
5
Archiwum jar tworzy sie używając komendy jar, np: jar cf archiwum.jar klasa1.class klasa2.class ...
Użyte opcje:
● c – tworzenie pliku (create),
● f – zawartość archiwum zostanie zapisana do pliku archiwum.jar zamiast do standardowego wyjscia (stdout);
Inne opcje, które mogłyby zostac dodane do cf:
● v – informacje o postępie prac (verbose),
● 0 (zero) – brak kompresji,
● M – domyślny plik manifest nie zostanie dołączony do archiwum
● m – do archiwum zostanie dołączony plik manifest z określonej lokalizacji, np: jar cmf plik_manifest archiwum.jar *,
● -C – zmiana katologu w trakcie działania archiwizatora, np: jar cf ImageAudio.jar -C images * -C audio *.
6
W archiwum jar zwykle znajduje się katalog META-INF a w nim plik MANIFEST.MF zawierający dodatkowe informacje o archiwum.
Typowa zawartość:
Manifest-Version: 1.0
Created-By: 1.5.0-b64 (Sun Microsystems Inc.)
Ant-Version: Apache Ant 1.6.5
Main-Class: pl.edu.uj.if.wyklady.java.Wyklad01
mówi, że po uruchomieniu archiwum wykonana zostanie metoda
main(String[] args) zawarta w klasie Wyklad01 znajdującej się w pakiecie pl.edu.uj.if.wyklady.java.
Uruchomienie pliku jar:
java -jar archiwum.jar
7
Przeglądanie zawartości pliku JAR
Archiwum jar przegląda się używając opcji t, np:
jar tf archiwum.jar
Użyte opcje:
t – przeglądanie pliku (table).
Przykład:
jar tf dt.jar
META-INF/
META-INF/MANIFEST.MF
javax/
javax/swing/
javax/swing/AbstractButtonBeanInfo.class
javax/swing/beaninfo/
javax/swing/beaninfo/images/
javax/swing/beaninfo/images/AbstractButtonColor16.gif
javax/swing/beaninfo/images/BorderColor16.gif
javax/swing/beaninfo/images/BoxColor16.gif
...
8
Archiwum jar można rozpakować za pomocą opcji x, np: jar xf archiwum.jar [plik(i) do rozpakowania]
Użyte opcje:
● x – tworzenie pliku (create).
Przykład:
jar xf dt.jar – rozpakuje całe archiwum.
jar xf dt.jar javax/swing/AbstractButtonBeanInfo.class –
rozpakuje plik javax/swing/AbstractButtonBeanInfo.class.
UWAGA:
podczas rozpakowywania wszystkie istniejące pliki o ścieżkach takich jak pliki rozpakowywane zostaną nadpisane.
9
Sposoby modyfikacji pliku jar:
jar cmf dodatek-do-manifestu archiwum.jar [plik(i) do
spakowania]
jar uf archiwum.jar [plik(i) do aktualizacji]
Użyte opcje:
● m – dopisanie informacji do pliku manifest,
● u – aktualizacja archiwum.
Opcje u i m – mogą być użyte równocześnie. Przykład: jar xf dt.jar – rozpakuje całe archiwum.
jar umf info dt.jar javax/swing/AbstractButtonBeanInfo.class
– aktualizuje w pliku dt.jar manifest zawartością info i plik
javax/swing/AbstractButtonBeanInfo.class.
10
Cyfrowy podpis to ciąg bitów wyliczony na podstawie podpisywanych danych i prywatnego klucza osoby (instytucji) podpisującej. Podstawowe cechy podpisu cyfrowego:
● jego autentyczność jest weryfikowana za pomocą klucza publicznego podpisującego,
● nie może zostać podrobiony (dopóki klucz prywatny jest chroniony),
● nie może być wykorzystany do podpisu innych danych, ponieważ jest funkcją podpisywanej treści,
● podpisana treść nie może być zmieniona, w przeciwnym wypadku podpis straci autentyczność.
Aby wygenerować podpis należy posiadać parę odpowiadających sobie kluczy: prywatny i publiczny. Dodatkowo potrzebny jest certyfikat potwierdzający autentyczność klucza publicznego.
11
keytool służy do zarządzania kluczmi i certyfikatami. Wszystkie klucze są przechowywane w tzw. keystore. Na dysku jest on przechowywany w domyślnym katalogu użytkownika w pliku o nazwie .keystore lub keystore. Aby wygenerować nowy klucz należy użyć opcji genkey: keytool -genkey {-alias alias} {-keyalg keyalg} {-keysize
keysize} {-sigalg sigalg} [-dname dname] [-keypass
keypass] {-validity valDays} {-storetype storetype}
{-keystore keystore} [-storepass storepass] [-provider
provider_class_name] {-v} {-Jjavaoption}
Więcej informacji:
http://java.sun.com/j2se/1.4.2/docs/tooldocs/solaris/keytool.html
12
C:\jdk1.5.0\bin>keytool -genkey -alias mckey
Enter keystore password: haslo0
What is your first and last name?
[Unknown]: Michal
What is the name of your organizational unit?
[Unknown]: Ciesla
What is the name of your organization?
[Unknown]: IIS UJ
What is the name of your City or Locality?
[Unknown]: Krakow
What is the name of your State or Province?
[Unknown]: Malopolska
What is the two-letter country code for this unit?
[Unknown]: PL
Is CN=Michal, OU=Ciesla, O=IIS UJ, L=Krakow, ST=Malopolska,
C=PL correct?
[no]: yes
Enter key password for <mckey>
(RETURN if same as keystore password): haslomckey
13
jarsigner jest wykorzystywany do podpisywania plików jar.
Aby podpisać plik przyklad.jar za pomocą wygenerowanego wcześniej klucza mckey używamy polecenia:
C:\jdk1.5.0\bin>jarsigner przyklad.jar mckey
Enter Passphrase for keystore: haslo0
Enter key password for mckey: haslomckey
Warning: The signer certificate will expire within six
months.
Więcej informacji:
http://java.sun.com/j2se/1.4.2/docs/tooldocs/solaris/jarsigner.html
14
Applet pozwala na uruchomienie dowolnego programu w javie za pośrednictwem przeglądarki internetowej. Po wejściu na odpowiednio przygotowaną stronę internetową następuje pobranie wskazanych plików potrzebnych do uruchomienia programu. Pliki potrzebne do uruchomienia programu są automatycznie pobierane po czym następuje uruchomienie wskazanej klasy na lokalnym komputerze. Aplet nie musi wykonywać się w oknie przeglądarki.
Jak każdy program w javie moze on otworzyć osobne okienko (okienka) do komunikacji z klientem. Przed uruchomieniem apletu może nastąpić sprawdzenie podpisów cyfrowych.
15
package pl.edu.uj.is.java
public class ExampleApplet extends javax.swing.JApplet {
/** Konstruktor. Tworzy instancje apletu */
public ExampleApplet() {
getRootPane().putClientProperty(
"defeatSystemEventQueueCheck",
Boolean.TRUE);
}
/**
* Metoda wykonywana po uruchomieniu appletu
* @see java.applet.Applet#init()
*/
public void init() {
ExampleClass.main(null);
}
}
16
<html>
<head>
<title>Strona zawierająca applet</title>
</head>
<body>
<APPLET CODE ="pl.edu.uj.if.ExampleApplet.class"
WIDTH ="300" HEIGHT ="30">
<PARAM NAME ="ARCHIVE"
VALUE ="kat/archiwum1.jar, kat2/lib/biblioteka.jar"> alt="Twoja przegladarka obsluguje applety,
jednak z nieznanych przyczyn nie potrafi ich
uruchomic.">
Twoja przegladarka ignoruje applety !
</APPLET>
</body>
</html>
17
Przykładowa strona www – Internet Explorer
<html>
<head>
<title>Strona zawierająca applet</title>
</head>
<body>
<OBJECT
classid = "clsid:CAFEEFAC-0014-0001-0000-ABCDEFFEDCBA"
codebase =
"http://java.sun.com/products/plugin/autodl/jinstall-1_4_1-windows-i586.cab#Version=1,4,1,0" WIDTH = 300 HEIGHT = 60>
<PARAM NAME ="CODE"
VALUE ="pl.edu.uj.if.ExampleApplet.class" >
<PARAM NAME = "type" VALUE = "application/x-java-applet;version=1.4.1">
<PARAM NAME = "ARCHIVE" VALUE = "kat/archiwum1.jar, kat2/lib/biblioteka.jar">
18
Przykładowa strona www – Internet Explorer
<COMMENT>
<EMBED
type = "application/x-java-applet;version=1.4.1"
CODE = "pl.edu.uj.if.ExampleApplet.class"
WIDTH = 300
HEIGHT = 30
pluginspage =
"http://java.sun.com/products/plugin/index.html#download">
<NOEMBED>
alt="Twoja przegladarka obsluguje applety, jednak z nieznanych przyczyn nie potrafi ich uruchomic."
Twoja przegladarka ignoruje applety !
</NOEMBED>
</EMBED>
</COMMENT>
</OBJECT>
</html>
19
Technologia Java Web Start jest rozwiązaniem dedykowanym do lokalnego uruchamiania programów w Javie umieszczonych w sieci.
JWS:
● jest w pełni niezależna od używanych przeglądarek internetowych,
● umożliwia automatyczne pobranie właściwej wersji środowiska JRE,
● pobierane są tylko pliki, które zostały zmienione,
● obsługuje prawa dostępu do zasobów lokalnego komputera (dysk, sieć, itp.),
● do opisu zadania do uruchomienia wykorzystuje pliki jnlp (Java Network Launch Protocol).
Więcej informacji:
http://java.sun.com/products/javawebstart/index.jsp
20
<?xml version="1.0" encoding="utf-8"?>
<jnlp
spec="1.0+"
codebase="http://www.serwer.w.sieci.pl/katalog"
href="plik_jws.jnlp">
<information>
<title>Nazwa programu</title>
<vendor>Producent programu</vendor>
<homepage href="http://www.strona.programu.pl"/>
<description kind="short">Krotki opis
programu</description>
<icon kind="splash" href="kat/splashscreen.gif"/>
<icon href="kat/ikona.gif"/>
<offline-allowed/>
</information>
21
<security>
<all-permissions/>
</security>
<resources>
<j2se version="1.4+"/>
<jar href="kat/archiwum1.jar"/>
<jar href=" kat2/lib/biblioteka.jar"/>
</resources>
<application-desc main-
class="pl.edu.uj.if.ExampleApplet"/>
</jnlp>
Więcej:
http://java.sun.com/j2se/1.4.2/docs/guide/jws/downloadservletguide.html
http://java.sun.com/j2se/1.4.2/docs/guide/jws/developersguide/overview.html#requirements Plik jnlp umieszczamy na serwerze www. Często należy skonfigurować odpowiadający mu typ mime: application/x-java-jnlp-file JNLP
22
Projekt IzPack (http://www.izforge.com/izpack/) służy do tworzenia instalatorów dla programów w Javie. Jego podstawowe cechy:
● opensource udostępniony na licencji GNU GPL,
● powszechnie używany,
● obsługuje wiele wersji językowych (w tym polską),
● wieloplatformowy (testowany w Win32, MacOS X, Linux/i386, FreeBSD/i386),
● konfigurowany poprzez dokument XML,
● tworzy programy odinstalowujące.
23
pliki
zasoby
Instalator jest opisany za pomocą
dokumentu XML. Dokument ten opisuje
wszelkie zasoby z których korzysta
Dokument XML
program. Wynikiem jego kompilacji jest
archiwum jar zawierające instalator. Do
uruchomienia instalatora wymagane jest
środowisko JRE.
kompilator
instalator
24
Dokument XML opisujący program instalacyjny ma następującą strukture: Program.xml
<installation version="1.0">
<info>
...
</info>
<guiprefs ...>
...
</guiprefs>
<locale>
...
</locale>
<resources>
...
</resources>
<panels>
...
</panels>
<packs>
...
</packs>
</installation>
25
Sekcja info zawiera podstawowe informacje o programie, takie jak nazwa wersja, autorzy, itp:
<info>
<appname>MyApp</appname>
<appversion>1.2.3</appversion>
<authors>
<author name="Snoopy" email="snoopy@myapp.org" />
<author name="Foo Bar" email="foo@bar.org" />
</authors>
<url>http://www.myapp.org/</url>
<javaversion>1.4</javaversion>
</info>
Sekcja guiprefs określa natomiast wygląd instalatora:
<guiprefs height="600" resizable="yes" width="800">
<laf name="metouia">
<os family="unix" />
</laf>
</guiprefs>
26
Sekcja locale definiuje dostępne wersje językowe instalatora:
<locale>
<langpack iso3="eng"/>
<langpack iso3="fra"/>
<langpack iso3="deu"/>
<langpack iso3="ita"/>
<langpack iso3="jpn"/>
<langpack iso3="spa"/>
</locale>
Sekcja resources pozwala wskazać zasoby wykorzystywane do tworzenia okienek instalatora:
<resources>
<res src="https://zanotowane.pl/14/3825/install-readme.html" id="HTMLInfoPanel.info"/>
<res src="https://zanotowane.pl/14/3825/Licence.txt" id="LicencePanel.licence"/>
<res src="https://zanotowane.pl/14/3825/langsel.jpg" id="installer.langsel.img"/>
</resources>
27
Instalator bedzie zawierał okienka określone w sekcji panels.
<panels>
<panel classname="HelloPanel"/>
<panel classname="HTMLInfoPanel"/>
<panel classname="LicencePanel"/>
<panel classname="PacksPanel"/>
<panel classname="TargetPanel"/>
<panel classname="InstallPanel"/>
<panel classname="SimpleFinishPanel"/>
</panels>
Sekcja packs określa położenie komponentów programu
<packs>
<pack name="Core" required="yes">
<description>MyApp core files.</description>
<fileset dir="" targetdir="$INSTALL_PATH">
<include name="*.txt" />
<include name="lib/**/*" />
</fileset>
</pack>
</packs>
28
Aby stworzyć wersje instalacyjną można użyc skryptu compile np: compile install.xml -b . -o install.jar -k standard
użyte opcje:
-b podstawowa ścieżka tzw. basepath,
-o nazwa pliku wynikowego,
-k typ instalatora,
Uruchomienie instalatora nastąpi po wydaniu polecenia:
java -jar install.jar
Aby uruchomić program nie posiadając środowiska JRE można zastosować dodatkowo inny program np: izpack-launcher.
29
Aplikacje w javie można dostarczyć odbiorcy na kilka sposobów. Istnieje możliwość przygotowania klasycznej wersji instalacyjnej jak również uruchomienia programu umieszczonego w sieci internet. U podstaw wszystkich tych rozwiązań znajduje się format archiwów javy - jar.
30