Steve Jobs a superpočítač Cray-1 budou vyobrazeny na pamětních jednodolarových mincích vyražených v příštím roce v rámci série Americká inovace. Série má 57 mincí, tj. 57 inovací. Poslední 4 mince budou vyraženy v roce 2032.
Byl zveřejněn průběžně aktualizovaný program konference OpenAlt 2025 o otevřeném softwaru a datech, IT bezpečnosti, DIY a IoT. Konference proběhne o víkendu 1. a 2. listopadu v prostorách FIT VUT v Brně. Vstup je zdarma.
Senát včera opětovně nepřijal návrh ústavního zákona, který měl do Listiny základních práv a svobod zakotvit právo občanů platit v hotovosti nebo být off-line. Návrh předložila skupina senátorů již v roce 2023. Senát dnes návrh neschválil, ale ani nezamítl. Pokud by ho přijal, dostala by ho k projednání Sněmovna a vyjádřila by se k němu vláda.
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 13.0 (Mastodon). Forgejo je fork Gitei.
Společnost Eclypsium se na svém blogu rozepsala o bezpečnostním problému počítačů Framework. Jedná se o zranitelnost v UEFI umožňující útočníkům obejít Secure Boot.
Editor kódů Zed (Wikipedie) po macOS a Linuxu s verzí 0.208.4 už běží také ve Windows.
Apple dnes představil 14palcový MacBook Pro, iPad Pro a Apple Vision Pro s novým čipem M5.
Debian pro mobilní zařízení Mobian (Wikipedie) byl vydán ve verzi 13 Trixie. Nová stabilní verze je k dispozici pro PINE64 PinePhone, PinePhone Pro a PineTab, Purism Librem 5, Google Pixel 3a a 3a XL, OnePlus 6 a 6T a Xiaomi Pocophone F1.
Operátor O2 představil tarif Datamanie 1200 GB . Nový tarif přináší 1200 GB dat s neomezenou 5G rychlostí, a také možnost neomezeného volání do všech sítí za 15 Kč na den. Při roční variantě předplatného zákazníci získají po provedení jednorázové platby celou porci dat najednou a mohou je bezstarostně čerpat kdykoli během roku. Do 13. listopadu jej O2 nabízí za zvýhodněných 2 988 Kč. Při průměrné spotřebě tak 100 GB dat vychází na 249 Kč měsíčně.
Byly publikovány informace o útoku na zařízení s Androidem pojmenovaném Pixnapping Attack (CVE-2025-48561). Aplikace může číst citlivá data zobrazovaná jinou aplikací. V demonstračním videu aplikace čte 2FA kódy z Google Authenticatoru.
Pro účely tohoto článku byl vytvořen ilustrační miniprojekt, kterého účelem je vytvořit dva provázané fiktivní produkty:
Uvedené aplikace se omezí pouze na to, že vypíší parametry připojení. Pro zjednodušení jim budeme dále zkráceně říkat klient a server.
Kompletní kompilovatelný projekt si můžete stáhnout zde. Autor jej vytvořil s přesvědčením, že může být pro vás inspirací pro vaše projekty. Pokud jej vylepšíte, bude vděčný za vaše připomínky a návrhy.
Struktura projektu je znázorněna na následujícím obrázku:
V hlavním adresáři se nacházejí tři soubory. Soubor
build.xml
obsahuje hlavní antovský skript, kterého
jediným účelem je inkrementovat číslo buildu nacházející
se v souboru build.number
a spouštět Antovské
skripty pro klienta a server, umístěné v příslušných podadresářích
src/client
a src/server
.
Soubor build.properties
obsahuje pouze odkaz na příslušný
konfigurační profil definovaný v podadresáři conf
:
# Soubor nastaveni pro build file je ulozen v prislusnem konfiguracnim
|
Konfigurační profil dmi.properties
používá vývojář
dmi na svém počítači, který se jmenuje dmi
.
Kromě definice některých proměnných dále větví konfigurační profil
pomocí odkazů na soubory v podadresářích jdbc
a
jndi
. Tzn. nenastavuje zbytečně mnoho proměnných, které by
se v každém profilu opakovaly, ale obsahuje přepínač na konkrétní sadu
nastavení, v tomto případě typ jdbc driveru a typ aplikačního serveru.
Adresář src
obsahuje dva izolované podprojekty.
Následující obrázek ukazuje strukturu podprojektu klienta:
Podadresář build
obsahuje soubory vznikající během buildu,
tedy zkompilované soubory a výsledný zabalený produkt
(package
), včetně knihoven.
Adresář java
obsahuje zdrojové
kódy tříd projektu, lib
knihovny nezbytné pro kompilaci a
spuštění (skript by je měl nakopírovat do package
).
Adresář rsrc
obsahuje další soubory (resources), které aplikace potřebuje za běhu. Tyto soubory jsou rozděleny do dvou skupin.
Soubory v adresáři etc
se přibalí k výslednému jar
souboru, takže jsou dostupné v classpath
za běhu aplikace.
Soubory v adresáři main
se nakopírují do hlavního adresáře
produktu - typicky se jedná o spouštěcí dávky.
Zajímavé na souborech v adresáři rsrc
je, že obsahují
odkazy na proměnné definované v konfiguračním profilu. Např.
spouštěcí dávka run.sh
je napsána velmi obecně. Zvlášť
zajímavé je předání hodnot client.property1
a client.property2
, které jsou pak aplikaci k dispozici
pomocí volání System.getProperty("client.property1");
a System.getProperty("client.property2");
:
#/bin/sh
|
Výhoda substituce parametrů rsrc souborů pomocí konfiguračních profilů
se stane zřejmá, když potřebujeme stejný parametr použít na více místech.
Jelikož klient by měl být alternativě spustitelný také pomocí
jnlp
souboru, přijde vhod možnost předat klientovi stejné
parametry také pomocí jnlp
spouštěče:
<?xml version="1.0" encoding="UTF-8" ?>
|
Teorie bylo už dost, podívejme se na výstup klientské aplikace pro jednotlivé konfigurační profily:
Profil dmi:
01 Ant Demo, build 6
|
Profil prof2:
01 Ant Demo, build 6
|
Ve dvou výše uvedených výstupech vidíme následující rozdíly:
Serverová aplikace je strukturována téměř identickým způsobem jako
klient. Rozdíl je pouze ve struktuře adresáře package
,
který zahrnuje podadresáře lib
a etc
.
Narozdíl od klienta není obsah adresáře rsrc/etc
přibalován přímo do výsledného jar
souboru,
ale ponechán jako adresář, který je přidán do classpath
ve spouštěcí dávce. Díky tomu lze měnit konfiguraci nainstalovaného
produktu bez nutnosti rebuildu (hesla, nastavení logu apod.).
Ant poskytuje vše, co je třeba pro robustní strukturu projektu. Klíčovým prvkem je možnost nastavovat proměnné a při kopírování provádět substituci ve zdrojových souborech. Tímto jsme však nahlédli pouze do jedné z mnoha kapitol podpory projektu, kterou Ant přináší. Pro Ant existuje celá řada užitečných tasků, ať již integrovaných nebo třetích stran - generátorů kódu (XDoclet), formáterů zdrojových kódů, kontrol kvality zdrojového kódu, podpory pro unit testing apod.
Pokud jste ještě Ant nikdy nepoužili, vyzkoušejte jej - a uvidíte, že si pak bez něj nebudete dokázat představit svůj programátorský život. Je velmi dobře zdokumentovaný, obsahuje jak úvod typu "snadno a rychle", tak solidní referenční příručku.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: