Je uživatel online?
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Je uživatel online?Je uživatel online?

 

Je uživatel online?

Google       Google       26. 1. 2008       17 971×

Každý z nás to jednou zažil. Přijdete na stránky nějaké firmy, chcete se zeptat zástupců této firmy, ale nevíte, komu napsat. Navíc firma používá svůj vlastní komunikátor. Proto se často využívají tzv. status ikony, které vám jasně poví, který člen firmy odpoví ihned. Já vám dneska povím, jak si vytvořit tuto jednoduchou status ikonu.

Reklama
Reklama

Obvykle, když se podíváte na vlastnosti takovéto ikony, zjistíte, že je URL např.:

http://www.server.cz/images/stats.php?par=style1|1

Pro představu vám zde ukáži dva příklady z praxe:

Příklad 1 (chat Lide.cz – Python a CGI)
Příklad 2 (ICQ)

Co jen to ten uživatel po nás chce?

Víme, že by uživatel rád věděl, jestli je na stránkách přítomen i někdo z členů firmy (vývojového týmu). Ale jak přesně určit, od kterého uživatele by chtěl vidět stav? Veškeré potřebné uživatelské údaje jsou skriptu předány pomocí metody GET. Pro názornost využijeme této adresy:

http://www.server.cz/images/stats.php?par=style1|1

Parametr par si pomocí funkce explode() rozdělíme a pomocí funkce list() přiřadíme do proměnných.

GET je metoda komunikace mezi klientem a serverem. Při metodě GET je dotaz předán pomocí URL. Použijeme-li metodu POST, bude dotaz předán v hlavičkách.

Více informací: originální dokumentace

<?php
//vytvoreni promennych styl a idecko
list($styl, $idecko)=explode("|",$_GET["par"]);
// $styl = je hodnota urcujici podobu ikony
// $idecko = identifikátor člena
?>

Databáze MySQL

Veškeré informace o členech máme uloženy v databázi. Když už víme, o kterého člena se bude jednat, můžeme z databáze zjistit, zda je zrovna připojený a kde se na stránkách nachází.

Vzorová tabulka

Představte si, že máme v databázi tabulku clenove, která má 4 sloupce. Sloupec id je identifikátor jednotlivých členů – každý člen má svůj jedinečný identifikátor.

TABULKA: clenove
id jmeno prijmeni stav
1 jmeno1 xxxxxx online
2 jmeno2 yyyyy forum
3 jmeno3 zzzzz ofline
4 jmeno4 vvvvv chat
5 jmeno5 uuuuu online
6 jmeno6 ttttt chat
7 jmeno7 wwwww online

Dolování v databázi

Díky tomu, že jsme si rozdělili dotaz do dvou proměnných, nyní můžeme z databáze vydolovat data, která se týkají pouze dotyčného člena.

<?php
//navazani spojeni se serverem
$kontakt=mysql_connect($server, $nick, $heslo);
if(!$kontakt) {
	$image="status/$styl/chyba.gif";
	//nacteni prislusne ikony
	$im=imagecreatefromgif($image);
	//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
	header("Content-Type: image/gif");
	//zobrazeni ikony
	imagegif($im);
	destroy($im);
	mysql_close($kontakt);
	exit;
}
//vyber databaze
$vybrano=mysql_select_db($databaze);
if(!$vybrano) {
	$image="status/$styl/chyba.gif";
	//nacteni prislusne ikony
	$im=imagecreatefromgif($image);
	//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
	header("Content-Type: image/gif");
	//zobrazeni ikony
	imagegif($im);
	destroy($im);
	mysql_close($kontakt);
	exit;
}

//ochrana pred injection
if(!is_numeric($idecko)){
	$image="status/$styl/chyba.gif";
	//nacteni prislusne ikony
	$im=imagecreatefromgif($image);
	//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
	header("Content-Type: image/gif");
	//zobrazeni ikony
	imagegif($im);
	destroy($im);
	mysql_close($kontakt);
	exit;
}

//kontrola spravnosti stylu
if($styl != "style1" && $styl != "style2"){
	$image="status/style1/chyba.gif";
	//nacteni prislusne ikony
	$im=imagecreatefromgif($image);
	//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
	header("Content-Type: image/gif");
	//zobrazeni ikony
	imagegif($im);
	destroy($im);
	mysql_close($kontakt);
	exit;
}


