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 01:33 | IT novinky

    Celkové tržby společnosti Canonical za rok 2024 byly 292 milionů dolarů (pdf). Za rok 2023 to bylo 251 milionů dolarů.

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

    Byla vydána verze 1.88.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 01:11 | Nová verze

    Distribuce Tails specializující se ochranu online soukromí uživatele byla vydána ve verzi 6.17. Mimo jiné aktualizuje Tor Browser (14.5.4) a opravuje několik chyb.

    Fluttershy, yay! | Komentářů: 0
    včera 21:11 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 13:11 | IT novinky

    Město Lyon posiluje svou digitální suverenitu a postupně nahrazuje software od společnosti Microsoft bezplatnými alternativami, zejména OnlyOffice pro kancelářské aplikace a Linux a PostgreSQL pro systémy a databáze.

    Ladislav Hagara | Komentářů: 6
    včera 11:44 | Zajímavý projekt

    Evropská občanská iniciativa Stop Destroying Videogames se snaží o to, aby vydavatelé, kteří spotřebitelům v Evropské unii prodávají videohry nebo na ně udělují licence, měli povinnost tyto hry ponechat ve funkčním (hratelném) stavu i po ukončení podpory ze své strany. Podpořit podpisem tuto iniciativu můžete v Systému pro online sběr podpisů.

    trekker.dk | Komentářů: 4
    včera 11:22 | Komunita

    Mozilla oficiálně ukončila svůj již několik let mrtvý projekt DeepSpeech pro převod řeči na text.

    Ladislav Hagara | Komentářů: 2
    včera 05:22 | Komunita

    Krátce po oficiálním oznámení forku X.Org Xserveru s názvem XLibre Xserver byl ve Fedoře předložen návrh, aby byl X.Org Xserver nahrazen tímto XLibre Xserverem. Po krátké ale intenzivní diskusi byl návrh stažen.

    Ladislav Hagara | Komentářů: 24
    včera 01:33 | Komunita

    62 projektů získalo finanční podporu od NLnet Foundation (Wikipedie).

    Ladislav Hagara | Komentářů: 1
    včera 00:33 | Nová verze Ladislav Hagara | Komentářů: 1
    Jaký je váš oblíbený skriptovací jazyk?
     (58%)
     (29%)
     (7%)
     (2%)
     (0%)
     (1%)
     (3%)
    Celkem 316 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    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.