Weblog

NBÚ

Náš naozaj najbezpečnejší úrad, ktorý by sa mal starať o elektronickú bezpečnosť, je jednoznačne jediný na svete, ktorý má stránkové hodiny dokonca aj na svoje webové stránky (prístupné od 7.30 do 16.00), má pre istotu zverejnený Rozpočet na rok 2007 na localhost-e, aby hackeri vedeli, koľko peňazí bolo investovaných do zmeny hesla nbusr123 na nové – nbusr1234.

Toto je odkaz na spomínaný rozpočet:

http://localhost/…ocet2007.pdf

A čo asi znamená hodnota X-xxxxxxxx: xxxxxxxxxxxxx­xxxxxx v HTTP hlavičkách posielaných zo serveru?

Jedinej informácii na stránkach www.nbusr.sk naozaj verím: že medzi záľuby riaditeľa patrí rybárstvo a záhradkárstvo.

Microsoft okopíroval Javu

Toto je časté revanie malých detí, ktoré si myslia, že keď napíšu kód v Jave, tak sú programátori. Je to naozaj silný pocit prehnať kód javac kompilátorom a potom si myslieť, že toto je „programový kód“. java je však v skutočnosti interpretovaná, preto sa jedná o „skriptovací kód“.

Mýtus: Microsoft okopíroval Javu.

Fakt: citácia z knihy JSP – Java Server Pages, Barry Burd, 2003 Computer Pres­s:

Poohlédněme se teda za historií objektů typu JavaBeans. Ke knoci devadesátých let minulého století se programátoři ve vývojovém týmu firmy Sun Micrososystems dívali přes rameno svým kolegům v Redmondu. A co spatřili? Dozrávajíci model komponentového softwaru známý jako COM – neboli Microsoft Component Object Model. Objekty modelu COM byly z oblibou používány na webových stránkach známých pod označením ASP – Active Server Pages. Odpovědí firmy Sun byla specifikace JavaBeans (jako součást sady JDK 1.1).

Tento odstavec presne naznačuje, že Sun sa nechal inšpirovať komponentovým modelom COM od Microsoft-u.

Java jazyk vs. C#

Microsoft, ktorý údajne okopíroval Javu, sa pri návrhu jazyka C# (ktorý je syntakticky oveľa viacej podobný na C++ než na Javu) inšpiroval: autori C# zistili, že checked a unchecked exceptions sú úplná zbytočnosť, C# má narozdiel od Javy aj Vlastnosti, Delegátov, skutočné Udalosti a iné vymoženosti.

.NET narozdiel od Javy má skutočné generické typy – Java kompilátor odstráni informáciu o typovosti generických typov (tzv. erasures) – teda tieto informácie, nerozdiel od .NET, nie sú dostupné pomocou reflexie za behu programu. Podobne je tomu aj s atribútovým programovaním. Zatiaľ čo Java má v poslednej verzii úbohú podporu pre anotácie (veľmi zjednodušená obdoba atribútov), .NET už vo svojej prvej verzii podporuje plnohodnotnú prácu s atribútmi i pomocou reflexie. Plno „killing“ (alebo „that rocks!“) vlastností .NET-u je založených práve na atribútoch.

Ďalšie rozdiely medzi C# a Javou: Java vytvára všetky metódy ako virtuálne (explicitne treba zákazať pomocou final). C# (a .NET MSIL kód) ide presne opačnou cestou: virtuálne metódy treba explicitne označiť. Deklarácia implementácie rozhrania alebo rozširovania triedy sa v C# označuje operátorom : (ako v C++). Java používa kľúčové slová extends a implements. .NET (a teda aj C#) umožňujú explicitnú implementáciu rozhrania – Java nie.

Hodnotové a referenčné typy

