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 03:33 | Zajímavý článek

    Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    včera 22:55 | Bezpečnostní upozornění

    Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | Humor

    Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.

    Ladislav Hagara | Komentářů: 10
    včera 05:11 | Nová verze

    Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.

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

    Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    6.5. 16:44 | Komunita

    Richard Hughes oznámil, že po společnostech Red Hat a Framework a organizacích OSFF a Linux Foundation, službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzorují také společnosti Dell a Lenovo. Do dnešního dne bylo díky LVFS provedeno více než 145 milionů aktualizací firmwarů od více než 100 různých výrobců na milionech linuxových zařízení.

    Ladislav Hagara | Komentářů: 0
    6.5. 15:22 | IT novinky

    Americké technologické společnosti Microsoft, Google a xAI souhlasily, že vládě Spojených států poskytnou přístup k novým modelům umělé inteligence (AI) před jejich uvedením na trh. Oznámila to americká vláda, která tak bude moci prověřit, zda modely nepředstavují hrozbu pro národní bezpečnost. Oznámení podtrhuje rostoucí obavy Washingtonu z rizik spojených s výkonnými AI systémy. Americké úřady chtějí v rámci předběžného přístupu

    … více »
    Ladislav Hagara | Komentářů: 1
    6.5. 14:11 | IT novinky

    Společnost Valve zveřejnila (GitLab) nákresy ovladače Steam Controller a puku. Pro všechny, kdo by jej chtěli hacknout nebo modifikovat, případně pro ně navrhnout nějaké příslušenství. Pod licencí Creative Commons (CC BY-NC-SA 4.0).

    Ladislav Hagara | Komentářů: 0
    6.5. 12:44 | Komunita

    PHP bylo dlouho distribuováno pod vlastní licencí – s výjimkou částí spadajících pod licenci Zend Engine. Po několikaleté práci se povedlo PHP přelicencovat na 3bodovou licenci BSD.

    Ladislav Hagara | Komentářů: 0
    6.5. 05:00 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube). Na Linuxu je vedle Qt frontendu nově k dispozici také GTK4 / libadwaita frontend.

    Ladislav Hagara | Komentářů: 20
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (32%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1531 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    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.