Mendelova zemědělská a lesnická univerzita v Brně Provozně ekonomická fakulta
Systém evidence knih v obecní knihovně Bakalářská práce
Vedoucí práce: Ing. Petr Jedlička, Ph.D
Radek Majer
Brno 2009
Rád bych touto cestou poděkoval Ing. Petru Jedličkovi, Ph.D. za veškerou pomoc, cenné rady a připomínky, které mi poskytl při zpracování bakalářské práce.
Prohlašuji, že jsem vyvíjený program, který je cílem bakalářské práce, zpracoval samostatně a bakalářskou práci také samostatně s použitím uvedené literatury a pod odborným vedením Ing. Petra Jedličky, Ph.D.
V Brně 14. května 2009
....................................................
4
Abstract Majer, R. System for books account in the council library. Bc. Dissertation. Brno, 2009. The dissertation deals with development program for books registration. This work analyzes the current registration of books, identifies the current deficiencies in the way of evidence in the local library. On the basis of this information suggests and implements an appropriate information system, which has implemented functions as log books, readers, books borrowing and archiving, inventory, Web catalog and part of the whole system is also a help. The consequent program can be easily modified for any library (approx 20 000 volumes).
Abstrakt Majer, R. Systém evidence knih v obecní knihovně. Bakalářská práce. Brno, 2009. Bakalářská práce se zabývá vývojem programu pro evidenci knih. Práce analyzuje stávající způsob evidence knih, zjišťuje nedostatky současného způsobu evidence v místní knihovně. Na základě těchto informací navrhuje a realizuje vhodný informační systém, který má implemenotovány funkce jako je např. evidence knih, čtenářů, vypůjčky a jejich archivace, inventarizace, webový katalog a součástí celého systému je také nápověda. Výsledný program lze snadno modifikovat pro libovolnou knihovnu (cca 20 000 svazků).
5
OBSAH
Obsah 1 Úvod
8
2 Cíl a metodika práce 10 2.1 Cíl práce . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 2.2 Metodika práce . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 3 Současný stav 12 3.1 Popis současného způsobu evidence knih . . . . . . . . . . . . . . . . 12 3.2 Hlavní problémy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 4 Návrh řešení 5 Volba technologií pro implementaci 5.1 Programovací jazyk . . . . . . . . . . . . . . . 5.2 Vývojové prostředí . . . . . . . . . . . . . . . 5.3 Volba databáze . . . . . . . . . . . . . . . . . 5.4 Spring . . . . . . . . . . . . . . . . . . . . . . 5.5 Hibernate . . . . . . . . . . . . . . . . . . . . 5.5.1 Mapování tabulek . . . . . . . . . . . . 5.5.2 Ukládání, aktualizace a mazání dat . . 5.5.3 Vyhledávání a načítání dat z databáze 5.5.4 Replikace . . . . . . . . . . . . . . . . 5.6 Jasper Reports . . . . . . . . . . . . . . . . . 5.7 SwingX . . . . . . . . . . . . . . . . . . . . . 5.8 Substance . . . . . . . . . . . . . . . . . . . . 5.9 HTML a PHP . . . . . . . . . . . . . . . . . .
15
. . . . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . . . .
6 Implementace 6.1 Zabezpeční aplikace . . . . . . . . . . . . . . . . . . 6.2 Evidence čtenářů . . . . . . . . . . . . . . . . . . . 6.3 Evidence knih . . . . . . . . . . . . . . . . . . . . . 6.4 Výpůjčky a jejich archivace . . . . . . . . . . . . . 6.5 Inventarizace . . . . . . . . . . . . . . . . . . . . . 6.6 Tisk reportů, čárových kódů a čtenářských kartiček 6.7 Vlastní nastavení aplikace . . . . . . . . . . . . . . 6.8 Rezervace knih . . . . . . . . . . . . . . . . . . . . 6.9 Synchronice databází . . . . . . . . . . . . . . . . . 6.10 Nápověda . . . . . . . . . . . . . . . . . . . . . . . 6.11 Webový katalog . . . . . . . . . . . . . . . . . . . . 7 Závěr
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
. . . . . . . . . . .
. . . . . . . . . . . . .
20 20 21 21 22 25 26 28 29 30 31 35 36 37
. . . . . . . . . . .
38 38 38 40 41 42 43 45 46 47 49 50 51
OBSAH
6
8 Literatura
53
Přílohy
54
A Náhledy aplikace
55
B Elektronické přílohy
59
PŘEHLED POUŽITÝCH ZKRATEK
Přehled použitých zkratek AOP API AWT BSD DAO DI GPL GUI HQL HTML IDE IoC JDBC JDK JEE JMF JMS JPA JRE JSF LGPL MVC OQL ORM PHP POJO UML SWT
Aspect Oriented Programming Application interface Abstract Windowing Toolkit Berkeley Software Distribution Data Access Object Dependency Injection General Public Licence Graphical User Interface Hibernate Query Language HyperText Markup Language Integrated Development Environment Inversion of Control Java Database Connectivity Java Develpoment Kit Java Enterprise Edition Java Media Framework Java Message Service Java Persistence API Java Runtime Environment JavaServer Faces Lesser General Public Licence Model View Controller Object Query Language Object Relational Mapping Hypertext Preprocessor Plain Old Java Object Unified Modeling Language Standard Widget Toolkit
7
1 ÚVOD
1
8
Úvod
V současné době se v České republice podle údajů z Evidence knihoven Ministerstva kultury nacházelo 6 170 knihoven.1 Podle knihovního zákona č. 257/2001 Sb. byly zrušeny knihovny2 neposkytující přístup k informacím na internetu. Podle knihovního zákona se knihovnou rozumí zařízení, v němž jsou způsobem zaručujícím rovný přístup všem bez rozdílu poskytovány veřejné knihovnické a informační služby vymezené tímto zákonem, a které je zapsáno v evidenci knihoven.3 V ČR podle odstavce 1 §3 tohoto zákona funguje následující systém knihoven: • Národní knihovna České republiky (dále jen „Národní knihovnaÿ), Knihovna a tiskárna pro nevidomé K. E. Macana, Moravská zemská knihovna v Brně, zřízené Ministerstvem kultury (dále jen „ministerstvoÿ), • krajské knihovny, zřízené příslušným orgánem kraje, • základní knihovny, zřízené příslušným orgánem obce, • specializované knihovny (např. univerzitní, církevní, lékařské,. . .). Prvotní myšlenkou pro vytvoření této bakalářské práce, a tedy informačního systému, byl požadavek zastupitelstva obce Kašnice posoudit výhodnost koupě informačního systému pro evidenci knih do místní knihovny. Obec Kašnice se nachází v Jihomoravském kraji v okresu Břeclav a leží na hlavní silnici mezi městy Brno a Hodonín. V této malé obci žije 227 obyvatel a průměrný věk zde dostahuje 39 let. Nenachází se zde škola, pošta ani restaurace, přesto se sem začínají stěhovat hlavně mladí lidé. Tato zařízení jsou dostupná ve vedlejším městě Klobouky u Brna a z obce je snadná dostupnost do větších měst. Z této dostupnosti pramení i nejnižší nezaměstnanost na Břeclavsku, dosahuje něco málo přes pět procent.4 V obci se nachází malá knihovna pod názvem Místní lidová knihovna Kašnice registrovaná na Ministerstvu kultury České republiky. Jedná se o malou knihovnu s přibližně 3 500 svazky. Obdobných knihoven je po celé republice několik set a všechny mají stejný problém. Tento problém je nedostatek finančních prostředků na rozvoj služeb poskytovaných těmito organizacemi. Pro tyto potřeby fungují jak dotace ze státního rozpočtu, tak strukturální fondy z EU. Avšak přes náročnou ad1
Údaje z Ministerstva kultury (MK ČR) (Ministerstvo kultury ČR, 2008) Podle údajů MK ČR zrušeno 201 knihoven do 1. ledna 2008 (Ministerstvo kultury ČR, 2008) 3 Knihovní zákon č. 257/2001 Sb. (Knihovní zákon, 2003) 4 Břeclavský deník 19.3. 2009 (Ševčík, 2009) 2
1 ÚVOD
9
ministrativu a zdlouhavé vyřizování dotací se může stát, že tak malá knihovna, jako je knihovna v Kašnici, nemusí tyto prostředky získat.
2 CÍL A METODIKA PRÁCE
2 2.1
10
Cíl a metodika práce Cíl práce
Cílem této bakalářské práce je usnadnění evidence knih ve vybrané místní knihovně. Po předběžné analýze stavu obecní knihovny byl stanoven cíl vytvořit program, který bude určený pro malé knihovny. Tento cíl se tedy shoduje s cílem bakalářské práce. Program by měl být mnohonásobně levnější než programy od konkurence a to pomocí použití nejmodernějších technologií při tvorbě aplikace. Měl by také výrazně zjednodušit evidenci knih v knihovně, jakož i inventarizaci a sdílení katalogu knih na internetu. Vyvíjený produkt vznikal pod záštitou firmy Effectiva Solutions, s. r. o. na popud obecního zastupitelsta, které chtělo zmodernizovat služby v místní knihovně. Původně se jednalo o posouzení existujícího informačního systému k evidenci knih a čtenářů. Cena tohoto produktu se pohybuje okolo 40 000 Kč. Existují i varianty, které jsou levnější, ale jsou dostupné pouze on-line. Jedná se o internetové aplikace, které nejsou tak schopné, jako klasické desktopové aplikace, proto nejsou tak oblíbené. Dalším, neméně důležitým cílem, je přilákat nové čtenáře do knihovny. Knihovní systém by měl umožňovat sdílet svůj katalog na internetu pro potřeby čtenářů. Základní podmínkou je, aby aplikace byla nainstalovaná na lokálním počítači a fungovala bez nutnosti nepřetržitého přístupu k internetu (v tzv. offline režimu) a přesto byl webový katalog dostupný pro nahlížení čtenářů.
2.2
Metodika práce
Pro splnění výše uvedeného cíle je celé řešení rozděleno do několika etap. Nejprve bude popsáno zjištění současného stavu při evidenci knih a návrh možného zlepšení. Tedy návrh vlastní aplikace, zejména datové části, která bude vycházet ze současného stavu evidence knih a požadavků na nový systém. Po namodelování situace budoucího systému budou zvoleny vhodné technologie, které umožní vytvořit velmi kvalitní aplikaci za použití co nejméně času. Tedy takové technologie, které jsou relativně jednoduché na použití nebo jejich použití je složité, ale přesto budou vést ke zkrácení doby vývoje celé aplikace. Při popisu jednotlivých technologií budou ukázány krátké ukázky zdrojového kódu pro použití této technologie nebo její části. Po zvolení těchto technologií bude program vytvořen ve zvoleném programovacím jazyce a s použitím daných techno-
2 CÍL A METODIKA PRÁCE
11
logií. Následně pak bude program popsán z pohledu implementačního a funkčního. Na závěr bude zhodnoceno, zda bylo dosaženo požadovaného výsledku, popřípadě v jaké míře jej bylo dosaženo.
3 SOUČASNÝ STAV
3 3.1
12
Současný stav Popis současného způsobu evidence knih
Nyní se knihy evidují pomoci tzv. „kartičkovéhoÿ systému. Každá kniha v knihovně má vlastní kartičku, na které je uvedeno její název, autor, rok vydání a další. Dále se na ni vypisuje datum vypůjčení, datum vrácení a jméno čtenáře, který si knihu vypůjčil. Každý čtenář má svoji složku, do které se vkládají při vypůjčení kartičky z knihy, vyplní se údaje o vypůjčení a při vrácení se kartička vrátí zpět do knihy a vyplní se údaje příslušné údaje o vrácení. Následující systémový diagram popisuje současný stav evidence knih. V případě vypůjčování knihy si čtenář vybere knihu, kterou si chce vypůjčit a následně zaměstnanec knihovny provede zápis o vypůjčení do výpůjčního protokolu. Jakmile čtenář vrací knihu, pak zaměstnanec opět zapíše záznam do výpůjčního protokolu o vrácení knihy. Systém evidence knih zůstane takřka identický, dojde pouze k odstranění fyzického zápisu evidence knih do automatizovaného informačního systému.
13
3 SOUČASNÝ STAV
Obr. 1: Systémový diagram V knihovně se nachází starší počítač (HDD 8 GB, RAM 128 MB, CPU Celeron 1 200 MHz) a je na něm nainstalovaný operační systém Microsoft Windows XP Professional, dále je k němu připojena barevná inkoustová tiskárna. Čtenáři mohou tento počítač využívat k prohlížení internetu, tisku dokumentů nebo jen učení práce s počítačem. Počítač je připojen k internetu technologií WI-FI o rychlosti pohybující se kolem 6 Mb/s. Toto připojení je sdílené s počítačem obecní úřadu obce Kašnice. Knihovna má možnost využít laserovou tiskárnu, která je umístěna na obecním úřadě, který se nachází hned vedle knihovny. V současnosti tento počítač je relativně nevyužit, protože slouží čtenářům knihovny k prohlížení internetu, psaní dopisů, tisku atd. Tuto službu čtenáři moc nevyužívají a to hlavně z důvodu, že mají internet doma, nebo o počítače nemají vůbec zájem. Jelikož knihovna nemá dostatek finančních prostředků na nákup nové výpočetní techniky, tak by aplikace měla fungovat na tomtéž počítači.
3.2
Hlavní problémy
Největším problémem je zdlouhavé vyřizování vypůjčení a vracení knih. Při současném způsobu evidence knih dochází i k určitým nesrovnalostem, kdy si čtenář knihu vypůjčil, mezi tím ji vrátil, ale do knihy nebyla vrácena kartička ze čtenářovy složky,
3 SOUČASNÝ STAV
14
a se může zdát, že ji čtenář ještě nevrátil a je po něm požadována. Velkým problémem také je inventarizace knih, která se provádí jednou za pět let. I když knihovna obsahuje necelých 3 600 svazků knih, inventarizace zabere několik dnů a může se stát, že i přesto nebude stoprocentní. Dalším problém je absence on-line katalogu knihovny. Tato absence je také částečným důvodem, proč do knihovny chodí nízký počet občanů. Občané si ani nejsou vědomi, jestli daná kniha se v knihovně nachází, a proto chodí do větší knihovny, kde si mohou ověřit dostupnost knihy.
4 NÁVRH ŘEŠENÍ
4
15
Návrh řešení
Aplikace by měla být rozdělena na dvě části. Hlavní aplikace by měla mít podobu klasické desktopové aplikace, měla by být jednoduchá na ovládání a uživatelsky přívětivá, dále by měla být nezávislá na dostupnosti internetu (měla by mít schopnost práce v tzv. offline režimu). Jednou z hlavních podmínek je, aby bylo možné spustit aplikaci na počítači, který se již v knihovně nachází, bez větších nákladů. Stěžejní funkce programu jsou evidence knih, čtenářů, aktuálních výpůjček a archivace výpůjček. Další z hlavních vlastností je možnost sdílení katalogu knih na internetu bez nutnosti vlastnit server a veřejnou vlastní IP adresu. Součástí evidence čtenářů je tisk čtenářských kartiček a čárových kódů. Čárové kódy budou rovněž použity pro evidenci knih. Aplikace bude knihy identifikovat pomocí čtečky čárových kódů. Nedílnou součástí evidence knih je jejich inventarizace a následné reportování výsledků. Reporty bude možné tisknout pro kteroukoliv tabulku po filtraci nebo seřazení. Součástí programu by měla být podrobná nápověda, která pomůže pracovníkovi knihovny vyřešit všechny běžné problémy s evidencí knih. S použitím všech těchto technologií dojde ke zjednodušení a tím následné zrychlení práce. Webová část aplikace sloužící pro čtenáře by měla být umístěna na internetu jako webový katalog, aby čtenáři měli on-line přístup k informacím o dostupných knihách v knihovně. Aplikace by čtenáři měla umožnit on-line listovat katalogem. Webový katalog by měl pracovat s jinou databází, než hlavní aplikace, přičemž by obě databáze měly pracovat se stejnými daty. Internetová databáze by měla zároveň sloužit jako záloha dat v případě, že by došlo k poškození lokální databáze. Následující UML diagram tříd popisuje atributy a metody jednotlivých objektů v informačním systému knihovny a vztahy mezi jednotlivými objekty. Jedná se o návrh základní struktury programu vyjádřený v podobě objektů. Z tohoto diagramu bude vycházet i ERD diagram, který bude představovat uložení dat do databáze.
4 NÁVRH ŘEŠENÍ
16
Obr. 2: UML diagram - Diagram tříd
4 NÁVRH ŘEŠENÍ
17
Celý systém bude složen ze sedmi tabulek, z toho jedna zůstává relativně nevyužita. Jedná se o tabulku rezervace a to z toho důvodu, že zatím nebyl požadavek na rezervování knih čtenáři přes internet. Hlavní aplikace s tabulkou při vypůjčování knih kontroluje, zda je kniha rezervována či nikoliv. Pokud je kniha rezervována, pak se ještě provádí kontrola, jestli je rezervována pro čtenáře, který si knihu právě půjčuje. Internetová část systému zatím s tabulkou nepracuje, tj. neukládají se do ní požadavky na rezervaci od čtenářů. Pokud nastane požadavek knihovny na rezervace přes internet, bude zbývat přepsat webovou část systému bez nutnosti zasahovat do desktopové aplikace. Data z tabulky Rezervace a Vypujcky budou z databáze vymazávána. V těchto tabulkách by bylo zbytečné uchovávat staré záznamy. Například v tabulce Vypujcky by za několik let bylo velké množství záznamů a postupně by se aplikace při vypůjčování knih zpomalovala. Proto je navržena druhá tabulka VypujckyArchiv, do které se budou ukládat všechny výpůjčky a je možné nad nimi v případě potřeby vyhledávat. V ostatních tabulkách se mazání dat nebude provádět. K vytvoření dojmu vymazání záznamu v každé takové tabulce bude sloužit atribut viditelnost, který bude boolenovského typu. V případě, že bude položka vymazána, pak bude tento atribut nastaven na hodnotu false. Data není vhodné mazat z důvodu návaznosti jednotlivých tabulek na sebe. Pokud bychom chtěli vymazat pracovníka knihovny, pak bychom museli použít kaskádové mazání a vymazali bychom všechny informace, které zaměstnanec s příslušným ID provedl. Z toho důvodu dojde pouze k relativnímu vymazání položky a přitom nedojde k narušení integrity databáze. Tabulka Ctenari slouží pro evidenci čtenářů a bude mít celkem 14 atributů. Mezi nejdůležitější patří ID, které jednoznačně identifikuje čtenáře a má datový typ INTEGER (bude se jednat o primární klíč tabulky). Dalším jednoznačným identifikátorem je CID, je datového typu VARCHAR a jedná se o unikátní klíč. Hlavní rozdíl mezi CID a ID je ten, že CID bude složen ze dvou složek první z nich je písmeno C (označení čtenáře) a dalších devět čísel. Dále obsahuje atributy pro jméno, příjmení, heslo (pro on-line rezervaci knih) a další. Tabulka pro knihy bude rozdělena na dvě části a to na Objekty a Vytisky. Je to z důvodu redundance dat v databázi. Tabulka Objekty v sobě obsahuje ty atributy, které mají knihy společné (pokud máme dvě knihy stejné knihy s názvem např. Umění klamu, pak mají stejný název, autora, nakladatele, ale stejné už nemají jejich OID - unikátní klíč, místo umístění v knihovně, informace o jejich stavu, inventarizaci,. . .). OID bude opět složeno ze dvou složek a to z písmene O (definuje objekt - může to být kniha, časopis,. . .) a devíti čísel.
4 NÁVRH ŘEŠENÍ
18
Propojení tabulky Ctenari a Vytisky je z důvodu výměnného fondu. Knihovny si mezi sebou mohou navzájem půjčovat knih a tak jedna působí v roli knihovny a druhá v roli „čtenářeÿ. Pokud čtenář obsahuje atribut výměnný fond, pak v tomto atributu bude uveden název knihovny a ve jméně a příjmení bude uvedena odpovědná osoba, která nám knihy zapůjčila. Pokud máme knihu v invenáři z výměnného fondu, pak v tabulce Vytisky v atributu vymennyFond uvedeno ID z tabulky Ctenari, který je veden jako výměnný fond. Pokud tedy chceme zjistit, které knihy máme zapůjčeny od dané knihovny, je možné ji pak jednoduše vyfiltrovat. Důvod proč nevyužít CID nebo OID jako primární klíč je ten, že se jedná o datový typ VARCHAR a porovnávání tohoto typu trvá déle, než porovnávání datového typu INTEGER. Tabulka Uzivatele v sobě bude uchovávat informace o zaměstnancích v knihovně. Jim je přiřazeno přihlašovací jméno (automaticky transformuje jejich příjmení na malé znaky bez diakritiky) a heslo. Další tabulkou kde se informace budou mazat, je tabulka Vypujcky. Po vypůjčení a následném vrácení knihy jsou data přesunuty z této tabulky do tabulky VypujckyArchiv. V tabulce Vypujcky jsou atributy ID, Datum, Uzivatel, Vytisk a Ctenar. Tyto atributy nám umožní identifikovat kdy si který čtenář danou knihu zapůjčil. V tabulce VypujckyArchiv ještě přibyl navíc atribut DatumVraceni, do kterého je uloženo datum o vrácení knihy. Všechny časové atributy budou ukládány do časového datového typu podle příslušné databáze většinou DATETIME. Číselné hodnoty jsou ukládádny do datového typu INTEGER (NUMBER) a řetězcové znaky do datového typu VARCHAR (VARCHAR2). Všechny datové typ jsou voleny automaticky podle příslušné databáze. Následující ERD diagram znázorňuje tabulky, atributy a vazby mezi nimi.
4 NÁVRH ŘEŠENÍ
19
Obr. 3: ERD diagram
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
5
20
Volba technologií pro implementaci
Pro tvorbu aplikace byly vybírány technologie spadající do kategorie JEE (Java Enterprise Editon). Označení JEE je velmi široký pojem a může být i trochu matoucí. Neznamená to, že tyto technologie jsou určeny pouze pro obrovské projekty. Tyto technologie velmi zjednodušují práci a zkracují až několikanásobně dobu vývoje celé aplikace. Příkladem může být Jasper Reports (technologie pro reportování dokumentů). Šablonu pro report je možné vytvořit během několika minut. Výsledek vypadá velmi profesionálně a navíc je možné výsledný report uložit do několika formátů. Pokud bychom chtěli reportovat výsledky byť jen do jednoho typu souboru, zabralo by nám to minimálně několik hodin a následný report by nebyl zdaleka v takové kvalitě.
5.1
Programovací jazyk
V dnešní době se téměř vše vyjadřuje objektově. Využití objektů v programování je velmi velkým zjednodušením a to díky použití dědičnosti, asociace a polymorfismu. Proto byl zvolen objektově orientovaný jazyk Java, který má hlavní výhodu např. proti .NETu tu, že se jedná o multiplatformní aplikaci. To znamená, že může běžet na systému s operačním systémem Windows, Linux nebo MacOS. Jedinou podmínkou je, že na daném systému musí být nainstalovaný balíček JRE, který slouží jako virtuální stroj, na kterém se aplikace spouští. Dnes na většině počítačů již JRE nainstalované je, protože například pro přístup k internetovému bankovnictví se používají applety, které jsou napsané v Javě a přístup ke svému účtu bychom bez JRE neměli. Platforma Java má tři velké výhody oproti ostatním objektově orientovaným programovacím jazykům. První z nich je možnost komerčního využití knihoven třetích stran, které velmi významně zjednodušují vývoj aplikací. Další z nich je možnost výběru z několika vývojových prostředí, ne všechna jsou však zdarma. Aplikace vyvíjené v programovacím jazyku Java mohou být vyvíjeny v jakémkoliv operačním systému, za podmínky, že je na něm nainstalované JDK. JDK obsahuje základní nástroje pro vývoj aplikací v Javě. JDK obsahuje: • JRE, • překladač do bytekódu (javac), • debugger pro hledání chyb a ladění programu (jdb),
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
21
• javadoc pro generování vývojářské dokumentace (javadoc), • nástroj pro tvorbu JAR balíčků (jar), • nástroj pro spouštění a ladění appletů bez webového prohlížeče (appletviewer). Proto jsou náklady pro programátora na vývoj nulové. Nevýhodou Javy je její rychlost. V současnosti je nevhodná pro aplikace pracující v reálném čase. Java je oproti jazyku C několikanásobně pomalejší. Toto by se mělo změnit v roce 2010, kdy společnost Sun Microsystems by měla pro Java 7 uvolnit nový Garbage Collector (označovaný G1) a ten slibuje přiblížení rychlosti Javy k aplikacím real-time.
5.2
Vývojové prostředí
IDE (Integrated development environment) je zkratka pro vývojové prostředí. Každé IDE je většinou zaměřené na jeden programovací jazyk. Výběr IDE není jednoduchý. Existují dva hlavní kandidáti a to jsou Netbeans a Eclipse. Obě IDE podporují verzovací systém SVN, Maven a další. Tyto IDE jsou na stejné úrovni, a proto jen záleží na volbě programátora, které IDE je mu příjemnější na práci. Vývojové prostředí Netbeans má jednu malou výhodu a to tu, že ho vyvíjí společnost Sun Microsystems, která je také největším distributorem JRE, a proto bylo zvoleno toto IDE. Netbeans je vydáváno jako open-source projekt, za kterým stojí velká komunita vývojářů. Celé Netbeans jsou napsány v programovacím jazyce Java a lze spustit na libovolném operačním systému (jde o multiplatformní aplikaci), na kterém je nainstalované JDK (Windows, Linux, Mac a Solaris). V současnosti je verze Netbeans ve verzi 6.5.1, která umožňuje programovat v programovacích jazycích Java, C/C++, Ruby, Python a nově i v PHP. Další výhodou Netbeans je, že po nainstalování pluginu se celé IDE nemusí restartovávat, to v ostatních IDE není možné.
5.3
Volba databáze
Mezi použitelné databáze je možné uvažovat nad třemi databázemi. Všechny tři podporují kódování UTF-8. První z nich je databáze MySQL. Jedná se o velmi rychlou multiplatformní databázi, ale má také své nevýhody, pokud není MySQL databáze nainstalována pod utf czech cs, pak je nutné nastavit collate pro schéma, tabulku i sloupce. Mezi hlavní nevýhodu databáze MySQL je změna licenece z LGPL na GPL. Licence GPL je velmi striktní a při jejím použití celá aplikace musí být vydána pod licencí
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
22
GPL. Jinak je možné si zakoupit komerční licenci. U této databáze se kódování nastavuje jak pro schéma, tabulku tak i pro sloupec. To může být někdy výhodné, pokud máme databázi nastavenou na jiné kódování, než požadujeme, pak budeme mít problémy s kódováním českých znaků. Druhou možností je zvolení databáze PostgreSQL, je to také multiplatformní aplikace, ale je o něco pomalejší než databáze MySQL. Databáze má konstatní výkon, takže při větším množství dat má přibližně stejnou dobu odezvy jako u malého množství dat. Velkou výhodou databáze PostgreSQL je její licence. Je vydána pod licencí BSD, která je velmi svobodná a ve volném překladu říká: „Vezmi si, co chceš a dělej si s tím, co chcešÿ. Třetí možností je použití databáze Apache Derby. Jde také o multiplatformní databázi, která je vydána pod licencí Apache License, Version 2.0. Tato licence nevynucuje redistribuci kódů pod stejnou licencí, jen musíme do kódu uvádět, které soubory byly použity pod touto licencí. Mezi velkou výhodu této databáze je, že se instaluje úplně automaticky a uživatel o ní ani neví. Je velmi nenáročná na paměť a místo na disku. Má ovšem jednu velkou nevýhodu a to je praktická nemožnost její zprávcování. Přístup do databáze je pouze přes vlastní rozhraní, které si v aplikaci napíšeme nebo z IDE např. Netbeans. Byla zvolena tato databáze a to hlavně z důvodu její jednoduchosti instalace (instaluje se zcela automaticky). Rozhraní pro přístup k datům není vůbec důležité, někdy může být i nevhodné. Příkladem může být, že bychom ručně přidali nějaké záznamy do databáze, ale zapomněli bychom zvýšit poslední použité ID. Při zápisu dat z aplikace by následně docházelo ke kolizím.
5.4
Spring
Tato technologie spadá do kategorie JEE, jedná se o moderní technologii, která je zaměřena pro tvorbu webových aplikací. Tuto technologii je možné použít takřka ve všech typech aplikací včetně klasických (desktopových) aplikací. Tento framework podporuje všechny vrstvy aplikace: • • • • •
perzistenční vrstva, datová vrstva, aplikační vrstva, prezentační vrstva, vrstva webových služeb.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
23
Spring je zprostředkovatel technologií (integruje ostatní nástroje) mezi použitými technologiemi a vlastní aplikací. Jedná se o JSF, JPA, JMF, JDBC, Hibernate a další. Další funkcí Springu je poskytování služeb jako je konfigurace, AOP, remoting, transakce, nastavení rozesílání e-mailů a další. Konfiguraci Springu je možné provést čtyřmi způsoby: • XML - Konfigurace pomocí XML souboru má jednu velkou výhodu. Tou je, že celá konfigurace je vždy uložena na jednom místě. Použití XML souborů pro konfigurací Springu je povinné vždy i v případě kdy jej nechceme používat, protože v souboru musíme alespoň říct, jak Spring budeme konfigurovat. • Properties - Použití properties souborů se v dnes již moc nepoužívá. Pokud je tato konfigurace použita, pak z toho důvodu, že je v ní uloženo připojení k databázi a podobné nastavení, které se často mění a to z důvodu, že ne vždy aplikaci nasazuje programátor. Ten, co aplikaci nasazuje, by musel zkontrolovat někdy i značné množství zdrojového kódu, než by našel požadované nastavení. Proto je možné takové nastavení oddělit do těchto souborů. • Anotace - Použití anotací je moderní způsob konfigurace. Její malou nevýhodou je, že konfigurace celého Springu je na několika místech. • Konfigurace pomocí Javy - Jde o nestandardní část Spring frameworku a v současné době se již moc nevyvíjí. Tento způsob se doporučuje použít tehdy, pokud je potřeba za běhu aplikace měnit konfiguraci Springu. Spring se skládá z šesti částí (modulů). Základním modulem, který je nutné vždy použít je Core modul. Pak obsahuje dalších pět volitelných modulů - DAO, ORM, AOP, JEE a Web. • Core Je nejdůležitější částí Springu a musí být implementovaný vždy, pokud chceme použít nějaký modul Springu. Obsahuje vlastní třídu implementující BeanFactory, která umožňuje vyhledávání objektů podle jmen a následné řízení vztahů. Core modul obsahuje IoC (někdy označovaný jako DI kontejner), který představuje aplikační kontext Springu. Tento kontejner se stará o třídy, které jsou managované Springem. Nemanagementované třídy vznikají na základě volání jejich konstruktoru. • AOP Je zkratka z aspektově orientovaného programování. Tato metoda programování je nadstavbou nad objektově orientovaným programováním (AOP doplňuje OOP). Používá se u opakujících částí kódu, které jsou většinou skoro stejné.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
•
•
•
•
24
Možnosti použití jsou zejména u otevírání, zavírání transakcí, autorizaci, logování a mnohému dalšímu. Opět máme možnost použít konfiguraci pomocí anotací nebo XML souborů. AOP programování je možné použít pouze na objekty vytvořené Springem, v případě objektů nevytvořených ve Springu nebude automatické volání metod fungovat. DAO Velmi důležitou částí Springu je vrstva DAO, která umožňuje přístup k datům. Tento modul umožňuje jednoduché použití transakcí v aplikaci, ty můžeme ovládat programově nebo deklarativně. Operace, které jsou prováděny pomocí transakcí, musí používat jedno připojení do databáze (jinak by transakce nebylo možné realizovat). Od takovýchto věcí nás odděluje Spring, který si to řeší sám (podobné je to s otevíráním a uzavíráním spojení). Nevýhody použití klasického JDBC API jsou následující: – nutné napsat velké množství zdrojového kódu, – nepřehlednost, – odchytávání velkého množství výjimek, – vzniká pouze jediná výjimka - SQLException. ORM Spring podporuje objektově-relační mapování databází. V současnosti jsou relační databáze nejrozšířenějšími databázemi, ale struktura releční databáze je odlišná od struktury objektové. Proto je nutné namapovat objekty do databáze. Spring sám nemá žádný ORM nástroj pro mapování, ale podporuje nástroje třetích stran. Nejpopulárnějším mapovacím nástrojem je Hibernate, ale existují i další nástroje např. iBatis. Hibernate si generuje vlastní SQL dotazy pro každou databázi, takže je ho možné použít takřka beze změn pro jakoukoliv databázi (je v něm možné psát i klasické SQL dotazy). iBatis je nutné téměř vše psát ručně, což má své výhody i nevýhody. JEE Tato technologie umožňuje například jednoduší tvorbu a příjem e-mailů než v klasickém Java Mail API včetně správného zobrazování českých znaků, kde lze jednoduše nadefinovat požadované kódování. Lze také k těmto e-mailům jednoduše přikládat soubory jako přílohy. JEE obsahuje JMS, které slouží pro příjem, zpracování vlastních zpráv. Tato technologie je založená na síti peer-topeer. WEB Jedna z nejdůležitějších částí Sprigu je modul Web. Spring se nejvíce používá
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
25
pro tvorbu webových aplikací. Obsahuje MVC rámec (např. Struts) pro vývoj webových aplikací. Jedná se o softwarovou architekturu, která aplikaci rozděluje do tří komponent: – datový model, – řídící logika aplikace, – uživatelské rozhraní. Spring umožňuje intgeraci prezentační technologií jako např. reportovací nástroj JasperReports, Velocity, PDF, Excel. Dále obsahuje JSF, což je prostředí pro vývoj webových rozhraní. Hlavní výhodou JSF je odstínění programátora od tvorby grafiky a odstínění grafika od programování. Podobně je to s frameworkem FreeMarker.
5.5
Hibernate
Hibernate slouží jako rozhraní mezi vlastní aplikací a databází. Je vydáván pod licencí LGPL, kde můžeme knihovnu Hibernatu a výsledný produkt můžeme vydávat pod libovolnou licencí. Hibernate zajišťuje persistenci dat. Vlastnosti persistence: • více uživatelů má v jednu chvíli přístup ke stejným datům, • více uživatelů může v jednu chvíli s daty pracovat - modifikovat je a to bez poškození integrity dat. To zajišťuje transakční přístup, • snadná přenositelnost programů na jiná datová úložiště. Hibernate je plně objektový jazyk (vychází z jazyka OQL - Object Query Language) a umožňuje využití vlastností objektů jako jsou dědičnost, asociace a polymorfismus. Hibernate používá vlastní jazyk HQL, který je nadstavbou nad jazykem OQL. HQL vychází ze syntaxe SQL jazyka pro danou databázi. Jedná se o velmi univerzální nástroj, který může pracovat až z 25 různými databázemi v různých verzích. Primárně je Hibernate testován pro databázi Microsoft SQL Server 2000. Dále podporuje databáze Oracle, MySQL, PostgreSQL, Apache Derby, Microsoft Access a mnohé další. Napojení na určitou databázi je velmi jednoduché. Stačí k tomu ovladač dané databáze, který je typu JAR souboru a přiloží se k projektu. Poté jen stačí upravit několik řádků v nastavení Springu připojení k databázi. Tato technologie byla vybrána pro svou univerzálnost, jednoduchost nastavení a bez nutnosti psaní SQL dotazů, které jsou většinou použitelné jen pro jednu databázi (v různých databázích se SQL dotazy v detailech liší). Obecně je známo, že Hibernate je o trochu pomalejší při složitých dotazech oproti SQL dotazům. Po-
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
26
kud tedy potřebujeme velmi výkonnou aplikaci, pak si kdykoliv můžeme složité SQL dotazy napsat sami. 5.5.1
Mapování tabulek
Pro namapování tabulek z objektů máme více možností. Tou jednodušší je, že třídu, kterou chceme namapovat jako tabulku, označíme anotací a pak dalšími anotacemi označíme jednotlivé proměnné. Následující zjednodušená třída Uzivatele obsahuje proměnné ID a Jmeno. Označení třídy se provádí pomocí @hibernate.class a uvedením jejího názvu. Podobné je to s označením atributů, kde se uvádí @hibernate.property a název atributu. Při refaktoringu kódu je velkou výhodou pro programátora umístění kódu na jednom místě. /** * @hibernate.class * table="uzivatele" */ public class Uzivatele { /** * @hibernate.id * generator-class="sequence" * column="id" */ private integer id; /** * @hibernate.property * column="jmeno" */ private String jmeno; } Druhou možností k mapování je použití XML souborů. Soubor se musí jmenovat stejně jako mapovaná třída, v našem případě Uzivatele.hbm.xml. XML soubor musí povinně obsahovat hlavičku XML dokumentu a poté již definujeme vlastní mapování.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
27
<param name="sequence">id_uzivatele <property name="jmeno"/> Obecně lze říci, že pro menší třídy je lepší použítí anotací, vše je na jednom místě a je přehledné. Ale pokud budeme mít na mapování rozsáhlou třídu, je výhodnější použít mapování pomocí hbm.xml souborů. Velkou výhodou Hibernatu je, že se nemusíme starat o datové typy, která databáze podporuje. Hibernate si totiž mapuje proměnné z výchozího nastavení podle sebe, toto je velké usnadnění pro programátora. Pokud však z nějakého důvodu potřebujeme změnit datový typ, je to možné pomocí použití klíčového slova type a uvedením požadovaného typu. Pro definování vlastností atributů se používají následující položky (property): • name - jméno proměnné, • column - určuje výsledný název sloupce, ve výchozím nastavení se jméno sloupce určuje ze jména proměnné, • type - typ sloupce v databázích. Hibernate sám určuje výsledný datový typ. Použití type se doporučuje, jen pokud je to nezbytně nutné, • lazy - určuje typ načítání dat. Pokud je hodnota nastavena na false, pak při dotazu do databáze se nám stahují celé objekty nebo listy. Pokud však je hodnota nastavena na true, pak se záznamy načítají až v době, kdy jsou skutečně potřeba. Velkou výhodou je, že se nepřenáší zbytečně velké množství dat, ale jen skutečně požadované záznamy. Nevýhodou naopak je, že pokud požadujeme
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
28
data ze zděděné třídy, musíme je znovu načíst a to vede k většímu počtu dotazů do databáze, • unique - říká databázi, jestli je daný sloupec unikátní nebo ne. To znamená, že v daném sloupci se daná hodnota může vyskytnout pouze jedenkrát, • not-null - pokud je hodnota nastavena na true, tak při vkládání dat nebo jejich editaci tato položka musí být vyplněna (musí obsahovat nějakou hodnotu). Mapování zděděných objektů Pokud jeden objekt obsahuje další objekt, pak se pro mapování objektu do databáze používá vazby many-to-one, která nám umožní namapovat objekty a pak při načtení s nimi jako s objekty pracovat. <many-to-one name="ctenar" class="cz.effectiva.ukazka.bo.Ctenar"/> Mapování je velmi jednoduché. Je nutné pouze zadat typ vazby, jméno proměnné ze třídy Java a pak cestu ke třídě. Toto jsou povinné údaje, dále je možné připojit property. Oproti property běžných proměnných je možné obohatit o další property jako je např. cascade - kaskádové mazázní záznamů. 5.5.2
Ukládání, aktualizace a mazání dat
Při ukládání, aktualizaci a mazání dat je nutné si nejprve vytvořit spojení, které nám požadovanou činnost umožní. To se provádí příkazem: Session session = getSessionFactory().openSession(); Po provedení požadovaných změn v databázi je nutné spojení ukončit a to se provede příkazem: session.flush(); session.close(); Uložení dat do databáze je velmi jednoduché a při ukládání si můžeme zvolit z několika možností uložení. session.flush(); • Tento příkaz provede uložení nového záznam: session.save(ctenar); • Tento příkaz provede uložení nového záznamu nebo aktualizaci již existujícího záznamu: session.saveOrUpdate(ctenar); • Způsobí aktualizaci již existujícího záznamu v databázi: session.update(ctenar);
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
29
Klíčové slovo flush označuje tzv. flushing. Do doby, kdy nezavoláme příkaz flush(), nedojde k aktualizaci dat v databázi. To může být výhodné, zejména pokud nechceme často navazovat spojení a ukládat data po jednom záznamu. Nedojde-li ani ke změně objektu a chceme provést uložení do databáze, pak spojení nebude ani navázáno, protože bychom ukládali stejný objekt. S tímto příkazem můžeme pracovat podle sebe. Defaultně se tento příkaz volá před každým dotazem do databáze nebo jej můžeme nastavit, aby se spouštěl před každým commitem nebo jej úplně vypnout a pak změny ukládáme sami. Mazání objektů v databázi je možné provést mnoha způsoby. Nejjednodušším z nich je pomocí příkazu session.delete(ctenar); kde v jednom spojení vymažeme objekt čtenář. Toto lze provést, pouze pokud pracujeme s jednou databází. Pokud chceme načíst záznam z jedné databáze a vymazat ho ve druhé databázi, pak tento příkaz nelze použít, protože objekt nerovná se objekt. Objekty obsahují různé indexy, které nejsou na první pohled viditelné a v každé databázi jsou jiné. Pokud chceme provést mazání objektů z různých databází, pak je nutné je mazat podle jejich unikátních identifikátorů (ID). To ukazuje následující příklad: Query q = session.createQuery("DELETE FROM Vypujcka vp WHERE vp.id = :id"); q.setParameter("id", vypujcka.getId()); q.executeUpdate();
5.5.3
Vyhledávání a načítání dat z databáze
Hibernate umožňuje tři základní přístupy k tvorbě dotazů do databáze: SQL dotazy - Hibernate umožňuje psaní klasických SQL dotazů, ale použití tohoto přístupu se velmi nedoporučuje, snad je v nevyhnutelných případech. Je to hlavně z toho důvodu, že technologie Hibernate je určena pro komunikaci s více než dvaceti druhy databází a v některé z databází se mohou lišit jednotlivé SQL dotazy (sice jen v detailech), pak ale není zaručena stabilita aplikace. public List
listCtenari(String cid) { sess.createSQLQuery("SELECT * FROM Ctenari").list(); } HQL dotazy - Vychází z jazyka OQL (tedy objektový přístup k datům), do jisté míry je podobý přístupu SQL ve které se používá relační přístup.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
30
public List listVypujckaCid(String cid) { return (List) getHibernateTemplate() .find("from Vypujcka v left join fetch v.ctenar c where c.cid=? order by v.vytisk.objekt.nazev", cid); } Další možností získávání dat z databáze je za použití kritérií. Jde o velmi mocný nástroj, se kterým se pracuje velmi intuitivně bez nutnosti znalosti SQL nebo HQL dotazů. Výsledný SQL dotaz se automaticky vygeneruje podle databáze se kterou pracujeme. public List listVytiskyCriteria(String oid, String autor, String nakladatel, String nazev) { Criteria criteria = getSession().createCriteria(Vytisk.class) .add(Restrictions.eq("oid", oid)) .createAlias("objekt", "o") .add(Restrictions.like("o.jmenoAutora", autor + "%")) .add(Restrictions.like("o.nazev", nazev + "%")) .add(Restrictions.like("o.nakladatel", nakladatel + "%")) .add(Restrictions.eq("viditelnost", true)) .addOrder(Property.forName("o.nazev").asc()); return (List) criteria.list(); }
5.5.4
Replikace
Pro synchronizace dat v databázích je vhodné využít v Hibernatu replikace. Tato možnost nám umožní synchronizaci dvou různých databází (např. je možné synchronizovat databázi MySQL s databází Oracle). Pro replikaci se používá příkaz replicate(Object, ReplicationMode). Jako první parametr se uvádí libovolný objekt, který má být replikovaný. Druhým parametrem se uvádí jeden ze čtyř módů replikace: • ReplicationMode.OVERWRITE - Přepíše záznam v tabulce se stejným identifikátorem. • ReplicationMode.LATEST VERSION - Přepíše záznam v tabulce, pokud replikovaný řádek je novější. Pokud je záznam starší, pak se replikace neprovádí.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
31
• ReplicationMode.IGNORE - Zapíše záznam do databáze pokud se záznam se stejným identifikátorem v databázi nenachází. Pokud již je záznam v databázi se stejným identifikátorem obsažen, pak se nechá v původních hodnotách (nedojde k přepsání na novější data). • ReplicationMode.EXCEPTION - Spustí výjimku, pokud se v databázi nachází záznam se stejným identifikátorem. Kdybychom jako první příklad parametru replicate uváděli vždy jeden objekt, pak by synchronizace dvou databází po jednom objektu trvala neúměrně dlouho, protože pro každé načtení a následné uložení objektu se musí vytvořit spojení. Proto je vhodné v jednom spojení data načíst a ve druhém spojení data uložit jako list záznamů. Nejprve libovolně získáme list položek (může se jednat i o celou tabulku) a následně se provede uložení do druhé databáze. To ukazuje následující příklad: Session session2 = getSessionFactory().openSession(); Transaction tx2 = session2.beginTransaction(); for (Ctenar ctenar: listCtenari) { session2.replicate(ctenar, ReplicationMode.OVERWRITE); } tx2.commit(); session2.close(); }
5.6
Jasper Reports
V současnosti je tato technologie nejlepší volbou pro tvorbu reportů. Umožňuje přímý tisk a ukládání do formátu PDF, RTF, ODT, HTML, CSV, XML, XLS a vlastního formátu jrprint. Pro návrh tiskových sestav se používá program iReport, který je vydán pod licencí GNU GPL. iReport je program vytvoření v programovacím jazyce Javě, je tedy multiplatformní a lze jej spustit přímo bez instalace. Ještě existuje v druhé verzi jako plugin do Netbeans, pak nemusíme spouštět žádný další program a návrh reportu vytvoříme přímo v Netbeans a můžeme je zařadit přímo do balíčku. iReport je založen na XML dokumentu. Návrh výsledného reportu můžeme tvořit za použití: • statických textů, • proměnlivých textů (tzv. TextFields), • tabulek,
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
• • • • •
32
grafů, obrázků, čárových kódů, čar a křivek, sub-reportů.
Sub-report je report v reportu, tedy jeden report může obsahovat několik dalších reportů. Použití se najde v mnoha případech, nejčastěji však, mají-li se v reportu objevovat data několikrát za sebou a ty data mohou mít další položky, které se proměnlivě mění. Typickým příkladem může být výpis domů a jejich majitelů v obci. V takovém případě je nutné použít report v reportu, kde výpis domů bude „vnějšíÿ report a vlastníci daného domu budou „vnitřníÿ report. Celý report je rozdělen do devíti částí, kde každá část se v dokumentu objevuje na jiných místech. Struktura reportu je následující: • Background - Nastavuje pozadí reportu. • Title - Jde o titulek stránky a v případě vícestránkového dokumentu se titulek zobrazuje pouze na první stránce. • Page Header - Hlavička stránky, která se zobrazuje na každé stránce reportovaného dokumentu. • Column Header - Hlavička sloupců tabulky. Tato část bezprostředně souvisní s částí detail. • Detail - Jde o hlavní část sestavy. Tato část umí vytvářet nové řádky. • Column Footer - Patička sloupců. • Page Footer - Patička stránky. • Last Page Footer - Patička poslední stránky reportu. Důležitou vlastností této části je, že se zobrazuje vždy na poslední stránce reportu na konci stránky. Pokud tuto část použijeme, pak se Page Footer na poslední stránce zobrazovat nebude (Last Page Footer jej překryje). • Summary - Zobrazuje se vždy na poslední stránce pro závěrečná shrnutí. Zobrazuje se však na poslední stránce tiskové sestavy před Column Footer i když v návrháři je uvedená až jako poslední. Soubor je uložen do formátu jrxml a před následným tiskem je nutné jej zkompilovat do formátu .jasper, pak je možné zvolit tisk nebo jednu z forem exportu. iReport umožňuje vkládat tři typy proměnných a to variables, parameters a fields. Variables obsahují některé proměnné, které iReport již vytvoříl sám, jako jsou např. číslo strany, celkový počet stran, číslo sloupce, celkový počet sloupců
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
33
a počet reportů. Další proměnné si můžeme vytvořit sami. U těchto proměnných si můžeme zvolit způsoby jejich výpočtu z implicitních vzorců, jako jsou součty, průměry, vybírat nejvyšší, nejnižší čísla přímo v reportu. Dále máme možnost si vytvořit zcela vlastní vzorce pro výpočty. Parameters jsou proměnné předávané z Javy a slouží k zobrazování položek stejných pro jednotlivé řádky reportu. Zejména se jedná o nadpisy, hlavičky tabulek, datum, tvůrce reportu atd. Parametry jsou v Javě zastoupeny pomocí mapy. Následuje jednoduchý příklad: Map parameters = new HashMap(); parameters.put("titulek", "Historie výpůjček"); parameters.put("jmenoCtenare", ctenar.getPrijmeniJmeno()); parameters.put("datum", new Date()); parameters.put("pocetVypujcek", vypujcky.size()); } Jedná se o obecnou mapu, do které můžeme vkládat datum, řetězce znaků, čísla, logické proměnné atd. První podmínkou pro vytvoření reportu je, že proměnné v Javě se musí jmenovat stejně jako Parameters v reportu včetně velikosti písmen. Druhou podmínkou je, že pokud vkládáme čísla, je nutné je v reportu převést na řetězec. K tomu se používá metoda toString(). Pro práci s datem, řetězci, čísly existuje v iReportu široké spektrum metod. Například pro práci s řetězci existuje přibližně čtyřicet metod: • charAt(int) - Tato metoda nám vráti znak na pozici podle zadaného parametru, • compareTo(String) - Metoda pro porovnání dvou řetězců, • contains(String) - Slouží ke zjištění, jestli jeden řetězec obsahuje druhý řetězec. Metoda vrací logickou hodnotu, • equalsIgnoreCase(String) - Srovnává dva řetězce a vrací logickou hodnotu, přičemž ignoruje velikost písmen, • isEmpty() - Kontroluje, jestli řetězec obsahuje nějaké znaky. Tato metoda vrací logickou hodnotu. Pro práci s datem existuje přes dvacet metod. Jedná se zejména o získávání minut, hodin, dnů, měsíců ze zadaného data a formátování data k zobrazení (např. na čas podle GMT).
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
34
Poslední proměnnou k zobrazení jsou Fields. Jsou to položky, které tvoří jednotlivé řádky v reportu. Používají se zejména v tabulkách jako její jednotlivé buňky a umístňují se nejčastěji do části Detail v reportu. U Fields platí stejné podmínky jako u Parameters. V Javě jsou reprezentovány pomocí kolekce a ukazuje to následující příklad: List<JrVytisky> jrVytisky = new ArrayList(); for (Vytisk vytisk : vytisky) { JrVytisky polozka = new JrVytisky(); polozka.setOid(vytisk.getOid()); polozka.setIsbn(vytisk.getObjekt().getIsbn()); polozka.setJmenoAutora(vytisk.getObjekt().getJmenoAutora()); polozka.setNazev(vytisk.getObjekt().getNazev()); polozka.setRokVydani(vytisk.getObjekt().getRokVydani()); polozka.setNakladatel(vytisk.getObjekt().getNakladatel().getNazev()); jrVytisky.add(polozka); } Tento příklad ukazuje použití kolekce. ArrayList implementuje rozhraní List a je jednou ze základních kolekcí. Na prvním řádku je vytvoření Listu, do kterého budou jednotlivé položky uloženy. Následuje for cyklus, který přidává každé položce hodnoty. Následující příklad zobrazuje reportování dokumentu. První parametr je název reportu, který se má použít. Druhým parametrem je mapa parametrů a třetím parametrem jsou již zmíněné kolekce. Po zkompilování se provede zobrazení reportu do programu Jasper Viewer, ze kterého je možné data tisknout nebo ukládat do již zmíněných formátů. Při exportu dokumentu musíme vložit mapu a kolekci položek. Pokud chceme vytvořit report pouze s mapou, pak musíme vytvořit prázdnou kolekci, analogicky to platí pro vytvoření reportu pouze s kolekcí. public static void printList(String reportName, Map parameters, Collection polozky) { String jasperExtension = ".jrxml"; InputStream is = Thread.currentThread().getContextClassLoader() .getResourceAsStream("cz/effectiva/adriana/resources/" + reportName + jasperExtension); try {
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
35
JRDataSource dataSource = new JRBeanCollectionDataSource(polozky); JasperReport report = JasperCompileManager.compileReport(is); JRLoader.loadObject(is); JasperPrint print = JasperFillManager.fillReport(report, parameters, dataSource); JasperViewer.viewReport(print, false); } catch (JRException ex) { ex.printStackTrace(); } }
5.7
SwingX
Jedná se o knihovnu, která nabízí nové GUI komponenty nebo vylepšuje starší komponenty Swingu. Knihovna je vydaná pod licencí LGPL což znamená, že se jedná o licenci, kde výsledný program může být vydán pod libovolnou licencí (tedy i komerčně). Pro Javu je možné si vybrat mezi Swingem, SWT a AWT komponentami (pak existují ještě komerční varianty např. JIDE komponenty). AWT komponenty byly první implementací grafiky v Javě. Jde o platformově nezávislé komponenty, ale jejich přenositelnost je problematická. SWT komponenty mají různé problémy na operačním systému MAC OS (všeobecně se nedoporučuje míchat aplikace s SWT a Swing komponentami). Jde hlavně o problémy se zabezpečováním událostí nad komponentami a problémy s výkonem. Swing nabízí několikanásobně více komponent, než zmíněné SWT. Změna skinování (look and feel) v aplikacích používající SWT je velmi složitá, naproti tomu změna skinování v aplikacích Swing je velmi jednoduchá, skiny si můžeme volit např. použitím Substance. Proto je použití Swingu mnohem používanější než použití komponent založených na SWT. Zvolení této knihovny bylo hlavně z několika důvodů. První z nich je, že se dají využít zdarma i ke komerčním účelům, jsou skinovatelné a nabízí požadované komponenty (kalendářová komponenta a komponenta pro zobrazení obrázku). Dále SwingX vlastní komponenty pro práci s grafy, s rozšířenými tabulkami, stromové tabulky, hypertextové odkazy, vylepšenou komponentu pro práci s listem, pro práci se stromem, komponentu pro zobrazení stavu aplikace (rozšířený progressbar) a mnohé další.
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
36
Pro zobrazení obrázku do panelu se používají nasledující příkazy: BufferedImage logo = ImageIO.read(path); jXImagePanel_Logo.setImage(logo); První příkaz načte obrázek podle proměnné path, která určuje cestu k obrázku, který se nachází přímo ve výsledném JAR balíčku. Druhým příkazem se provede zobrazení načteného obrázku do panelu. Práce s komponentou pro datum je také velmi jednoduchá. Pro nastavení data do komponenty je možné použít dva způsoby. První možností je zdata přímo datum (první řádek následující ukázky) a tou druhou je zadat čas v milisekundách od 1. 1. 1970 (druhý řádek následující ukázky). Metoda get je obdobná k metodě set. Pro získání data se používá metoda getDate() (metoda vrací datum) nebo getDateInMilis() (metoda vrací počet milisekund od 1. 1. 1970). jXDatePicker_Do.setDate(datumOd); jXDatePicker_DatumOd.setDate(new Date(datumOdInMilis));
5.8
Substance
Tato technologie slouží ke zlepšení vzhledu stávající aplikace. Jsou dva hlavní důvody proč měnit vzhled aplikace. První z nich je, že aplikace vytvořené bez použití změny vzhledu (look and feel) jsou rozdílné na různých operačních systémech. Standardně Java používá nativní vzhled operačního systému. Například aplikace spuštěná pod Windows vypadá nativně, ale například na linuxu aplikace vypadá trochu jinak (neprofesionálně) zejména v KDE. Dalším důvodem je, že aplikace jsou značně uživatelsky nepřívětivé. Od verze Java 5 je podporovaný nativní vzhled aplikací pro Microsoft, po vydání Java 6 se nativní vzhled ještě zlepšil, ale přesto aplikace nedosahují takových kvalit, jako aplikace se změněným vzhledem. K odstranění nedostatků vzhledu slouží právě různé technologie pro změnu vzhledu aplikace. Z internetu je možné si stáhnout spousty šablon pro změnu vzhledu, ale existuje knihovna, ve které si můžeme volit vzhled sami a to je právě Substance. V současnosti je tato technologie ve verzi 5.0. Jedná se o knihovnu vydanou pod licencí BSD, proto si v této knihovně můžeme upravovat sami libovolné části kódu, bez porušení licence. S použitím této technologie se aplikace stává uživatelsky mnohem přívětivější. Změna vzhledu nám umožňuje měnit různé části aplikace:
5 VOLBA TECHNOLOGIÍ PRO IMPLEMENTACI
37
• rámečku aplikace, • dialogů (otevírací, ukládací, potvrzovací,. . .), • hlavní aplikace - můžeme měnit vzhled i vodotisk aplikace. Pro volbu vzhledu aplikace máme k dispozici zhruba dvacet předpřipravených vzhledů, například aplikace může vypadat jako MS Office 2007 (modrá nebo stříbrná barva). Zlepšení vzhledu můžeme ještě umocnit použitím vodoznaků, na výběr máme opět několik předpřipravených vodoznaků (např. s pruhy, s čísly, s planktonem, se šrafováním, s vlastním obrázkem na pozadí aplikace a další).
5.9
HTML a PHP
Jelikož celý systém musí být multiplatformní, pak musí být multiplatformní i nápověda. Nelze použít např. klasické nápovědy pro Windows ve formátu *.hlp. Jako optimální se proto jeví použití HTML. Hlavní výhodou této technologie je, že stránky vytvořené v prostém HTML nemusí být umístěny na žádném serveru, lze je tedy spustit lokálně bez dostupnosti internetu. Nápověda vytvořená v tomto jazyce stačí být zkopírována do počítače a následně ihned spuštěna za předpokladu, že v počítači je nainstalovaný internetový prohlížeč. Pro zjednodušení nastavení a zlepšení vzhledu výsledné nápovědy je docíleno použitím kaskádových stylů. Pro tvorbu webového katalogu bylo rozhodováno mezi JSF a PHP. Požadavek na webový katalog je pouze k zobrazení dostupných knih v knihovně. JSF technologie spadá do kategorie JEE a použití k tomuto požadavku je nevhodné. Tato technologie je velmi obsáhlá a složitá na implementaci. Pro menší projekty spíše prodlužuje dobu vývoje oproti klasickému PHP. Využití JSF ve velkých projektech je naopak výhodnější, neboť po počáteční konfiguraci se aplikace vyvíjí mnohem rychleji a nabízí široké spektrum možností. Aby aplikace vytvořená v JSF mohla být provozována, pak na serveru musí být nainstalovaný servlet Apache Tomcat. Pro tvorbu webového katalogu byla zvolena technologie PHP. Pro webový katalog jsou také použité kaskádové styly pro zlepšení vzhledu celého katalogu.
6 IMPLEMENTACE
6
38
Implementace
6.1
Zabezpeční aplikace
Pro zabezpečení aplikace se musí pracovník před prací se systémem autorizovat pomocí svého přihlašovacího jména a hesla. Aplikace umožňuje práci ve dvou režimech. První z nich je režim administrátorský, ve kterém můžeme přidávat, editovat a mazat uživatele. Další důležitou funkcí administrátora je nastavení synchronizace mezi databázemi. Může například zvolit, že chce obnovit celou databázi z veřejného serveru (může to být z důvodu reinstalace počítače v knihovně nebo porušení databáze). Dále může nastavit synchronizaci pro určitou tabulku a tím zkontrolovat správnost dat. Druhý režim slouží pro zaměstnanece knihovny, kteří se systémem pracují a evidují čtenáře a jejich výpůjčky. Jelikož počítač slouží i čtenářům k prohlížení internetu, tisku dokumentů a dalších činností, pak zaměstnanec nemusí aplikaci vypínat a pak opět zapínat, ale stačí mu pouze odhlášení ze systému. Po odhlášení je možné aplikaci vypnout, znovu se přihlásit nebo přihlásit jiného zaměstnance knihovny.
6.2
Evidence čtenářů
Čtenáři knihovny jsou evidováni do stejnojmenné tabulky Ctenari, kde se o nich ukládají jednotlivé informace. O čtenáři nás zajímají následující informace: • • • • • •
jméno, příjmení, adresa, telefonní číslo, e-mail, doplňující informace o čtenáři (např. pravidelné pozdní vracení knih a podobně).
Každému čtenáři je přidělen desetimístný unikátní identifikátor začínajícím písmenem velké C (označovaný jako CID). CID je vyjádřen pomocí čárového kódu, který je vytištěný na čtenářskou kartičku příslušného čtenáře. Pomocí této kartičky se čtenář identifikuje při vypůjčování nebo vracení knih. Knihovna umožňuje i výpůjčky z jiných knihoven (meziknihovní výpůjčky), proto se v evidenci čtenářů nachází položka VF (výměnný fond). Zvolíme-li tuto položku, dále zadáme název knihovny a následně tato knihovna slouží jako výměnný fond, od kterého si můžeme knihy nejen půjčovat, ale také jim knihy půjčovat.
6 IMPLEMENTACE
39
Jméno a příjmení pak slouží jako kontaktní informace na odpovědnou osobu z dané knihovny. Protože čtenář a výměnný fond jsou v konečném důsledku to stejné (zajímají nás o nich stejné informace), tak se data ukládají do stejné tabulky. Pokud by se jednalo o větší knihovnu, která by si půjčovala knihy od většího počtu knihoven, bylo by výhodnější rozdělit tuto tabulku na dvě. Poté jednoduše můžeme provést selekci dat z databáze a zobrazit knihy, které máme vypůjčeny ze které knihovny. Pro vyhledávání mezi čtenáři slouží klávesová zkratka CTRL + F nebo z hlavního menu kliknout na Úpravy a následně kliknout na Filtry. Tím se nám v záložkách pro evidenci čtenářů zobrazí nebo skryjí vyhledávací pole, podle kterých můžeme mezi čtenáři vyhledávat. Zobrazí se nám následující čtyři pole (můžeme vyhledávat podle nich zároveň): • • • •
CID, jména, příjmení, adresy.
Pro přidání nebo editaci čtenáře klikneme v hlavním menu na položku Čtenáři a následně na požadovanou akci, kterou chceme nad čtenářem provést. Pokud chceme čtenáře přidat nebo upravit, pak je nutné vyplnit minimálně ty položky, které jsou označeny červeně. Bez vyplnění těchto povinných položek nebude čtenář přidán do databáze a moct si půjčovat knihy. Po přidání nebo úpravě čtenáře máme možnost automatického tisku čtenářské kartičky (podle vlastní nastavení aplikace). Pokud chceme vytisknout kartičku k existujícímu čtenáři bez nutnosti jeho edice, pak ho stačí v databázi najít, kliknout na něj v tabulce myší a stisknout tlačítko Tisk, tím dojde k vytištění kartičky požadovaného čtenáře. Při přidání čtenáře je automaticky vytvořeno jeho heslo, které je vytvořeno ze čtenářova příjmení a to tak, že nejprve jsou všechny písmena zmenšeny a následně je z nich odstraněna diakritika. Pomocí CID a tohoto hesla, se čtenář bude moct přihlásit do internetového katalogu a provádět rezervace knih, nahlížení do výpůjček, případně editovat svůj účet (pokud bude požadavek na obsáhlejší internetový katalog). Dále se automaticky při přidání čtenáře do atributu datum vytvoření čtenáře vloží aktuální datum a dále se ke čtenáři přidá pracovník knihovny, který uživatele vytvořil. O každém čtenáři si můžeme zjistit podrobné informace v záložce Informace o jednotlivých čtenářích nebo z hlavního menu Čtenáři kliknutím na položku Informace o jednotlivých čtenářích. Pro zjištění informace o konkrétním čtenáři zadáme
6 IMPLEMENTACE
40
jeho CID a vybereme si v rozbalovacím seznamu (comboboxu) informaci, která nás o čtenáři zajímá. Máme na výběr ze tří následujících informací: • o vypůjčených knihách, • o nevrácených knihách, • o archivu výpůjček. Ve vypůjčených knihách a nevrácených knihách máme zobrazené tlačítko Vrátit. Tímto tlačítkem můžeme libovolnou knihu, kterou má čtenář vypůjčenou vrátit tak, že v tabulce klikneme na knihu, kterou čtenář vrací do knihovny, a následně klikneme na tlačítko Vrátit.
6.3
Evidence knih
Evidence knih je velmi podobná evidenci čtenářů. Každé knize je přiřazen desetimístný unikátní identifikátor, který začíná velkým písmenem O (označovaný jako OID). Položky, které jsou označeny červeně, jsou povinné k vyplnění. O knize evidujeme následující údaje: • • • • • • • • • •
ISBN, název, jméno autora, nakladatel, rok vydání, žánr, cena, umístění knihy v knihovně, výměnný fond (pokud z něj kniha byla vypůjčena), doplňující informace o stavu knihy (např. informace o jejím poškození a podobně).
Přidáváme-li do evidence knih novou knihu, je vhodné nejdříve vyplnit položku ISBN. Nachází-li se již tato kniha v knihovně, usnadní nám práci v automatickém doplnění informací, které mají tyto knihy společné. Pokud se žádná stejná kniha v knihovně nenachází, pak se musejí všechny informace o knize doplnit ručně. O knize se automaticky evidují informace o datu pořízení, datu vymazání a zaměstnanci knihovny, který evidenci prováděl. V záložce evidence knih se nám zobrazuje výpis jednotlivých knih. První sloupec je pojmenovaný VP (zkratka z vypůjčený) a v každém je zobrazena logická hodnota ve formě zaškrtávacího políčka (checkboxu) o tom, zda je kniha vypůjčena či nikoliv (pokud je kniha vypůjčena,
6 IMPLEMENTACE
41
pak je políčko zaškrtnuté). Nad zaevidovanými knihami je možné vyhledávat jako v případě čtenářů. Můžeme vyhledávat podle následujících kritérií (zadaná kritéria lze různě kombinovat): • • • • •
6.4
OID, názvu knihy, autora knihy, nakladatele, CID výměnného fondu, pokud knihy byla vypůjčena z jiné knihovny.
Výpůjčky a jejich archivace
Evidence výpůjček se zobrazuje ve stejnojmenném panelu Výpůjčky. V této tabulce jsou zobrazovány aktuálně vypůjčené knihy. V tabulce jsou zobrazeny následující údaje: • • • • • •
CID čtenáře, příjmení, jméno a adresa čtenáře, OID knihy, název knihy, jméno autora, datum vypůjčení.
Pokud si čtenář chce půjčit knihu, pak zaměstnanec knihovny naskenuje (nebo napíše) jeho CID a po správném načtení identifikátoru se v aplikaci zobrazí souhrnné informace o čtenáři. To stejné je i s identifikátorem OID, kde po naskenování dojde k zobrazení souhrnných informací o vypůjčované knize. Tyto zobrazované údaje zároveň slouží k lepší orientaci pracovníka knihovny, který se ujišťuje, že vypůjčuje správnou knihu správnému čtenři, neboť čtení čárového kódu není bezchybné (i když procento chyb je takřka nulové). V nastavení se můžeme zvolit maximální dobu, jakou čtenáři mohou mít knihu vypůjčenou. Po uplynutí této doby se výpůjčka knihy bude zobrazovat v seznamu nevrácených knih. Knihovna si může nechat zobrazit informaci o tom, o kolik dnů později byla kniha vrácena. Informace o nevrácených knihách zjistíme z hlavního menu položky Výpůjčky a následném kliknutí na Nevrácené knihy nebo přímo na záložku Nevrácené knihy. V tabulce se nám zobrazí seznam knih, které čtenář má vypůjčené déle, než knihovna povoluje. Výpis nevrácených knih je seřazen od nejstarších výpůjček, tzn., že na prvních místech jsou zobrazeny knihy, které jsou nejdéle vypůjčeny a doposud nebyly vráceny.
6 IMPLEMENTACE
42
Po vrácení knihy do knihovny se automaticky vymaží data z tabulky výpůjček, a celá výpůjčeka se přesune do tabulky výpůjčky archiv. Prohlížet archiv výpůjček je možné ve stejnojmenném panelu. Zde jsou zobrazeny všechny výpůjčky, které kdy v knihovně byly provedeny. Nad archivem je možné provádět filtraci: • CID čtenáře, • OID knihy, • datem vypůjčení. Je možné provádět kombinaci všech filtrů. Tzn., že můžeme vyhledat jednu knihu a zobrazit si celou její minulost vypůjčování (to stejné lze udělat se čtenářem) nebo si můžeme zvolit pouze rozmezí od data vypůjčení do data vypůjčení a tím se nám zobrazí výpůjčky dané knihy za dané období (obdobně je to opět u čtenáře). Dále je možné vyhledávat v historii pomocí CID a OID zároveň. Tím dospějeme k tomu, že se nám zobrazí požadovaný čtenář a požadovaná kniha. Pokud si čtenář z nějakého důvodu knihu půjčuje častěji, lze takhle jednoduše vyfiltrovat informace nesouvisející s ostatními knihami nebo čtenáři, samozřejmě je možné na tento filtr aplikovat třetí (časový) filtr, kdy si zobrazíme jen zadané období.
6.5
Inventarizace
Další zásadním bodem, který byl kladen na software je inventarizace knih v knihovně, která umožňuje zjistit úbytky nebo příbytky knih. Pokud chceme provést inventarizaci, pak v hlavním menu klikneme na Soubor, pak na položku Inventarizace a zvolíme Nová. Tím se nám databáze připraví na novou inventarizaci knih. Poté klikneme na záložku Inventarizace a může se provádět skenování kódů pomocí čtečky čárových kódů. V tabulce si můžeme vybrat, co chceme zobrazovat. Máme na výběr mezi následujícími položkami: • • • •
zinventarizované knihy, chybějící knihy, nezinventarizované knihy, vypůjčené nezinventarizované knihy.
Dále je možné nastavit, že po načtení jednoho kódu se musí kliknout na tlačítko OK a tím se provede zinventarizování jedné knihy nebo je možné nastavit, že ihned po zadání OID knihy se provede automaticky zinventarizování (tlačítko OK se nepoužívá). Druhá možnost výrazně zjednodušuje inventarizaci.
6 IMPLEMENTACE
43
Poté, co provedeme inventarizaci všech knih v knihovně nebo i v jejím průběhu se můžeme podívat na dosavadní výsledky inventarizace. Tyto výsledky se zobrazí kliknutím na položku Soubor, pak na položku Inventarizace a následně na Výsledky inventarizace. Pak se nám zobrazí okno kde je zobrazen souhrn výsledů z provedené inventarizace. Nejdůležitější položka je Počet chybějících knih (jejich seznam je možné si vytisknout a vést si evidenci ztracených knih v určitém období). Všechny chybějící knihy můžeme z databáze odstranit stisknutím jediného tlačítka Vymazat chybějící knihy z databáze. Pokud se chceme jen podívat, pak klikneme na tlačítko Zavřít.
6.6
Tisk reportů, čárových kódů a čtenářských kartiček
Tisk reportů se provádí do předem vytvořených šablon v programu iReport. Náhled výsledného reportu je zobrazen v programu JasperViewer, který slouží k náhledu na požadovaný report. Z JasperViewer je možné reporty přímo tisknout nebo je exportovat do již uvedených formátů. Uživatel si může vybrat, která data chce exportovat a která ne. Může využít tlačítek (od A do Z) pro rychlý výběr, pak použít různé filtry pro vyfiltrování hledaných záznamů a následně seřadit výsledek podle určitého sloupce. Tyto kombinace lze zvolit nezávisle na sobě. Poté stačí kliknout v hlavním menu na Soubor, pak na Export a Exportovat aktuální tabulku nebo použít klávesové zkratky Alt+E. Výsledný report obsahuje důležité informace pro určování aktuálnosti dokumentů, obsahuje především tyto informace: • • • • • •
název reportu - z které tabulky byl report vytvořen, datum a čas vytvoření dokumentu, jméno a příjmení uživatele, který report vytvořil, vlastní data - jednotlivé položky z tabulky, celkový počet položek v reportu, místo pro podpis uživatele, který report vytiskl.
Exportování reportů tabulek je velmi důležité u inventarizace, kde je možné sledovat i zpětně úbytky knih. Dále je velmi důležité exportování nad výpůjčkami jednotlivých čtenářů, kde si mohou ověřit svoje výpůjčky nebo nevrácené knihy. Samozřejmě je důležitý export i nad ostatními tabulkami, kde si knihovna může vést evidenci o nevrácených knihách od všech čtenářů, exportovat si všechny čtenáře knihovny, knihy co knihovna vlastní a spoustu dalších informací.
6 IMPLEMENTACE
44
Export čárových kódů je určen pro evidenci čtenářů a knih. Každý čtenář má přiřazen unikátní identifikátor CID a každá kniha má unikátní identifikátor OID. Tyto kódy jsou vyjádřeny pomocí čárového kódu, kterým se daná kniha nebo čtenář identifikují. Jako typ čárového kódu byl zvolen Code 128, který dokáže zobrazit až 128 znaků. Jedná se o jednorozměrný kód, který má chybovost 1 : 5 000 000. Aplikace si pamatuje poslední exportovaný kód pro čtenáře a pro knihu (je možné ho změnit a vytisknout případně nějaký kód znovu). Při vytváření nového čtenáře nebo knihy ještě probíhá kontrola na existenci kódu v databázi. Pokud je kód již v databázi použit, pak aplikace nedovolí znovupoužití stejného kódu pro jiné knihy nebo čtenáře. Čárové kódy jsou exportovány v počtu 24ks/stránku (osm kódů ve sloupci a tři kódy v řádku). Pro správný export je doporučen samolepící nařezaný papír s již uvedeným rozložením jednotlivých nařezaných částí. Aplikace tedy exportuje čárové kódy v počtu 24ks/stránku, stačí si zvolit počet požadovaných stran a automaticky se zobrazí celkový počet čárových kódů. Pro informaci je možné si zvolit náhled prvního z čárového kódu přímo do panelu aplikace. Po vyexportování se čárové kódy opět zobrazí v programu JasperViewer a pak je možné je opět uložit do libovolného formátu nebo vytisknout. Vzhledem k tomu, že se v knihovně nachází pouze inkoustová tiskárna a její tisk má mnohem menší životnost než tisk laserové tiskárny, proto je doporučené vyexportované čárové kódy uložit do formátu PDF a vytisknout je na laserové tiskárně, která je dostupná na radnici obce Kašnice. Export čtenářských kartiček je možno provést automaticky ihned po přidání nového čtenáře nebo ručně po vybrání čtenáře, kterému chceme čtenářskou kartičku vytisknou. Samozřejmostí je možnost tisku prázdných čtenářských kartiček, kde zaměstnanec knihovny pak ručně vyplní informace o čtenáři a zezadu nalepí čárový kód přidělený čtenáři. Kartička se skládá: • • • •
z černého rámečku, který usnadňuje následné vystříhnutí, z loga obce Kašnice, která knihovnu podporuje, CID čtenáře, kdyby čárový kód nebyl čitelný, jména a příjmení čtenáře nebo názvu knihovny (pokud se jedná o výměnný fond), • datum založení čtenáře. Opět po exportu je náhled zobrazen v programu JasperViewer. V tomto případě je možné z něj přímo tisknout na inkoustové tiskárně, protože logo obce je barevné
6 IMPLEMENTACE
45
a čtenáři nosí kartičky v peněžence, proto je dobré kartičku umístnit do fólie, ve které bude čárový kód dobře čitelný a nebude docházet k opotřebení kartičky.
6.7
Vlastní nastavení aplikace
Aplikace je optimalizována pro rozlišení 1024x768 pixelů a vyšší. Pro odstranění nepěkného vzhledu Javy byla použita knihovna Substance ve verzi 5.0 a možnost obrázkového menu, které si může uživatel sám vypnout. Aplikace je rozdělena do záložek a tím se stává velmi přehlednou a rychlou na ovládání. Uživatel (zaměstnanec knihovny) si může nastavit aplikaci podle sebe. Může si nastavit z několika oblastí: • zobrazení libovolné záložky po startu aplikace, • zapnutí/vypnutí obrázkového menu, – po přidání čtenáře, – po úpravě čtenáře, – jako prázdné čtenářské kartičky, – jako prázdné čtenářské kartičky pro výměnný fond; • inventarizace – je možné si zvolit možnost, že po zadání OID se nám kniha automaticky označí jako zinventarizovaná nebo se počká na stisk tlačítka OK, – při inventarizaci zobrazovat v tabulce: ∗ zinventarizované knihy - ty knihy jejichž OID byly zavedeny do systému, ∗ chybějící knihy - ty které nebyly zinventarizované a ani nebyly vypůjčené, ∗ nezinventarizované knihy - knihy, jejichž OID nebylo zavedeno do systému, ∗ vypůjčené nezinventarizované knihy - jedná se o knihy, které mají čtenáři vypůjčeny a jejich OID nebylo uvedeno v inventarizaci; • počet dnů, kdy čtenář může mít knihu vypůjčenou a po překročení této lhůty se kniha bude zobrazovat v nevrácených knihách, • při překročení limitu na vypůjčení knihy a následném vracení je možnost zobrazení varovné zprávy s počtem dnů, o kolik je kniha vrácena později, • rezervace knih - jedná se o nastavení, po kterém budou rezervace automaticky mazány, pokud si čtenář knihu nevyzvedne. Toto nastavení je pro budoucí možnost rozšíření webového katalogu,
6 IMPLEMENTACE
46
• synchronizace - zvolení synchronizace obou databází při startu i při ukončení aplikace a tím zajištění aktuálnosti informací. Administrátor systému má větší možnosti nastavení aplikace. Nastavení se týká zejména práce s databází. Administrátor má následující možnosti nastavení: • přidávání osob oprávněných se systémem pracovat - pracovníky knihovny, • nastavení synchronizace databází - pro každou tabulku je možné nastavit, od kterých záznamů se mají synchronizovat, • nastavení cesty k Derby databázi - defaultně je umístěna v domácím adresáře uživatele, který aplikaci spouští. Pokud má být aplikace spouštěna více uživateli (každý z nich má vlastní účet v peračním systému), pak musí být aplikace umístněna na místě, kde mají všichni uživatelé právo zápisu.
6.8
Rezervace knih
Požadavky na rezervaci knih nebyly, ale do budoucna je možné, že přibudou. Proto s tím bylo počítáno již při návrhu databázové struktury a celém vývoji aplikace. V návrhu databáze přibyla tabulka rezervace, do které čtenáři budou moct zadávat požadavky na rezervaci. Již nyní probíhá kontrola při vypůjčování, jestli vypůjčovaná kniha nebyla rezervována a pokud ano jestli čtenáři, který si ji právě půjčuje. Dále je počítáno s tím, že čtenáři budou moci prohlížet historii svých výpůjček, současné výpůjčky a editovat rezervace. To bude možné až po jejich autorizaci do internetového systému. V současné době je v tabulce Ctenari atribut Heslo, pomocí kterého budou čtenáři moct přistupovat ke svým internetovým účtům. Nyní se do položky heslo ukládá příjmení čtenáře bez diakritky. Jako přihlašovací jméno bude sloužit CID čtenáře. Po přihlášení si bude moci čtenář své heslo změnit. Pokud tedy přibude požadavek na rezervace knih, pak se nebude muset měnit databázová struktura ani aplikace. Pouze se vytvoří nové webové rozhraní, pomocí kterého čtenáři budou přistupovat k databázi. Rezervace knih se bude provádět pomocí webového klienta a data se budou ukládat do internetové databáze. Při spuštění nebo ukončení programu pro evidenci knih se provádí automatická synchronizace obou databází. Pokud si čtenář zarezervuje knihu, pak musí počkat na potvrzení rezervace, které automaticky udělí sama hlavní aplikace. Schválení rezervace proběhne v tom případě, pokud mezi jednotlivými synchronizacemi bude jediný požadavek na rezervaci daného výtisku, pokud bude více požadavků na stejný výtisk o rezervaci, bude rozhodovat čas rezervace.
6 IMPLEMENTACE
47
Může nastat případ, kdy si více čtenářů zarezervuje stejnou knihu ve stejný okamžik, v tomto případě bude o rezervaci rozhodovat nižší ID čtenáře. Rezervace knih maže opět hlavní aplikace a to v případě kdy kniha byla vypůjčena čtenáři, který si ji rezervoval nebo uplynula lhůta stanovená knihovnou pro rezervování knih (tuto lhůtu si může nastavit knihovna sama). Poté je rezervace zrušena a vymazána z obou databází.
6.9
Synchronice databází
Aplikace pracuje se dvěma databázemi nezávislých na sobě. Tím je možné docílit toho, že jsou data z knihovny dostupné na internetu i bez přístupů čtenářů přímo do hlavní databáze knihovny. Synchronizaci si mohou nastavit pracovníci knihovny podle sebe. Mohou si vybrat v synchronizaci při startu aplikace a při ukončení. Průběžná synchronizace nebyla zvolena, protože se neočekávají výrazné změny v databázi během jednoho spuštění aplikace. Synchronizace při startu bude využívána v budoucnu, jestli bude implementovaná část rezervací. Při startu by se pak stahovaly záznamy o nových rezervacích, nebo o datech upravených čtenáři. Synchronizace po ukončení aplikace odesílá nové přírůstky knih, vypůjčené nebo vrácené knihy, přidané čtenáře a spoustu dalších informací. Primární databáze je umístěná na počítači, kde se software spouští. Druhá aplikace je umístěna v internetu na stránkách obce Kašnice. Vzhledem k rychlosti internetu a počtu knih v knihovně se při synchronizaci knih stahuje z internetové databáze celá tabulka. Tato metoda se používá i pro tabulku čtenářů, rezervací a uživatelů, kdy se stáhne celá tabulka a následně jsou porovnány data z obou databází. Jak již bylo zmíněno, objekt nerovná se objekt (nelze tedy použít metodu local.equals(server), která by vrátila hodnotu true nebo false podle toho, jestli by byly objekty stejné nebo nikoli). Jelikož tuto metodu použít nelze, pak se musí jednotlivé položky objektu porovnávat zvlášť. To ukazuje následující příklad. public boolean compareUzivatele(Uzivatel local, Uzivatel server) { if (local.getId().compareTo(server.getId()) != 0) { return false; } if (!local.getLogin().equals(server.getLogin())) { return false; }
6 IMPLEMENTACE
48
if (!local.getPass().equals(server.getPass())) { return false; } if (local.isViditelnost() != server.isViditelnost()) { return false; } return true; } Synchronizace tabulky pro archiv výpůjček je složitější z toho důvodu, že i když je v knihovně relativně nízký počet knih a čtenářů, postupem doby by se délka synchronizace prodlužovala. Při synchronizaci této tabulky se tedy uchovává poslední správně odeslané ID. Není tak nutné stahovat tuto tabulku z internetové databáze vůbec a odesílají se pouze nová data. Pro synchronizaci databází se používají transakce, protože je možné, že se bude odesílat nebo přijímat větší množství dat a po cestě by mohlo dojít k přerušení spojení, pak by se data mohla nekorektně uložit do databáze. V případě, že proběhne všechno správně, pak se v databázi provede akce zvaná commit, která všechny provedené změny uloží. Jestliže nastane nějaký problém, poté se zavolá rollback a všechny příkazy provedené v transakci se odvolají. Stažení tisíce záznamů z internetu trvá něco kolem 10 vteřin. Nejdéle trvá navázání a ukončení spojení (tisíc záznamů má velikost cca 150 KB). Synchronizace celé databáze je tedy velmi rychlá a trvá maximálně pár minut (záleží na počtu provedených změn). Pokud se počet změn při spuštění aplikace pohybuje v řádu stovek až tisíců, pak se nijak výrazně neprodlužuje doba synchronizace. Internetová databáze slouží zároveň jako záloha lokální databáze. V případě poruchy počítače, stačí přemístit aplikaci na jiný počítač a hned lze aplikaci provozovat bez dlouhého nastavování a kopírování záznamů. V případě přeinstalování operačního systému se tedy nemusí vůbec nic zálohovat. Po nainstalování nového systému stačí do počítače zkopírovat systém pro evidenci knih a při prvním spuštění se automaticky vytvoří databáze, do které se opět automaticky stáhnou data z internetové databáze.
6 IMPLEMENTACE
6.10
49
Nápověda
Nápověda je vytvořená v prostém HTML, a proto ji lze jednoduše spouštět bez nutnosti přístupu k internetu nebo požadavku na vlastní webový server. Při prvním spuštění aplikace se nápověda rozbalí do domovského adresáře uživatele, který je aktuálně přihlášen do systému. Je to z toho důvodu, že jedině v tomto adresáři máme vždy právo zápisu souborů a nezáleží na operačním systému. Každý operační systém má svůj domovský adresář například: • Linux: /home/jmenoUzivatele • Windows XP: C:\Documents and Settings\jmenoUzivatele • Windows Vista: C:\Users\jmenoUzivatele Nápověda se spouští klávesou F1 nebo z hlavního menu položka Nápověda. Nápověda se spustí v defaultním internetovém prohlížeči nastaveném v počítači. Po spuštění se nápověda v internetovém okně zobrazí v levé části menu, kde si můžeme zvolit oblast problémů. Máme na výběr z položek: • Co je to E-knihovna - Informuje nás o tom, co to E-knihovna je a jaké služby nám nabízí. • Hardwarové požadavky - Popsány doporučené požadavky na hardware počítače. • Softwarové požadavky - Popsány požadavky na software, který má být nainstalovaný, aby program mohl být korektně spuštěn. • Instalace E-knihovny - Jedná se o postup, jak na počítači umístnit a provozovat software E-knihovna. • Popis funkcí - Jde o nejdůležitější část nápovědy. Tato část nám pomáhá s prací v celém programu. Jedná se především o: – evidenci knih - přidávání, odebírání, upravování, – evidenci čtenářů - přidávání, odebírání, upravování, – vypůjčování knih, – vracení knih, – archivace výpůjček, – získávání podrobných informací o výpůjčkách jednotlivých čtenářů, – inventarizace, – reportování tabulek, – tisk čárových kódů,
6 IMPLEMENTACE
50
– tisk čtenářských kartiček, – vlastní nastavení aplikace. • Tipy a triky - Zde jsou popsány klávesové zkratky, které nám usnadňují práci. Dále se zde nachází tipy k inventarizaci svazků knihovny. • Často kladené dotazy - V této části se nachází časté otázky a odpovědi na ně.
6.11
Webový katalog
Jde o zjednodušenou formu webového katalogu. Webový katalog je napsaný v PHP a bude umístněn na stránkách obce Kašnice, kde si všichni čtenáři budou moct prohlížet dostupné knihy v obecní knihovně. Katalog čerpá data z internetové databáze. Data jsou uložena v databázi MySQL, tato databáze je u poskytovatele internetových stránek obce Kašnice. Katalog umí vyhledávat až podle čtyř položek zároveň: • • • •
názvu knihy, autora knihy, nakladatele, žánru.
Data jsou seřazena podle názvu knihy a následně jsou zobrazena do přehledné tabulky, která obsahuje vždy nejvýše padesát položek. Pokud je výsledků vyhledávání více než padesát, pak jsou výsledky rozděleny do několika stránek. O knize se nám zobrazí následující informace: • • • • • •
ISBN, název knihy, autor, nakladatel, žánr, rok vydání.
7 ZÁVĚR
7
51
Závěr
Vytvořený program splňuje veškeré požadavky na něj kladené a je vytvořen tak, aby bylo snadné jej modifikovat pro potřeby jiných knihoven. Dle mého názoru i názoru odborníků, kteří se ve světě knihovních systému pohybují přes dvacet let, se jedná o velmi zdařilý program, který má všechny potřebné funkce pro malé knihovny. Nabízí i některé funkce, které největší knihovní systémy neposkytují. Příkladem může být schopnost práce v offline režimu, kdy knihovna ukládá záznamy do lokální databáze a čtenáři si mohou nezávisle na lokální databázi prohlížet katalog nabízených knih k vypůjčení. Aplikace je velmi pěkně graficky zpracována a přitom její náročnost na výpočetní techniku je malá. Knihovní systém je vhodný do menších knihoven, které vlastní až 20 000 svazků knih.5 Při vývoji aplikace jsem se setkal s několika problémy, které byly nutné vyřešit. Některé problémy byly jednoduché a některé složité. Mezi nejsložitější problémy patřilo vytváření čárových kódů a reportování výsledků. Nejprve jsem se pokoušel oba problémy řešit svépomocí. Byly prováděny pokusy o tvorbu vlastního čárového kódu, ale tyto pokusy skončily nezdarem. Reportování bylo prováděno pomocí technologie iText, ale výsledné reporty bylo velmi náročné vytvořit a bylo možné je ukládat vždy jen do jednoho formátu. Navíc výsledné zobrazení nevypadalo profesionálně. Oba tyto problémy úspěšně vyřešila technologie JasperReports. Dalším složitějším problémem bylo vymyšlení a zprovoznění synchronizace dvou databází. Tento problém byl úspěšně vyřešen pomocí replikací v technologii Hibernate. Tím, jak je aplikace napsaná, se stává skutečně multiplatformní aplikací. Nejen tím, že je napsaná v programovacím jazyku Java, ale také tím, jak je v tomto jazyku napsaná. Příkladem může být ukládání všech dat do domácího adresáře, který se nalézá na každém operačním systému, volba internetového prohlížeče se volí podle toho, jaký internetový prohlížeč je nainstalovaný a nastavený jako defaultní prohlížeč. Dalším příkladem je volba databáze, která je spustitelná také pod libovolným operačním systémem. Díky tomu je aplikaci možné spustit ihned a bez jakýchkoli úprav. Evidence knih není tak jednoduchým problémem, jak se na první pohled zdá, nebo jak je uváděno ve školách. Větší knihovny potřebují detailní popis každého 5
Databáze byla bezproblematicky testována s celkovým počtem 100 000 svazků. Hranice 20 000 svazků byla zvolena z důvodu velikosti knihovny a s tím souvisejících nižších nároků na funkce programu. S velikostí knihovny souvisí větší nároky na funkce programu, které ve stávajícím systému nejsou implementovány, neboť pro potřeby této malé knihovny nejsou požadovány.
7 ZÁVĚR
52
svazku, než jak jsou knihy evidovány v malých knihovnách. Velké knihovny obsahují vlastní servery, na kterých sdílí data, ke kterým se mohou připojit menší knihovny a následně přidávat do evidence knihy, které jsou evidovány na serverech velkých knihoven. Tato výměna probíhá většinou přes Z39.50 protokol, který se objevil již v roce 1970. Informace o knihách se předávají ve specifickém formátu USMARC, UNIMARC nebo SUTRS. Protokol Z39.50 pracuje na architektuře klient-server. Každá knihovna, která si chce stáhnout záznamy z jiné knihovny, tak systém který vlastní, musí obsahovat Z39.50 klienta. Poté si záznamy může stáhnout a uložit do vlastní databáze. Tento produkt byl poskytnut do obecní knihovny Kašnice zdarma z důvodu možnosti poskytnutí reálného prostředí pro testování. V současné době je testována finální verze a postupně je databáze evidence knih a čtenářů naplňována reálnými daty. Prozatím se nevyskytly žádné zásadní nedostatky při používání zaměstnancem knihovny.
8
8
LITERATURA
53
Literatura
JASPERSOFT CORPORATION, C. JasperForge. [online]. 2000-2009 [cit. 2009-04-01] Dostupný z WWW: < http : //www.jasperf orge.org/> . JAVA PORTÁL [online]. 2004 [cit. 2009-04-03] Dostupný z WWW: < http : //www.java.cz/> . KNIHOVNÍ ZÁKON 257/2001 SB. ze dne 29. června 2001 [online]. 2003 [cit. 2009-04-14 ] Dostupný z WWW: < http : //proknihovny.svkkl.cz/knihovni zakon.php/> . MINISTERSTVO KULTURY ČR [online]. 2008 [cit. 2009-04-14] Dostupný z WWW: < http : //www.mkcr.cz/scripts/detail.php?id = 443/k 20. listopadu 2008> . PECINOVSKÝ, R. Myslíme objektově v jazyku Java 5.0. 1. vyd. Praha: Grada Publishing, 2004. 601 s. Myslíme v–. ISBN 80-247-0941-4 RED HAT MIDDLEWARE, L. Relational Persistence for Java and .NET.[online]. 2008 [cit. 2009-02-18] Dostupný z WWW: < http : //www.hibernate.org/> . SPRING SOURCE COMMUNITY, C. Spring Framework. [online]. 2008 [cit. 2009-03-19] Dostupný z WWW: < http : //www.springsource.org/> . ŠEVČÍK, Jiří. Nový Přerov drtí nezaměstnanost. Břeclavský deník [online]. 2009 [cit. 2009-04-19] Dostupný z WWW: < http : //http : //breclavsky.denik.cz/zpravy region/novy − prerov − drti − nezamestnanost20090318.html/> . THE SOURCE FOR JAVA TECHNOLOGY COLLABORATION, Sun Microsystems, Inc. [online]. 1995-2008 [cit. 2009-03-22] Dostupný z WWW: < http : //www.java.net/> .
Přílohy
A NÁHLEDY APLIKACE
A Náhledy aplikace
Obr. 4: Přihlášení uživatele
Obr. 5: Nastavení aplikace
55
A NÁHLEDY APLIKACE
56
Obr. 6: Evidence knih
A NÁHLEDY APLIKACE
57
Obr. 7: Nápověda
A NÁHLEDY APLIKACE
58
Obr. 8: Webový katalog
B ELEKTRONICKÉ PŘÍLOHY
59
B Elektronické přílohy Elektronické přílohy této práce jsou následující6 : • Výsledný systém pro evidenci knih v knihovně. Databáze, nápověda a nastavení se vytvoří automaticky při prvním spuštění aplikace. • Webový katalog.
6
V tištěné verzi této práce jsou všechny elektronické přílohy umístěné na CD a jsou součástí této práce.