Java obsahuje primitívne typy (ktoré sú naozaj primitívne a nedá sa s nimi robiť pomocou OOP – iba pomocou procedúr zaobalených do tried). .NET dotiahol unifikovanú OOP prácu s dátovými typmi takmer k dokonalosti – existujú hodnotové a referenčné typy, ktoré všetky dedia zo System.Object. Takto je skutočne zaručené, že všetky dátové typy dedia z jediného rootového typu. V Jave je toto obchádzané pomocou zaobalovacích tried. Základné dátové typy (bool, int, long, double, DateTime) sú hodnotové – tzn. vždy majú priradenú hodnotu. Takto sa vás nestane, že kompilátor za vás boxuje/unboxuje hodnoty, vy máte podmienku if (!isEditMode) { … } a zrazu dostanete NullPointerEx­ception.

Java Virtual Machine vs. .NET Runtime

Javisti si celkovo mýlia pojmy s dojmami a ani poriadne nerozlišújú medzi jazykom Java, jazykom C# a ich spúšťacími prostrediami – Java Virtual Machine a .NET Runtime. Mýtus okopírovania .NET modulu manažovanej správy pamäte vychádza práve z podobnosti správy pamäte v Jave. Treba však podotknúť, že manažovanú správu pamäti má aj PHP, Python, či JavaScript.

Finalizácia objektov je v .NETe oveľa lepšie vymyslená ako v JVM. .NET Garbage Collector umožňuje volať finalizátory (C# deštruktory) a podporuje IDisposable pattern. Ako som sa dočítal na webe, v Jave nie je vôbec zaručené vykonanie finalize() metódy a zdroje sa uvoľňujú v try/catch bloku. Vďaka definovanie IDisposable patternu a deštruktorom je možné správne uvoľniť zdroje, aj keď programátor spraví chybu a nepoužije napr. using() blok. Čo je ďalšia vec, ktorú jazyk Java nemá: blok using vygeneruje pre IDisposable objekty kompletný try/finally blok a dojde teda k správnemu a včasnému odstráneniu zdrojov.

No, to som sa ale rozpísal 🙂 Ako je vidieť, .NET ponúka oveľa bohatší programový model, ktorý je konzistentný a je založený na zdrojovom kóde (to je moje označenie. Java totiž strašne veľa vecí definuje iba v rôznych dokumentoch a špecikáciách (napr. JavaBeans a ich „vlastnosti“ = get, set, is). .NET vďaka využitiu atribútov poskytuje celé riadenie kompilátora, alebo vývojového prostredia zo zdrojového kódu.).

Človeka, ktorý píše skripty v Jave a hovorí si „programátor“, som určite nepresvedčil, že .NET a C# nie sú kópiou Javy. Ale ponúkol som prehľad výborných funkcií, ktoré nemajú svoj ekvivalent v Jave a vďaka ktorým viem, že som sa pred niekoľkými rokmi rozhodol správne, keď som sa začal učiť používať .NET platformu.

Aktulizácia: A skoro som zabudol na to, že pre .NET už môžete programovať vo vyše 30 jazykoch.

Klonované virtuálne počítače

Potreboval som si vytvoriť skúšobnú sieť o 3 serveroch (doména, DB, Sharepoint), tak som skúsil použiť VMware Workstation namiesto Virtual PC. Nainštaloval som Windows Server 2003 R2 Enterprise Edition, aplikoval Service Pack 2 a zaktualizoval. Potom som naklonoval tento virtuálny stroj a začal nastavovať počítače. Po vytvorení domény a pripojení serverov do nej som však začal mať problém ? nedalo sa prihlásiť do domény. Problém bol v duplicitnom SID počítačov. (Chybová hláška The name or SID of the domain specified is inconsistent with the trust information for that domain.)

Sysinternals však má dobrú utilitku NewSID, ktorá vygeneruje počítaču nové SID. Pred vygenerovaním a aplikovaním nového SID však je potrebné počítač odpojiť z domény, pretože novo aplikované SID nebude mať žiadne práva v doméne. Bude sa dať prihlásiť do domény avšak bude problém s právami počítača.

PS: 4GB disk je málo pre Windows Server 2003 R2 Enterprise Edition SP2. Po inštalácii zaberá 3GB.

Logo stránky

Prečo použiť štandardný kód:

<div class=„logo“><a href=„/“><img src=„/images/com­pany.png“ alt=„Company Ltd.“ />

keď to ide aj takto:

<div title=„Company Ltd.“ class=„logo“ onclick=„launchMe­nu(‚main‘);“ onmouseover=„this­.style.cursor=‚han­d‘; this.style.cur­sor=‚pointer‘;“ style=„background-image: url(/images/com­pany.gif)“></div>

Burning Crusade – prvé dojmy

Pred Brlohom bolo natrieskané, vyzeralo to na 150–200 ludí. Museli predčasne otvoriť (už o 23:45, oproti pôvodne plánovanému času 0:00 ? veď aj Dark Portal je jednosmerne otvorený už pár dní…) a za pol hodinu boli vykockované hracie karty a game kupóny, takže už sa hralo jedine o knižky. Tri šestky a teda Burning Crusade zdarma, knižka a karty ako výhra padli len raz.

Momentálne to vyzerá tak, že inteligentný inštalátor upgraduje World of Warcraft a počas kopírovania súborov umožňuje vykonať upgrade konta na rozšírenú verziu. Servre sú však preťažené a treba si počkať :-). Približne od času, kedy mohol byť Burning Crusade dostupný v Japonsku, sa zmenila aj úvodná stránka WOW Europe, ktorá je odľahčená, pretože mali kapacitné problémy. Americká stránka teraz je tiež prerobená v štýle „Dark Portal is opening“ s možnosťou upgradovať si konto.