//dotaz na daneho clena
$info=mysql_query("SELECT stav FROM clenove WHERE id = '$idecko'");
$pocet=mysql_num_rows($info);
if($pocet == '0') {
	$image="status/$styl/neexistuje.gif";
	//nacteni prislusne ikony
	$im=imagecreatefromgif($image);
	//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
	header("Content-Type: image/gif");
	//zobrazeni ikony
	imagegif($im);
	destroy($im);
	mysql_close($kontakt);
	exit;
}
$informace=mysql_fetch_array($info);

mysql_close($kontakt);
?>

Vytvoření ikony

Pro vytvoření ikony budeme ještě na serveru potřebovat soubory online.gif, offline.gif, chat.gif, forum.gif rozmístěny následovně (vycházíme z  umístění http://www.server.cz/images/):

  • status (složka)
    • style1 (podsložka)
      • online.gif
      • offline.gif
      • chat.gif
      • forum.gif
      • neexistuje.gif
      • chyba.gif
    • style2 (podsložka)
      • online.gif
      • offline.gif
      • chat.gif
      • forum.gif
      • neexistuje.gif
      • chyba.gif
<?php
$image="status/$styl/".$informace[0].".gif";
//nacteni prislusne ikony
$im=imagecreatefromgif($image);
//odeslani hlavicky ohledne zobrazovaneho typu (mime-type)
header("Content-Type: image/gif");
//zobrazeni ikony
imagegif($im);
destroy($im);
?>

Závěr

A to je zatím vše. Dneska jsme si ukázali, jak lehce vytvořit status ikonu pomocí PHP. Díky tomuto řešení (ikonka v externím souboru) je možno ikonku použít i na jinčích stránkách (blogu, osobní stránky, ...).

Poznámka autora:
V článku je schválně užit delší tvar $_GET["par"]. V případě serveru, kde budete mít povoleny register_globals stačí napsat jen $par a účinek bude stejný. Jestli vám vadí přípona .php, tak si ji změňte na .img a do souboru httpd.conf vložte řádek:
application/x-httpd-php .img

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Hlasování bylo ukončeno    
0 hlasů
Google
Autor vystudoval SPŠe ve Frenštátě pod Radhoštěm a to v oboru Automatizace. Po škole začal na plný úvazek pracovat pro firmu Siemens VDO jakožto technik výrobních prostředků. V současné době pracuje jakožto PLC Specialista ve firmě IMI Norgren CZ. Zvládá programování PLC od firem Mitsubishi, Omron a Beckhoff, ale autorovou nejsilnější stránkou jsou PLC SIEMENS. Dále se zajímá o identifikaci kusů ve výrobě, strojové vidění a průmyslovou komunikaci. Jeho zájmem v IT jsou PHP, HTML, CSS, JavaScript, RSS, MySQL, MS MQL, Visual Basic.NET, C# a ASP.NET. Mimo IT se zabývá historickým šermem a ohňovými efekty. Rád poslouchá starší skupiny jako třeba Scorpions, Queen, Def lepard, Kiss, Gun's roses a podobné "klasiky" ;-)
Web    

Nové články

Obrázek ke článku Nový IT hráč na českém trhu

Nový IT hráč na českém trhu

V roce 2015 otevřela v Praze na Pankráci v budově City Tower své kanceláře společnost EPAM Systems (NYSE:EPAM), jejíž centrála se nachází v USA. Společnost byla založená v roce 1993 a od té doby prošla velkým vývojem a stále roste.

Reklama
Reklama
Obrázek ke článku České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace (CRA) pořádají druhý ročník CRA IoT Hackathonů. Zájemci z řad vývojářů a fanoušků moderních technologií mohou změřit své síly a během jediného dne sestrojit co nejzajímavější funkční prototyp zařízení, které bude komunikovat prostřednictvím sítě LoRa. CRA IoT Hackathony se letos uskuteční ve dvou fázích, na jaře a na podzim, v různých městech České republiky. Jarní běh se odstartuje 31. března v Brně a 7. dubna v Praze.

Obrázek ke článku Cloud computing je využíván stále intenzivněji

Cloud computing je využíván stále intenzivněji

Využívání cloud computingu nabývá na intenzitě. Jen v letošním roce vzroste podle analytiků trh se službami veřejného cloudu o 18 %, přičemž o téměř 37 % vzrostou služby typu IaaS. Růst o více než pětinu pak čeká služby poskytování softwaru formou služby, tedy SaaS. Aktuálním trendům v oblasti využívání cloudu se bude věnovat konference Cloud computing v praxi, která se koná 23. března. 2017 v pražském Kongresovém centru Vavruška na Karlově náměstí 5.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý