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 12:22 | IT novinky

    Před dvěma lety zavedli operátoři ochranu proti podvrženým hovorům, kdy volající falšuje čísla anebo se vydává za někoho jiného. Nyní v roce 2026 blokují operátoři díky nasazeným technologiím v průměru 3 miliony pokusů o podvodný hovor měsíčně (tzn., že k propojení na zákazníka vůbec nedojde). Ochrana před tzv. spoofingem je pro zákazníky a zákaznice všech tří operátorů zdarma, ať už jde o mobilní čísla nebo pevné linky.

    Ladislav Hagara | Komentářů: 2
    dnes 03:44 | Komunita

    Společnost Meta (Facebook) předává React, React Native a související projekty jako JSX nadaci React Foundation patřící pod Linux Foundation. Zakládajícími členy React Foundation jsou Amazon, Callstack, Expo, Huawei, Meta, Microsoft, Software Mansion a Vercel.

    Ladislav Hagara | Komentářů: 3
    dnes 01:22 | IT novinky

    Samsung na akci Galaxy Unpacked February 2026 (YouTube) představil své nové telefony Galaxy S26, S26+ a S26 Ultra a sluchátka Galaxy Buds4 a Buds4 Pro. Telefon Galaxy S26 Ultra má nový typ displeje (Privacy Display) chránící obsah na obrazovce před zvědavými pohledy (YouTube).

    Ladislav Hagara | Komentářů: 2
    dnes 00:22 | Nová verze

    Byla vydána grafická knihovna Mesa 26.0.1 s podporou API OpenGL 4.6 a Vulkan 1.4. Je to první stabilní verze po 26.0.0, kde se novinky týkají mj. výkonu ray tracingu na GPU AMD a HoneyKrisp, implementace API Vulkan pro macOS.

    |🇵🇸 | Komentářů: 0
    včera 20:22 | Nová verze

    Byla vydána nová verze 4.6 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    Byla vydána nová verze 3.23.0 FreeRDP, tj. svobodné implementace protokolu RDP (Remote Desktop Protocol). Opravuje 11 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    včera 17:44 | Zajímavý článek

    Španělský softwarový inženýr oznámil, že se mu podařilo na dálku ovládat sedm tisíc robotických vysavačů po celém světě. Upozornil tak na slabé kybernetické zabezpečení těchto technologií a jejich možné a snadné zneužití. Nesnažil se hacknout všechny robotické vysavače po světě, ale pouze propojil svůj nový DJI Romo vysavač se zařízením Playstation. Aplikace podle něj ihned začala komunikovat se všemi sedmi tisíci spotřebiči a on je

    … více »
    Ladislav Hagara | Komentářů: 8
    včera 03:33 | Humor

    Momo je fenka cavapoo, která svými náhodnými stisky kláves bezdrátové klávesnice vytváří jednoduché počítačové hry. Technicky to funguje tak, že Raspberry Pi s připojenou bluetooth klávesnicí posílá text do Claude Code, který pak v Godotu píše hry a sám je i testuje pomocí screenshotů a jednoduchých simulovaných vstupů. Za stisky kláves je Momo automaticky odměňována pamlsky. Klíčový je pro projekt prompt, který instruuje AI, aby i

    … více »
    NUKE GAZA! 🎆 | Komentářů: 24
    včera 02:22 | Nová verze

    GNU awk (gawk), implementace specializovaného programovacího jazyka pro zpracování textu, byl vydán ve verzi 5.4.0. Jedná se o větší vydání po více než dvou letech. Mezi četnými změnami figuruje např. MinRX nově jako výchozí implementace pro regulární výrazy.

    |🇵🇸 | Komentářů: 0
    24.2. 16:22 | IT novinky

    Internetový prohlížeč Ladybird ohlásil tranzici z programovacího jazyka C++ do Rustu. Přechod bude probíhat postupně a nové komponenty budou dočasně koexistovat se stávajícím C++ kódem. Pro urychlení práce bude použita umělá inteligence, při portování první komponenty prohlížeče, JavaScriptového enginu LibJS, bylo během dvou týdnů pomocí nástrojů Claude Code a Codex vygenerováno kolem 25 000 řádků kódu. Nejedná se o čistě autonomní vývoj pomocí agentů.

    NUKE GAZA! 🎆 | Komentářů: 9
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (11%)
     (27%)
     (2%)
     (5%)
     (2%)
     (13%)
     (26%)
    Celkem 962 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    20.12.2017 00:10 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Hledám funkci pro BASH

    Tyhle domácí úkoly… Podle mě to postrádá smysl, pokud je člověk nevyřeší nějak samostatně. :-) Není jasné, o jakou šifru se jedná. Takže Bash může umět třeba tohle:

    $ string2base64 tajny-text
    dGFqbnktdGV4dA==
    
    $ string2base64 tajny-text | base64 -d
    tajny-text
    

    Implementace string2base64 se dá klidně udělat à la prase — například následující věc je v čistém Bashi bez dalších procesů. Ale neumí to ani náhodou Unicode a dokonce to neumí správně ošetřit nulový byte. Ale jinak to téměř funguje. Specifikace je třeba tady. Dekodér z base64 zpět do plaintextu si pozorný čtenář zajisté dovede sám naimplementovat za cvičení, podobně jako drobnou úpravu, která by string2base64 umožnila zpracovávat stream neomezené délky. Výkonnostních optimalizací se tam nabízí tři spousty a půl.

    #!/bin/bash
    
    # Creates a global mapping from ASCII bytes 1..255 to their binary codes.
    # For example, 'a' (i.e., ${#BYTE2CODE['a']}) maps to '01100001'.
    initcache() {
      if ((255 != "${#BYTE2CODE[@]}")); then
        declare -Ag BYTE2CODE
        local -i i
        for ((i = 1; i < 256; ++i)); do
          eval BYTE2CODE[$\'\\x"$(printf '%x' "$i")"\']="$(code2bin "$i")"
        done
      fi
    }
    
    # Translates an ASCII byte in decimal notation into an 8-digit binary literal.
    # For example, argument '97' (otherwise known as 0x61 or 'a') yields '01100001'.
    code2bin() {
      local -ai bits=(0 0 0 0 0 0 0 0)
      local -i number="$1"
      local -i idx=${#bits[@]}
      local -i i
      while ((number && idx)); do
        bits[--idx]='number % 2'
        ((number /= 2))
      done
      for ((i = 0; i < ${#bits[@]}; ++i)); do
          echo -n "${bits[i]}"
      done
    }
    
    # Translates a string into a binary representation suitable for base64 encoding.
    # The first output line is the number of padding characters (0 to 2).
    # Each subsequent line is a binary representation of 3 bytes or 4 base64 digits.
    # For example, argument 'aa' yields '1' (1 padding symbol) on the first line and
    # '011000010110000100000000' (24 bits of data) on the second line.
    string2code() {
      local -ri equals=$(((3 - ${#1} % 3) % 3))
      local -i i
      local buffer="$equals"
      for ((i = 0; i < ${#1}; ++i)); do
        if ((!(i % 3))); then
          echo "$buffer"
          buffer=
        fi
        buffer+="${BYTE2CODE[${1:i:1}]}"
      done
      echo -n "$buffer"
      for ((i = 0; i < equals; ++i)); do
        code2bin 0
      done
      echo
    }
    
    # Translates 6 bits (a string of '0' and '1' characters) to a base64 digit.
    # For example, argument '100111' (39 in decimal notation) yields 'n'.
    bin2basechar() {
      local -ri code=2#"$1"
      local -a chars
      if ((code < 26)); then
        chars=(A B C D E F G H I J K L M N O P Q R S T U V W X Y Z)
        echo -n "${chars[code]}"
      elif ((code < 52)); then
        chars=(a b c d e f g h i j k l m n o p q r s t u v w x y z)
        echo -n "${chars[code - 26]}"
      elif ((code < 62)); then
        chars=(0 1 2 3 4 5 6 7 8 9)
        echo -n "${chars[code - 52]}"
      else
        chars=(+ /)
        echo -n "${chars[code - 62]}"
      fi
    }
    
    # Translates its first (and only) argument into base64.
    # For example, argument 'doprdele' yields 'ZG9wcmRlbGU='.
    string2base64() {
      local -a fragments
      local fragment
      local line
      local -i equals
      local -i i
      local chars
      initcache
      string2code "$1" | {
        read equals
        while read line; do
          echo -n "$chars"
          fragments=("${line:0:6}" "${line:6:6}" "${line:12:6}" "${line:18:6}")
          chars=
          for fragment in "${fragments[@]}"; do
            chars+="$(bin2basechar "$fragment")"
          done
        done
        if ((equals)); then
            echo -n "${chars:0:-equals}"
            for ((i = 0; i < equals; ++i)); do echo -n '='; done
        else
            echo -n "$chars"
        fi
        echo
      }
    }
    

    Pár příkladů, kde k zakódování používám výše uvedenou funkci string2base64 a k dekódování slouží base64 z coreutils:

    $ string2base64 zzz$'\xa' 
    enp6Cg==
    
    $ string2base64 'bla bla bla'$'\xa' 
    YmxhIGJsYSBibGEK
    
    $ string2base64 zzz$'\xa' | base64 -d
    zzz
    
    $ string2base64 'bla bla bla'$'\xa' | base64 -d
    bla bla bla
    

    (Konce řádků jsou tam^^^ samozřejmě jen tak bezdůvodně, because we can.) A tady ještě drobný test, jestli to vůbec něco rozumného dělá:

    for i in x{a..z} {A..Z}y a{0..9}b; do
      echo -n "${i} "
      string2base64 "$i" | base64 -d
      echo
    done
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.