Počítač vo vašej dlani

Najdôležitejší obsah svojho PC, ktorý potrebujete mať na cestách, môžete mať vo svojej dlani už dávnejšie (a aj z Mac-u). SoonR služba umožňuje prístup k súborom, e-mailom, kalendáru a aj Skype chatom cez mobilný telefón. Teraz však získate ešte rýchlejší a pohodlnejší prístup k svojim údajom: je tu jedna z prvých Ajax aplikácii pre mobily!

Ak vlastníte mobilný telefón na ktorom dokáže bežať Opera Mobile, máte možnosť si už teraz vyskúšať jednu z prvých Ajax aplikácií pre mobilné prehliadače. Ajaxové stránky sme optimalizovali pre rýchly prenos dát, takže sú oveľa rýchlejšie ako klasický mobilný HTML interface a podstatne s ním ušetríte dátový prenos. Vďaka Ajaxu je možné si priečinok s obrázkami spustiť ako slide-show prezentáciu.

Marketingové info: SoonR Sizzles on AJAX

Načítavanie údajov z DB pomocou SqlDataReader-u

SqlDataReader je veľmi efektívny pri načítavaní údajov z databázy, pretože obsahuje vždy jeden riadok a načítava údaje postupne. Koncept (algoritmus) načítavania údajov je defacto je pri každom načítavaní jednotný. Problémom je ako dostať dáta z readeru a spracovať ich a mať počas toho aj otvorené pripojenie do databázy (SqlDataReader samozrejme vyžaduje počas čítania aktívne pripojenie).

Najľahšie sa dá napísať všeobecná metóda pre vykonávanie SQL príkazov cez metódu SqlCommand.Exe­cuteNonQuery(). Jej návratová hodnota je void, netreba ju teda nijako spracovať a nič vracať z vlastnej metódy.

Metóda ExecuteScalar() sa dá ľahko zaobaliť: buď bude metóda vracať Object, ktorý vracia ExecuteScalar(), alebo pri použití generík môže zaobaľujúca metóda vracať špecifický typ daný generickým parametrom.

Pri použití ExecuteReader() treba údaje nejako spracovať.

Práca so SqlDataReader-om

  • Pripravíme si objekt SqlConnection a SqlCommand
  • Otvoríme spojenie do databázy
  • Spracujeme údaje zo SqlDataReader-u
  • Uzatvoríme spojenie s databázou
  • Zrušíme objekty pomocou Dispose() metódy
  • Vrátime spracované údaje

Ako som spomenul, problém spočíva v tom, ako vytvoriť všeobecnú metódu, ktorá údaje zo SqlDataReader-u vytvorí špecifický dátový typ (IList, dátová tabuľka, užívateľské konto, produkt…) a vráti ho.

Prvá časť, ktorá je generická v tejto metóde, je návratová hodnota. Pred otvorením spojenia s databázou nainštancujeme návratovú premennú na východziu hodnotu operátorom default(). (Operátor default() inicializuje číselné typy na hodnotu 0, referenčné typy na null a v štruktúrach nastaví číselné a referenčné typy obdobne.) Po získaní objektu SqlDataReader vytvoríme inštanciu návratového objektu, poupratujeme za sebou a vrátime výsledok.

Ukážka 1.

Druhá generická časť je vytvorenie objektu. Na vstupe máme objekt SqlDataReader, na výstupe generický typ T. Generická metóda by vyzerala takto:

public T DataReaderHan­dle<T>(SqlData­Reader reader); 

Keď túto metódu zavoláme v časti ?spracovanie údajov?, vykonávanie sa tak presunie do užívateľského kódu a po vytvorení objektu sa vráti k štandardnému toku programu. Tu využijeme callback pomocou delegátov. Delegát určuje predpis metódy, ktorá má byť zavolaná a je možné ho použiť ako parameter funkcie. Ukážková metóda DataReaderHandle bude ako delegát vyzerať takto:

public delegate T DataReaderHan­dle<T>(SqlData­Reader reader); 

Ešte treba pridať delegát ako parameter do metódy a vyvolať metódu, na ktorú ukazuje:

Ukážka 2.

Už len stačí napísať metódy, ktoré budú spracovávať SqlDataReader a vytvárať patričné objekt. Keď máme triedu User so statickou metódou ParseUser vracajúcu objekt User, stačí zavolať ExecuteReader takto:

User user = DbLayer.Execu­teReader<User>(U­ser.ParseUser, „UserDetails“, sqlParams); 

Knižnica DbLayer: /weblog/media/dot­net/DbLayer.cs

Prečo programujeme v C-jazykoch?

Či už píšeme programy v jazyku C++, C#, Java a iných jazykoch založených na C (jedna prípustná syntax v PHP je podobná C, ale v PHP sa neprogramuje), nie je problém prečítať kód napísaný v inom C-style jazyku (i keď pochopenie je už ťažšie :-)). Prečo však bol jazyk C pomenovaný týmto písmeno a nie iným?

Jazykom, ktorý mal na históriu programovacích jazykov veľmi veľký vplyv bol ALGOL (algorithmic language) z roku 1958. Populárnym sa stal v roku 1960 po vzniku jednoduchšej varianty ALGOL-60. Jazyk bol portovateľný, s nízkou abstrakciou hardware a vyvinutý pre písanie algoritmov. ALGOL-68 pridal do jazyka nové vlastnosti, ale zvýšil jeho komplexnosť a abstrakciu hardwaru.

Roku 1963 Compoter Lab of Cambridge University prišiel s jazykom CPL. CPL bol založený na ALGOL-e, znižoval abstrakciu HW, ale zachovala sa v ňom komplexnosť ALGOL-u. Martin Richards navrhol Basic CPL (BCPL), ktorý bol okresanou verziou CPL. Tento jazyk ešte zlepšil Ken Thompson z Bell Labs svojím B jazykom.

Jazyk B bol oveľa vhodnejší na systémové programovanie, jednoduchší a rýchlejší. Jeho nástupca, C, vyšiel z Bell Labs roku 1972. So zachovaním jednoduchosti priniesol nový jazyk vyššiu abstrakciu hardware ako jeho predchodca.Pôvodne určený jazyk pre UNIXové systémy sa stal univerzálne použiteľný programovací jazyk.

Samostatne od procedurálnych programovacích jazykov bol navrhnutý jazyk na tvorbu simulácií ? Simula, vyvinul sa však na univerzálny objektovo orientovaný jazyk. Priniesol hlavné koncepty OPP: triedy, dedičnosť, dynamické väzby.

Kombináciou C a Simula vznikol priamy nástupca C ? C++ (1983) s novými vlastnosťami ako šablóny alebo výnimky.