abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
dnes 22:11 | Pozvánky

Ve středu 19. dubna proběhne v Praze v Národní technické knihovně konference zaměřená na kontejnery Containers Roadshow. Organizují ji DevConf.cz a Prague Containers. Vstup je zdarma. Přednášky, prezentace i workshopy budou v češtině.

Ladislav Hagara | Komentářů: 0
dnes 21:22 | Nová verze

Byla vydána nová verze aplikace pro instant messaging Telegram (Wikipedie). Přináší především šifrované hlasové hovory.

Ladislav Hagara | Komentářů: 0
včera 23:22 | Komunita

Na dnes, poslední středu v březnu, připadá Document Freedom Day (DFD, Wikipedie), jenž má upozornit na výhody otevřených standardů a formátů dokumentů. Organizátoři se rozhodli, že letos proběhne Document Freedom Day dvakrát. Druhý letošní Document Freedom Day proběhne 26. dubna.

Ladislav Hagara | Komentářů: 0
včera 12:33 | Nová verze

Byla vydána nová stabilní verze 1.8 (1.8.770.50) webového prohlížeče Vivaldi (Wikipedie). Z novinek vývojáři zdůrazňují vylepšenou historii prohlížení. Ukázka na YouTube. Chromium bylo aktualizováno na verzi 57.0.2987.111.

Ladislav Hagara | Komentářů: 0
včera 05:55 | Zajímavý projekt

Google na svém blogu věnovaném open source představil portál Google Open Source informující mimo jiné o více než 2000 open source projektech vyvíjených nebo používaných v Googlu.

Ladislav Hagara | Komentářů: 2
včera 03:33 | IT novinky

Pro společnost Red Hat skončil 28. února fiskální rok 2017. Dle finančních výsledků bylo čtvrté čtvrtletí, stejně jako celý fiskální rok 2017, opět úspěšné. Tržby jsou zvyšovány již 60 čtvrtletí v řadě. Za čtvrté čtvrtletí 2017 to bylo 629 milionů dolarů, tj. meziroční nárůst 16 %. Tržby za celý fiskální rok činily 2,4 miliardy dolarů, tj. meziroční nárůst 18 %.

Ladislav Hagara | Komentářů: 2
28.3. 18:22 | Bezpečnostní upozornění

V balíčku eject, příkaz pro vysunutí CD/DVD z mechaniky, v linuxových distribucích Ubuntu (USN-3246-1) a Debian (#858872) byla nalezena bezpečnostní chyba CVE-2017-6964 zneužitelná k lokální eskalaci práv. Linuxové distribuce používající eject z balíčku util-linux nejsou zranitelné.

Ladislav Hagara | Komentářů: 15
28.3. 05:55 | Komunita

Dries Buytaert, autor a vedoucí projektu Drupal a prezident Drupal Association, požádal soukromě před několika týdny Larryho Garfielda, jednoho z klíčových vývojářů Drupalu, aby projekt Drupal opustil. Larry Garfield minulý týden na svých stránkách napsal, že důvodem jsou jeho BDSM praktiky a rozpoutal tím bouřlivou diskusi. Na druhý den reagoval Dries Buytaert i Drupal Association. Pokračuje Larry Garfield [reddit].

Ladislav Hagara | Komentářů: 55
28.3. 04:44 | Humor

Společnost SAS zveřejnila na svých stránkách studii s názvem Open Source vs Proprietary: What organisations need to know (pdf). Organizace by měly například vědět, že ideální je mix 40 % open source softwaru a 60 % proprietárního softwaru [Slashdot].

Ladislav Hagara | Komentářů: 13
27.3. 23:33 | Zajímavý software

Byl vydán ShellCheck ve verzi 0.4.6. Jedná se o nástroj pro statickou analýzu shellových skriptů. Shellové skripty lze analyzovat na webové stránce ShellChecku, v terminálu nebo přímo z textových editorů. Příklady kódů, na které analýza upozorňuje a doporučuje je přepsat. ShellCheck je naprogramován v programovacím jazyce Haskell. Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (14%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 972 hlasů
 Komentářů: 72, poslední 1.3. 11:16
    Rozcestník

    Dotaz: BUG v PHP array_search a in_array ?

    21.5.2015 12:33 Sparrow | skóre: 4 | blog: Sparrow
    BUG v PHP array_search a in_array ?
    Přečteno: 284×

    Zdravím,

    teď jsem narazil na asi docela velký problém.
    Při hledání v poli mi to tam najde hodnotu která tam není :)

    Konkrétně jde o kontrolu voucherů ze Slevomatu, zda zákazník nezadá jeden voucher 2x.
    Bohužel si z nějakého důvodu PHP myslí že 6089139600E-908 = 3767958990E-624.

    Zkoušel jsem to php sanboxu a zjistil, že to blbne až od PHP v 5.2 :) V nižších verzích to funguje správně.

    Výsledek následujího kódu je FIND IN 2

    viz http://sandbox.onlinephpfunctions.com/code/df586ba56c8547a21853cade3dd5659195de4852

    To samé dělá i in_array, vrací TRUE.

    Vyřešil jsem to tím, že pole převedu na řetězec oddělený | a potom to hledám pomocí STRPOS, ale docela mne to rozhodilo.

    Co vy na to?

    Dan

     
    $allCode=array(
        0 => "4911843820E-152",
        1 => "9189208690C-823",
        2 => "6089139600E-908",
        3 => "1847645250C-229",
    );
    
    $findCode="3767958990E-624";
    
    $search = array_search($findCode,$allCode);
    
    if($search !== false){
        echo "FIND IN ".$search;
    }else{
        echo "NO FIND";
    }
    

    Řešení dotazu:


    Odpovědi

    21.5.2015 12:38 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Řešení 1× (Sparrow (tazatel))
    21.5.2015 13:00 lofcek
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Kratkodobe riesenie: Staci do search_array pridat posledny parameter (strict) true. Potom to bude fungovat.

    Dlhodobe riesenie: Prestat pouzivat PHP, uz asi milion krat som zastal na podobnych koninach. Dalsi podobny bonus - retazec "0" je vyhodnoteny ako false a podobne. Proste ked jazyk vznikol bol dobry, ale dnes uz patri na zasluzeny odpocinok.
    Řešení 1× (Sparrow (tazatel))
    21.5.2015 14:29 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Přidání parametru strict je dlouhodobým řešením.

    Dalším (a podle mne mnohem vhodnějším) dlouhodobým řešením je použití databáze, která ve většině případů umí hledat mnohem lépe než PHP.

    "0" přece je false. Nechápu, čemu se divíš. Pokud ti to nevyhovuje, použij jiný predikát.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    Jendа avatar 21.5.2015 16:41 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    "0" přece je false.
    Ale tazatel nemá "0", ale string s nějakým bordelem. Jenom PHP se snaží být strašně chytré a vyrábí ze stringů floaty a další věci podle potřeby.
    Nezapomeňte si posunout časovače na svých bombách o hodinu dopředu!
    21.5.2015 17:47 chrono
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Keď poviem Php, aby sa pokúsilo porovnať podobné objekty (napr. pomocou ==, array_search bez strict, ...) zmenou typu, tak nemôžem byť prekvapený, že to naozaj urobí.
    Jendа avatar 21.5.2015 19:38 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Samozřejmě, a to je deceptive default.
    Nezapomeňte si posunout časovače na svých bombách o hodinu dopředu!
    21.5.2015 20:06 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Obvykle je nejlepší takové konstrukce v PHP nepoužívat.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    21.5.2015 17:01 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Díky za nakopnutí, toho parametru jsem si vůbec nevšiml (nebo zapomněl) nebyl do teď potřeba.

    Jinak DB není potřeba jde o eShop a kontrolu pár kódů, než klient dokončí objednávku, o zbytek se pak už stará API Slevomatu.
    21.5.2015 17:07 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Ty kódy přece nemáš v aplikaci, ale v databázi, takže uživatelem zadaný string můžeš porovnávat přímo v té databázi.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    21.5.2015 17:22 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Vím jak to myslíš, ale kupóny se do DB ukládají až po dokončení objednávky. Jako "zboží" s minusovou hodnotou.

    Během objednávky se slevové kupóny ukládají pouze do SESSION v DB je pouze zboží.

    Je to kvůli tomu, že kupóny můžou mít časové omezení, tak když si vložím nějaké věci do košíku (ID košíku je v COOKIE) a vrátím se za třeba 3 dny tak kupón už může být neplatný.

    Díky všem za radu
    21.5.2015 17:36 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    A jak poznáš pravost kupónu od zákazníka jinak než jeho porovnáním se seznamem platných kupónů?
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    21.5.2015 17:50 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Přes API Slevomatu (tam zkontroji platnost a zboží ke kterému se vztahuje), po dokončení objednávky je přes něj "uplatním" takže už nejde znovu použít.

    Kódy si Slevomat generuje sám.

    V postatě jeho kód ani nemusím ukládat, stačí mi výrobek a jeho cena co mám odečíst z objednávky, ale ukládám je kvůli pozdější kontrole.
    21.5.2015 13:20 Jan Vostrý
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Bohužel to není bug ale feature. Pokud PHP porovnává dva stringy (operátor ==), které vypadají jako číslo, tak je oba převede na číslo a potom je porovnává. Tedy PHP pro "10" == "1e1" vrací true. viz. https://php.net/manual/en/language.operators.comparison.php
    21.5.2015 16:58 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Díky moc, to mne vůbec nenapadlo. Zadávám STRING myslím STRING, ach jo, taky mne mohlo trknout to E :(
    21.5.2015 20:17 lertimir | skóre: 60 | blog: Par_slov
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    No když jsem si otázku četl, ani mě nenapadlo, že to čísla nejsou a spíše jsem přemýšlel, proč číslo v řádu 10^-908 se rovná číslu v řádu 10^-624 a myslím si, že jsou mimo přesnost a jsou oba float 0. Ale považuji za hloupost generovat stringy, které jsou čísla. Použitím i pismen je situace jednoznačná a stringy jsou navíc kratší se stejnou kolizní bezpečností.
    Jendа avatar 21.5.2015 20:25 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Ale považuji za hloupost generovat stringy, které jsou čísla.
    Jenže to je API slevomatu mimo jeho kontrolu. (a nejsou to čísla, podívej se na ty ostatní - 9189208690C-823)
    Nezapomeňte si posunout časovače na svých bombách o hodinu dopředu!
    21.5.2015 20:53 Sparrow | skóre: 4 | blog: Sparrow
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Přesně tak, já vůbec do poslední chvíle netušil jak budou kódy vypadat.

    Dostal jsem akorát seznam ID (6 čísel) k propojení s výrobky.

    Až dnes jsem dostal po 3 dnech odpověď (od někoho, kdo zná někoho, který má email na IT ze Slevomatu :D ) Jak se vlastně generuje kód kupónu.

    xxxxxxxFF-xxx

    X - náhodné číslo

    FF - 256 kombinací pro produkt v HEX

    Popis API ani nechtějte vědět a testací prostředí se skládá ze 3 kódů formát 1234567-111 až 333 (existují, neexistující, a již využitý)

    Prostě radost něco napsat. :(

    A jak jsem psal výše komunikace s IT probíhá přes obchoďáka a někoho kdo mám kontakt na někoho kdo něco ví.
    21.5.2015 21:59 lertimir | skóre: 60 | blog: Par_slov
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    No a co kód v úplně prvním kroku concatenate s pevným stringem třeba "AA-".$SlevomatID, a pak v celém mém programu to bude vždy a pořád string, a až kód budu posílat Slevomatu tak prefix zase utrhnu.
    Jendа avatar 21.5.2015 22:04 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Geniální řešení.

    (jak je řešena stabilita té umělé inteligence napříč architekturami a verzemi? třeba až implementují komplexní čísla a začnou převádět všechny stringy kde je číslo a "i" :)
    Nezapomeňte si posunout časovače na svých bombách o hodinu dopředu!
    22.5.2015 10:08 logik
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Je řešena? V PHP? ....
    21.5.2015 14:36 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: BUG v PHP array_search a in_array ?
    Však vidíš, že ta dvě čísla jsou stejná:
    <?php
    $a = "3767958990E-624";
    $b = "6089139600E-908";
    echo ($a == $b) ? "rovno" : "nerovno";
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.