Soutenir Vision du Web dans son partage de logiciels et de ressources libres

Ce mineur crée de la monnaie numérique Monero pour soutenir Vision du web.
Merci de désactiver votre bloqueur de publicité.
Aucune publicité ne sera affichée.
Le mineur utilise les ressources de votre machine pour créer gratuitement de la monnaie numérique.
Le montant des donations pour Vision du web est de 0.045410024219401 Monero.

Programmation en Shell Bash Linux : Différence entre versions

De Wiki. Analyse, Communication, Développement, Hacking.
Aller à : navigation, rechercher
m (Créer un menu à choix multiples)
m (Échapper un caractère dans une chaine)
 
(45 révisions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
[[Category:Debian]]
+
[[Category:Linux]]
 
{{Transclusion_Entete}}
 
{{Transclusion_Entete}}
 
=Programmation en Shell Bash Linux=
 
=Programmation en Shell Bash Linux=
Ligne 19 : Ligne 19 :
 
  else
 
  else
 
  echo "NOK"
 
  echo "NOK"
 +
fi
 +
 +
Mettre en place le retour erreur après chaque action.
 +
Exemple pour l'utilisation du paquet apt clean :
 +
 +
apt clean
 +
if [ "$?" = "0" ] ; then
 +
echo "Les paquets présents dans /var/cache/apt/archives ont été supprimés."
 +
else
 +
echo "Les paquets présents dans /var/cache/apt/archives n'ont pas été supprimés."
 
  fi
 
  fi
  
 
  Source complémnetaire : okki666.free.fr/docmaster/articles/linux131.html
 
  Source complémnetaire : okki666.free.fr/docmaster/articles/linux131.html
 
  Autre possibilité, récupérer ce que apt-get envoie dans stderr pour avoir les messages d'erreur.
 
  Autre possibilité, récupérer ce que apt-get envoie dans stderr pour avoir les messages d'erreur.
 +
 +
==Variables et portée des variables==
 +
===Variables spéciales initialisées automatiquement au début du script===
 +
$0 Le nom de la commande (i.e. : du script)
 +
$1, $2, ... Le premier, deuxième, ... argument passés au script.
 +
$* La liste de tous les arguments passés au script.
 +
$# Le nombre d'arguments passés au script.
 +
$? Le code de retour de la dernière commande lancée.
 +
$! Le numéro de process de la dernière commande lancée en tâche de fond.
 +
$$ Le numéro de process du shell lui-même.
 +
===Variables d'environnement===
 +
$HOME  chemin du répertoire personnel de l'utilisateur
 +
$OLDPWD  chemin du répertoire précédent
 +
$PATH  liste des chemins de recherche des commandes exécutables
 +
$PPID  PID du processus père du shell
 +
$PS1  invite principale du shell
 +
$PS2  invite secondaire du shell
 +
$PS3  invite de la structure shell "select"
 +
$PS4  invite de l'option shell de débogage "xtrace"
 +
$PWD  chemin du répertoire courant
 +
$RANDOM  nombre entier aléatoire compris entre 0 et 32767
 +
$REPLY  variable par défaut de la commande "read" et de la structure shell "select"
 +
$SECONDS  nombre de secondes écoulées depuis le lancement du shell
 +
 +
===Exporter une variable===
 +
Une variable peut être supprimée avec la commande unset, et peut être verrouillée avec la commande readonly.
 +
moi=Zer00CooL
 +
echo $moi
 +
 +
Le résultat affiche Zer00CooL.
 +
 +
On verrouille la variable moi et on tente de la supprimer.
 +
readonly moi
 +
unset moi
 +
 +
On obtient un message d'erreur : bash: unset: moi: cannot unset: readonly variable
 +
 +
Portabilité de la variable moi dans les autres scripts appelés par le script d'origine, avec la commande export.
 +
export moi
 +
 +
Le script utilisant la variable exportée moi, ne peut pas la modifier.
 +
Les données peuvent "descendre" mais pas "remonter".
 +
 +
===Utiliser une variable globale à l'aide d'une fonction===
 +
#!/bin/bash
 +
fonction_portabilite_variable ()
 +
{
 +
global_var=Bonjour
 +
}
 +
 +
echo "global_var = $global_var"
 +
# global_var =
 +
# La fonction "fonction_portabilite_variable" n'a pas été appelée. $global_var n'est pas visible.
 +
 +
fonction_portabilite_variable
 +
echo "global_var = $global_var"
 +
# global_var affiche Bonjour
 +
# La variable "global_var" a été définie par appel de fonction.
 +
 +
Noter qu'une fonction peut être exportée avec la commande export -f fonction_portabilite_variable
 +
 +
===Remonter une variable enfant vers parent===
 +
====Exemple 1====
 +
#!/bin/bash
 +
# Utiliser un fichier intermédiaire.
 +
mknod fifo p
 +
(
 +
      echo 'Bonjour' > fifo &
 +
)
 +
VARIABLE=`cat fifo`
 +
echo $VARIABLE
 +
rm fifo
 +
 +
====Exemple 2====
 +
# Fichier parent.
 +
#!/usr/bin/ksh
 +
echo "In parent"
 +
second 
 +
. env_file
 +
echo "The value of MSG is : $MSG"
 +
 +
# Fichier enfant.
 +
#!/usr/bin/ksh
 +
echo "In child"
 +
export MSG="ENVIRON"
 +
printenv | sed 's/^/export /;s/=/=\"/;s/$/\"/' > env_file
 +
 +
En exécutant le fichier parent, on obtient bien les valeurs définies depuis le fichier enfant.
 +
In parent
 +
In child
 +
The value of MSG is : ENVIRON
 +
 +
What did we do:
 +
1. In the script 'second', after setting the environment variable, the list of all environment variables(printenv) is copied to a temporary file env_file.
 +
 +
2. The sed command is used to add the word 'export' at the beginning of every environment variable, and to wrap the variable value with double-quotes. This will enable us to simply run the file in the parent shell to export the variables.
 +
 +
3. In the parent 'first', the script 'second' is called. After the call to the 'second', all the environment variables are being sourced using the dot(.) command, and hence all the variables are now available in the parent as well.
 +
 +
4. On printing the variable VAR, got the value being set in the child and hence accessed the child shell environment variable in the parent.
 +
====Exemple 3====
 +
There is no  way to pass new variable value from the child shell to the parent shell. You may use files to communicate.
 +
 +
### A tester...
 +
 +
# Test 1
 +
# Script 1
 +
var1=1 ; export var1
 +
echo $var1
 +
./script2
 +
echo $var1
 +
echo $var2
 +
 +
# Script 2
 +
echo $var1
 +
var1=2
 +
echo $var1
 +
var2=3 ; export var2
 +
 +
# Test 2
 +
# Script 2
 +
echo 1 > /tmp/f1
 +
 +
# Script 1
 +
var=`cat /tmp/f1`
 +
echo $var
 +
echo $var2
 +
 +
===Différents types de variables===
 +
Source : http://www.epons.org/shell-bash-variables.php
 +
===Échapper un caractère dans une chaine===
 +
# Échapper la simple quote <code>'</code>.
 +
 +
# Utiliser PHP permet par exemple d'échapper avec la commande suivante :
 +
echappement=$(echo "John O'hara"  | php -R 'echo addslashes($argn);')
 +
echo $echappement
 +
 +
# On préfèrera utiliser sed, par défaut, quand c'est possible
 +
chaine="Chaine avec l'un des problèmes de caractères pouvant être rencontré, la simple quote."
 +
echappement=$(echo "$chaine" | sed s/"'"/"\\\'"/g)
 +
echo $echappement
 +
 +
===Récupérer le résultat d'une commande dans une variable===
 +
Source : http://artisan.karma-lab.net/bash-blocs-code-et-variables
 +
Source : http://www.commentcamarche.com/faq/5030-comment-recuperer-le-resultat-d-une-commande-dans-une-variable
 +
Source : https://openclassrooms.com/courses/reprenez-le-controle-a-l-aide-de-linux/afficher-et-manipuler-des-variables
  
 
==Créer un fichier de logs avec date heure minutes secondes==
 
==Créer un fichier de logs avec date heure minutes secondes==
Ligne 31 : Ligne 187 :
 
  cd /home/user/dossier
 
  cd /home/user/dossier
 
  echo "$jour - $heure : Mise en route du script." >> logs.txt
 
  echo "$jour - $heure : Mise en route du script." >> logs.txt
 +
 
==Connaître la date de création d'un fichier au format Timestamp==
 
==Connaître la date de création d'un fichier au format Timestamp==
 
  Date_Modif_Fichier=`perl -e '($atime,$mtime,$ctime)=(stat($ARGV[0]))[8..10];print "$mtime\n";' 00-menu.sh `
 
  Date_Modif_Fichier=`perl -e '($atime,$mtime,$ctime)=(stat($ARGV[0]))[8..10];print "$mtime\n";' 00-menu.sh `
Ligne 91 : Ligne 248 :
 
  [[Fichier:ok-ko.png]] Source : http://www.shellunix.com/awk.html
 
  [[Fichier:ok-ko.png]] Source : http://www.shellunix.com/awk.html
 
  [[Fichier:ok-ko.png]] Source : http://www.funix.org/fr/unix/awk.htm
 
  [[Fichier:ok-ko.png]] Source : http://www.funix.org/fr/unix/awk.htm
 +
[[Fichier:ok-ko.png]] Source : http://www.theunixschool.com/p/awk-sed.html
 
  [[Fichier:ok-ko.png]] Source : https://linuxconfig.org/learning-linux-commands-awk
 
  [[Fichier:ok-ko.png]] Source : https://linuxconfig.org/learning-linux-commands-awk
  
Ligne 117 : Ligne 275 :
 
==Opérateurs de comparaison==
 
==Opérateurs de comparaison==
 
  Source : https://abs.traduc.org/abs-5.3-fr/ch07s03.html
 
  Source : https://abs.traduc.org/abs-5.3-fr/ch07s03.html
 +
===Tester si un script est lancé en tant que root===
 +
if [ "$(whoami)" != root ];
 +
then
 +
  echo "$(whoami) n'est pas root. Relancer le script en tant que root !"
 +
  sleep 4
 +
  exit 1
 +
fi
 +
===Tester une chaîne de caractères===
 +
ID_table_affiliation=50
 +
Allemagne=DE
 +
 +
# Soit en utilisant if.
 +
if [ $Allemagne = "DE" ]
 +
then
 +
echo "DE est bien le code de l'Allemagne."
 +
else
 +
echo "La variable ne correspond pas.";
 +
fi
 +
 +
# Soit en utilisant grep.
 +
if echo "$Allemagne" | grep "DE" >/dev/null 2>&1;
 +
then
 +
echo "DE est bien le code de l'Allemagne."
 +
else
 +
echo "La variable ne correspond pas.";
 +
fi
  
 
==Tester un dossier ou un fichier==
 
==Tester un dossier ou un fichier==
Ligne 175 : Ligne 359 :
  
 
===Mettre pause avec read===
 
===Mettre pause avec read===
  read -p "Appuyer sur une touche pour continuer ..."
+
echo "Appuyer sur une touche pour continuer..."
 +
read a
 +
 
 +
Ou encore :
 +
 
 +
  read -p "Appuyer sur une touche pour continuer..."
  
 
===Mettre pause avec read===
 
===Mettre pause avec read===
Ligne 229 : Ligne 418 :
  
 
==Boucles==
 
==Boucles==
 +
===Test conditionnel avec if===
 +
if [ $? = 0 ]
 +
then
 +
# echo "Oui !"
 +
retour="0"
 +
else
 +
# echo "Non !"
 +
retour="1"
 +
fi
 +
 +
===Test conditionnel avec for===
 +
MAX=2
 +
for X in $(seq 1 $MAX) ; do
 +
commande
 +
done
 +
 
  Source : https://www.cyberciti.biz/faq/bash-for-loop/
 
  Source : https://www.cyberciti.biz/faq/bash-for-loop/
 
  Source : https://www.tutorialspoint.com/unix/unix-loop-control.htm
 
  Source : https://www.tutorialspoint.com/unix/unix-loop-control.htm
 +
 +
===Test conditionnel avec while===
 +
# Initialisation de la boucle.
 +
Var="0"
 +
while [ $Var = 0 ]
 +
do
 +
 +
# La boucle permet de répéter l'action d'ajouter différents canal web tant que la variable réponse est égale à la valeur oui, oui pour ajouter des références supplémentaires.
 +
Question=$(zenity --question \
 +
--title="Ajouter d'autres liens ?" \
 +
--ok-label="Oui" \
 +
--cancel-label="Non" \
 +
--text="Ajouter d'autres liens ?" 2>/dev/null
 +
);
 +
 +
# Tester le retour de la réponse à la question.
 +
# Si on choisit la réponse Oui, la valeur 0 est retournée.
 +
if [ $? = 0 ]
 +
then
 +
echo "Le choix est Oui !"
 +
Var="0"
 +
else
 +
echo "Le choix est Non !"
 +
Var="1"
 +
fi
 +
 +
echo "Test de la variable Var en fin de script $Var"
 +
 +
done
 +
 
==Barre de progression==
 
==Barre de progression==
 
  Source : https://github.com/adriano-pinaffo/progressbar.sh
 
  Source : https://github.com/adriano-pinaffo/progressbar.sh
Ligne 324 : Ligne 559 :
 
  esac
 
  esac
 
  exit 0
 
  exit 0
 +
 +
==Lancer une commande si le terminal est fermé avec la croix==
 +
Simuler un installateur classique :
 +
 +
#!/bin/bash
 +
set -e
 +
set -v
 +
 +
# Creating an installation directory with a unique name,
 +
# to avoid concurrency issues.
 +
INSTALLDIR="$(mktemp -d installdir.XXXXXX)"
 +
 +
# Setting up cleanup of the installation directory on
 +
# exit.  WARNING: do not use `cd` in the script, as
 +
# INSTALLDIR is a relative path.
 +
clean-installdir () {
 +
rm -r "$INSTALLDIR"
 +
}
 +
trap clean-installdir EXIT
 +
 +
# Installing...
 +
printf "Installation in progress in %s\n" "$INSTALLDIR"
 +
# The sleeping simulates the time it would take for a
 +
# real installation to occur.  You can close the program
 +
# in any way you wish, to do some tests, in this time
 +
# frame.
 +
sleep 10
 +
 +
# Everything went well for the script
 +
printf "%s\n" "Done."
 +
 +
# Note that you should see execution of clean-installdir
 +
# here, as the program is exiting. 
 +
 +
Si je ferme le programme à coup de <C-c>, ou si je clos la fenêtre avec le raccourci clavier de mon gestionnaire de fenêtre, le répertoire d'installation est effacé.
 +
Si je laisse le programme s'exécuter jusqu'au bout, c'est aussi le cas sans appeler explicitement la fonction.
 +
 +
Si je ferme la fenêtre de mon terminal avec le programme xkill, le script reçoit un signal KILL impossible à capter.
 +
Par conséquent, le répertoire d'installation reste présent à côté du script, et doit être effacé manuellement.
 +
 +
Il se peut que certains gestionnaires de fenêtres aient ce genre de comportement pour lutter contre les fenêtres récalcitrantes.
 +
Seul le manager de fenêtre dwm a été testé mais il y en a d'autres : xfwm4, metacity, kwin, awesome, fvwm, openbox...
  
 
==Créer un fichier temporaire avec mktemp==
 
==Créer un fichier temporaire avec mktemp==
Ligne 348 : Ligne 625 :
 
  mktemp -p /chroot/apache/var/tmp php.lock.XXXXXXXXXX
 
  mktemp -p /chroot/apache/var/tmp php.lock.XXXXXXXXXX
  
==Zenity==
+
=Bibliographie=
===Menu cliquable avec Zenity===
 
====Exemple 1 fonctionnel====
 
#!/bin/bash
 
file=$(zenity --width=360 --height=320 --list --title "Favourites" --text "Open..." --column File "Google Webmaster Tools" "bla" "bla" "bla")
 
 
if [ "$file" = "Google Webmaster Tools" ]; then
 
    xdg-open https://www.google.com/webmasters/tools
 
 
elif [ "$file" = "bla" ]; then
 
    xdg-open /home/bob/personal/2012_Xmas_letter.odt
 
 
elif [ "$file" = "bla" ]; then
 
    xdg-open /home/bob/music/Fleck/Cheeseballs_in_Cowtown.ogg
 
 
elif [ "$file" = "bla" ]; then
 
    xdg-open http://www.freesoftwaremagazine.com/
 
 
else
 
    exit 0
 
 
fi
 
 
 
Source : http://freesoftwaremagazine.com/articles/writing_simple_launcher_using_zenity/
 
====Exemple 2 - Menu qui redémarre ou monte des services====
 
#!/bin/sh
 
show_menu(){
 
    NORMAL=`echo "\033[m"`
 
    MENU=`echo "\033[36m"` #Blue
 
    NUMBER=`echo "\033[33m"` #yellow
 
    FGRED=`echo "\033[41m"`
 
    RED_TEXT=`echo "\033[31m"`
 
    ENTER_LINE=`echo "\033[33m"`
 
    echo -e "${MENU}*********************************************${NORMAL}"
 
    echo -e "${MENU}**${NUMBER} 1)${MENU} Mount dropbox ${NORMAL}"
 
    echo -e "${MENU}**${NUMBER} 2)${MENU} Mount USB 500 Gig Drive ${NORMAL}"
 
    echo -e "${MENU}**${NUMBER} 3)${MENU} Restart Apache ${NORMAL}"
 
    echo -e "${MENU}**${NUMBER} 4)${MENU} ssh Frost TomCat Server ${NORMAL}"
 
    echo -e "${MENU}**${NUMBER} 5)${MENU} ${NORMAL}"
 
    echo -e "${MENU}*********************************************${NORMAL}"
 
    echo -e "${ENTER_LINE}Please enter a menu option and enter or ${RED_TEXT}enter to exit. ${NORMAL}"
 
    read opt
 
}
 
function option_picked() {
 
    COLOR='\033[01;31m' # bold red
 
    RESET='\033[00;00m' # normal white
 
    MESSAGE=${@:-"${RESET}Error: No message passed"}
 
    echo -e "${COLOR}${MESSAGE}${RESET}"
 
}
 
 
clear
 
show_menu
 
while [ opt != '' ]
 
    do
 
    if [[ $opt = "" ]]; then
 
            exit;
 
    else
 
        case $opt in
 
        1) clear;
 
        option_picked "Option 1 Picked";
 
        sudo mount /dev/sdh1 /mnt/DropBox/; #The 3 terabyte
 
        menu;
 
        ;;
 
 
        2) clear;
 
            option_picked "Option 2 Picked";
 
            sudo mount /dev/sdi1 /mnt/usbDrive; #The 500 gig drive
 
        menu;
 
            ;;
 
 
        3) clear;
 
            option_picked "Option 3 Picked";
 
        sudo service apache2 restart;
 
            show_menu;
 
            ;;
 
 
        4) clear;
 
            option_picked "Option 4 Picked";
 
        ssh [email protected] -p 2010;
 
            show_menu;
 
            ;;
 
 
        x)exit;
 
        ;;
 
 
        \n)exit;
 
        ;;
 
 
        *)clear;
 
        option_picked "Pick an option from the menu";
 
        show_menu;
 
        ;;
 
    esac
 
fi
 
done
 
 
 
===Boîte de validation par défaut===
 
====Exemple====
 
result=$(zenity --title "Test Entry Box" --entry --text "Accept default or change value" --entry-text "Default Value")
 
echo "$result"
 
 
 
Attention, le terminal affiche le message suivant :
 
Gtk-Message: GtkDialog mapped without a transient parent. This is discouraged.
 
====Exemple====
 
#! /bin/bash
 
selection=$(zenity --list "Option 1" "Option 2" "Option 3" --column="" --text="Text above column(s)" --title="My menu")
 
case "$selection" in
 
"Option 1")zenity --info --text="Do something here for No1";;
 
"Option 2")zenity --info --text="Do something here for No2";;
 
"Option 3")zenity --info --text="Do something here for No3";;
 
esac
 
 
 
Attention, le terminal affiche le message suivant :
 
Gtk-Message: GtkDialog mapped without a transient parent. This is discouraged.
 
 
 
===Barre de progression avec Zenity===
 
#!/bin/sh
 
 
# Lancer avec ./progress_barre_Zenity.sh 12
 
 
(
 
echo "10" ; sleep 1
 
echo "# Updating mail logs" ; sleep 1
 
echo "20" ; sleep 1
 
echo "# Resetting cron jobs" ; sleep 1
 
echo "50" ; sleep 1
 
echo "This line will just be ignored" ; sleep 1
 
echo "75" ; sleep 1
 
echo "# Rebooting system" ; sleep 1
 
echo "100" ; sleep 1
 
) |
 
zenity --progress \
 
  --title="Update System Logs" \
 
  --text="Scanning mail logs..." \
 
  --percentage=0
 
 
if [ "$?" = -1 ] ; then
 
        zenity --error \
 
          --text="Update canceled."
 
fi
 
 
 
===Menu graphique à choix multiples avec Zenity===
 
#! /bin/bash
 
selection=$(zenity --list "Option 1" "Option 2" "Option 3" --column="" --text="Text above column(s)" --title="My menu")
 
 
case "$selection" in
 
"Option 1")zenity --info --text="Do something here for No1";;
 
"Option 2")zenity --info --text="Do something here for No2";;
 
"Option 3")zenity --info --text="Do something here for No3";;
 
esac
 
===Ressources complémentaires sur Zenity===
 
Source : https://www.linux.org/threads/zenity-gui-for-shell-scripts.9802/
 
Source : https://www.howtogeek.com/107537/how-to-make-simple-graphical-shell-scripts-with-zenity-on-linux/
 
 
 
==Bibliographie==
 
 
  [[Fichier:ok-ko.png]] Source : https://doc.ubuntu-fr.org/tutoriel/script_shell
 
  [[Fichier:ok-ko.png]] Source : https://doc.ubuntu-fr.org/tutoriel/script_shell
 
  [[Fichier:ok-ko.png]] Source : http://www.dreamsyssoft.com/unix-shell-scripting/ifelse-tutorial.php
 
  [[Fichier:ok-ko.png]] Source : http://www.dreamsyssoft.com/unix-shell-scripting/ifelse-tutorial.php
Ligne 509 : Ligne 632 :
 
  [[Fichier:ok-ko.png]] Source : https://linuxfrench.wordpress.com/2017/03/07/4-ligne-de-commande-scripts-shell/
 
  [[Fichier:ok-ko.png]] Source : https://linuxfrench.wordpress.com/2017/03/07/4-ligne-de-commande-scripts-shell/
 
  [[Fichier:ok-ko.png]] Source : https://buzut.fr/101-commandes-indispensables-sous-linux/
 
  [[Fichier:ok-ko.png]] Source : https://buzut.fr/101-commandes-indispensables-sous-linux/
 +
 +
==Programmation avancée avec Bash==
 +
Advanced Bash Scripting.
 +
[[Fichier:ok-ko.png]] Bash scripting Tutorial : https://linuxconfig.org/bash-scripting-tutorial
 +
[[Fichier:ok-ko.png]] Debian Admin - Advanced Bash-Scripting Guide : http://www.debianadmin.com/advanced-bash-scripting-guide.html
 +
[[Fichier:ok-ko.png]] ABS-Guide : https://linux.die.net/abs-guide/
 +
[[Fichier:ok-ko.png]] Advanced Bash-Scripting Guide : Revision 10 - 10 Mar 2014 : http://www.tldp.org/LDP/abs/abs-guide.pdf
 +
[[Fichier:ok-ko.png]] http://blaireaulinux.free.fr/linux-scripts-bash-1.php
 +
[[Fichier:ok-ko.png]] https://abs.traduc.org/abs-fr/
 +
 +
==Scripts pour Youtube et conversion du format vidéo==
 +
[[Fichier:ok.png]] Source : http://happy-tux.org/marco/scripts-youtube/
 +
 
==Utiliser des commandes Shell avec le terminal==
 
==Utiliser des commandes Shell avec le terminal==
 
  [[Utiliser_des_commandes_shell_avec_le_terminal|Utiliser des commandes Shell avec le terminal est un pense bête pour administrer GNU/Linux]].
 
  [[Utiliser_des_commandes_shell_avec_le_terminal|Utiliser des commandes Shell avec le terminal est un pense bête pour administrer GNU/Linux]].
 +
==Utiliser Zenity==
 +
[[Programmation_GNU_Linux_Zenity|Utiliser Zenity]]
  
 
{{Transclusion_Navigation}}
 
{{Transclusion_Navigation}}

Version actuelle datée du 6 avril 2018 à 16:17

Naviguer sur le wiki : Accueil du wiki - Sommaire Administrateur - Sommaire des projets - Sommaire pour Webmaster - Sommaire We make Hack
Naviguer sur le site : Accueil du site - Les annuaires - Les éditoriaux - Le forum - Les outils - Les projets

Sommaire

Programmation en Shell Bash Linux

Programmation en Shell Bash Linux est un pense bête pour créer des scripts interactifs.

Code retour

Par convention, un code de retour égal à 0 signifie que la commande s'est exécutée correctement.
Un code différent de 0 signifie soit une erreur d'exécution, soit une erreur syntaxique.
sudo apt-get install TRUUUUUC
Évidemment aucun logiciel ne va s'installer.
echo $?
Le code erreur 100 est affiché sur la console.
Le code erreur n'est pas 0, donc, la commande qui a été lancée n'a pas aboutie.
ls
if [ "$?" = "0" ] ; then
echo "OK"
else
echo "NOK"
fi
Mettre en place le retour erreur après chaque action.
Exemple pour l'utilisation du paquet apt clean :
apt clean
if [ "$?" = "0" ] ; then
echo "Les paquets présents dans /var/cache/apt/archives ont été supprimés."
else
echo "Les paquets présents dans /var/cache/apt/archives n'ont pas été supprimés."
fi
Source complémnetaire : okki666.free.fr/docmaster/articles/linux131.html
Autre possibilité, récupérer ce que apt-get envoie dans stderr pour avoir les messages d'erreur.

Variables et portée des variables

Variables spéciales initialisées automatiquement au début du script

$0 	Le nom de la commande (i.e. : du script)
$1, $2, ... 	Le premier, deuxième, ... argument passés au script.
$* 	La liste de tous les arguments passés au script.
$# 	Le nombre d'arguments passés au script.
$? 	Le code de retour de la dernière commande lancée.
$! 	Le numéro de process de la dernière commande lancée en tâche de fond.
$$ 	Le numéro de process du shell lui-même.

Variables d'environnement

$HOME   chemin du répertoire personnel de l'utilisateur
$OLDPWD   chemin du répertoire précédent
$PATH   liste des chemins de recherche des commandes exécutables
$PPID   PID du processus père du shell
$PS1   invite principale du shell
$PS2   invite secondaire du shell
$PS3   invite de la structure shell "select"
$PS4   invite de l'option shell de débogage "xtrace"
$PWD   chemin du répertoire courant
$RANDOM   nombre entier aléatoire compris entre 0 et 32767
$REPLY   variable par défaut de la commande "read" et de la structure shell "select"
$SECONDS   nombre de secondes écoulées depuis le lancement du shell

Exporter une variable

Une variable peut être supprimée avec la commande unset, et peut être verrouillée avec la commande readonly.
moi=Zer00CooL
echo $moi
Le résultat affiche Zer00CooL.
On verrouille la variable moi et on tente de la supprimer.
readonly moi
unset moi
On obtient un message d'erreur : bash: unset: moi: cannot unset: readonly variable
Portabilité de la variable moi dans les autres scripts appelés par le script d'origine, avec la commande export.
export moi
Le script utilisant la variable exportée moi, ne peut pas la modifier.
Les données peuvent "descendre" mais pas "remonter".

Utiliser une variable globale à l'aide d'une fonction

#!/bin/bash
fonction_portabilite_variable ()
{
global_var=Bonjour 
}

echo "global_var = $global_var"
# global_var =
# La fonction "fonction_portabilite_variable" n'a pas été appelée. $global_var n'est pas visible.

fonction_portabilite_variable
echo "global_var = $global_var"
# global_var affiche Bonjour
# La variable "global_var" a été définie par appel de fonction.
Noter qu'une fonction peut être exportée avec la commande export -f fonction_portabilite_variable

Remonter une variable enfant vers parent

Exemple 1

#!/bin/bash
# Utiliser un fichier intermédiaire.
mknod fifo p
(
      echo 'Bonjour' > fifo &
)
VARIABLE=`cat fifo`
echo $VARIABLE
rm fifo

Exemple 2

# Fichier parent.
#!/usr/bin/ksh
echo "In parent"
second   
. env_file
echo "The value of MSG is : $MSG"

# Fichier enfant.
#!/usr/bin/ksh
echo "In child"
export MSG="ENVIRON"
printenv | sed 's/^/export /;s/=/=\"/;s/$/\"/' > env_file

En exécutant le fichier parent, on obtient bien les valeurs définies depuis le fichier enfant.
In parent
In child
The value of MSG is : ENVIRON
What did we do:
1. In the script 'second', after setting the environment variable, the list of all environment variables(printenv) is copied to a temporary file env_file.
2. The sed command is used to add the word 'export' at the beginning of every environment variable, and to wrap the variable value with double-quotes. This will enable us to simply run the file in the parent shell to export the variables.
3. In the parent 'first', the script 'second' is called. After the call to the 'second', all the environment variables are being sourced using the dot(.) command, and hence all the variables are now available in the parent as well.
4. On printing the variable VAR, got the value being set in the child and hence accessed the child shell environment variable in the parent.

Exemple 3

There is no  way to pass new variable value from the child shell to the parent shell. You may use files to communicate.
### A tester...
# Test 1
# Script 1
var1=1 ; export var1
echo $var1
./script2
echo $var1
echo $var2
# Script 2
echo $var1
var1=2
echo $var1
var2=3 ; export var2
# Test 2
# Script 2
echo 1 > /tmp/f1
# Script 1
var=`cat /tmp/f1`
echo $var
echo $var2

Différents types de variables

Source : http://www.epons.org/shell-bash-variables.php

Échapper un caractère dans une chaine

# Échapper la simple quote '.
# Utiliser PHP permet par exemple d'échapper avec la commande suivante :
echappement=$(echo "John O'hara"  | php -R 'echo addslashes($argn);')
echo $echappement
# On préfèrera utiliser sed, par défaut, quand c'est possible
chaine="Chaine avec l'un des problèmes de caractères pouvant être rencontré, la simple quote."
echappement=$(echo "$chaine" | sed s/"'"/"\\\'"/g)
echo $echappement

Récupérer le résultat d'une commande dans une variable

Source : http://artisan.karma-lab.net/bash-blocs-code-et-variables
Source : http://www.commentcamarche.com/faq/5030-comment-recuperer-le-resultat-d-une-commande-dans-une-variable
Source : https://openclassrooms.com/courses/reprenez-le-controle-a-l-aide-de-linux/afficher-et-manipuler-des-variables

Créer un fichier de logs avec date heure minutes secondes

# Variables jour et heure.
jour=$(date %d-%m-+%Y)
heure=$(date +%H:%M:%S)

cd /home/user/dossier
echo "$jour - $heure : Mise en route du script." >> logs.txt

Connaître la date de création d'un fichier au format Timestamp

Date_Modif_Fichier=`perl -e '($atime,$mtime,$ctime)=(stat($ARGV[0]))[8..10];print "$mtime\n";' 00-menu.sh `
Date_Du_Jour=`date -u '+%s'`

echo " Date du jour : `date "+%d %B %Y %H:%M:%S"` "
echo
echo " Le timestamp (unix) désigne le nombre de secondes écoulées depuis le 1er janvier 1970 à minuit UTC précise. "
echo
echo " Date du jour au format Timestamp : $Date_Du_Jour "
echo " Date de modification du fichier au format Timestamp : $Date_Modif_Fichier "

echo
calcul=`expr $Date_Du_Jour - $Date_Modif_Fichier`
echo " Date du jour - Date de modification du fichier : $calcul secondes. "

calcul=`expr $calcul / 60`
echo " $calcul minute(s) "

if [ $calcul -gt 1 ]; then
echo " Le fichier n'est pas à jour avec $calcul minutes de durée de vie. "
else
echo " Le fichier est à jour avec $calcul minute de durée de vie. "
fi

Date

Utiliser date : http://www.jacksay.com/tutoriaux/bash-shell/bashshell-utilisation-commande-date.html
Supprimer des fichiers en fonction de leur date d'ancienneté : http://webdevpro.net/script-de-bash-pour-supprimer-des-fichiers-et-dossiers-en-fonction-dune-periode/
Supprimer des fichiers en fonction de leur date d'ancienneté : http://www.informatix.fr/tutoriels/unix-linux-bsd/comment-supprimer-les-fichiers-plus-vieux-qu-une-date-donnee-en-bash-117

TimeStamp

# TimeStamp vers Date
# perl -e "print scalar(localtime(1173279767))"
# Date vers TimeStamp
perl -e "use POSIX ; print (mktime(10,45,11,31,4,107));"
Pour utiliser l'heure locale française :
date -d 2005-10-20 +"%s
Noter que cette commande ne fonctionne PAS sur unix (Aix), il faut alors charger shellutils : directory.fsf.org/GNU/shellutils.html

Vider l'écran du terminal

clear
reset

Afficher une image ascii dans le terminal

cat ascii-seo.sh

Utiliser la commande awk

awk est une commande très puissante, un langage de programmation a elle tout seule qui permet une recherche de chaînes et l'exécution d'actions sur les lignes sélectionnées.
Cette commande est utile pour récupérer de l'information, générer des rapports, transformer des données entre autres.
Une grande partie de la syntaxe a été empruntée au langage c, d'ailleurs awk sont les abréviations de ces 3 créateurs dont k pour Kernighan, un des inventeurs du c. 
Exemple de la commande :
myvar="toto" cat $fic | awk '{ sub(/'$myvar'/,"commentaire"); print}'
Application :
[[email protected] trash]$ cat fich.txt Je m'appelle Toto et moi Tutu et mon frère Titi. [[email protected] trash]$ var="Toto" [[email protected] trash]$ cat fich.txt | awk '{ sub(/'$var'/,"Tata");print}' Je m'appelle Tata et moi Tutu et mon frère Titi. [[email protected] trash]$
Ok-ko.png Source : http://www.shellunix.com/awk.html
Ok-ko.png Source : http://www.funix.org/fr/unix/awk.htm
Ok-ko.png Source : http://www.theunixschool.com/p/awk-sed.html
Ok-ko.png Source : https://linuxconfig.org/learning-linux-commands-awk

Utiliser la commande sed

Remplacer une ligne entière

Remplacer une ligne entière par "Tata" uniquement si cette ligne contient "appelle" ?
$ cat plop
Je m'appelle Toto
et moi Tutu
et mon frère Titi.
$ sed '/appelle/cTata' plop
Tata
et moi Tutu
et mon frère Titi.

Ajouter un espace après tous les points

Ajouter un espace après chaque point ou caractères de ponctuation avec la commande sed 's/\./\. /g' input.txt > output.txt

Ressources complémentaires sur sed

Ok-ko.png Source : https://doc.ubuntu-fr.org/sed
Ok-ko.png Source : https://www.shellunix.com/sed.html
Ok-ko.png Source : https://openclassrooms.com/courses/la-commande-sed
Ok-ko.png Source : https://www.system-linux.eu/index.php?post/2008/12/21/La-commande-Sed
Ok-ko.png Source : https://supersonique.net/administration/rechercher-et-remplacer-en-ligne-de-commande-bash-shell-sed/
Ok-ko.png Source : 31 exemples : https://likegeeks.com/sed-linux/

Opérateurs de comparaison

Source : https://abs.traduc.org/abs-5.3-fr/ch07s03.html

Tester si un script est lancé en tant que root

if [ "$(whoami)" != root ];
then
 echo "$(whoami) n'est pas root. Relancer le script en tant que root !"
 sleep 4
 exit 1
fi

Tester une chaîne de caractères

ID_table_affiliation=50
Allemagne=DE

# Soit en utilisant if.
if [ $Allemagne = "DE" ]
then
echo "DE est bien le code de l'Allemagne."
else
echo "La variable ne correspond pas.";
fi

# Soit en utilisant grep.
if echo "$Allemagne" | grep "DE" >/dev/null 2>&1;
then
echo "DE est bien le code de l'Allemagne."
else
echo "La variable ne correspond pas.";
fi

Tester un dossier ou un fichier

Tester si un dossier existe

# Vérifier si le dossier d'installation existe, sinon, le créer.
ABS_PATH_INSTALLEUR=$(readlink -e ~/installeur)
if [ -d "$ABS_PATH_INSTALLEUR" ]; then
 echo " Le dossier ~/installeur existe déjà "
 sleep 3
else
 echo " Le dossier ~/installeur va être créé "
 sleep 3
 mkdir $ABS_PATH_INSTALLEUR
fi

Tester si un fichier existe sinon le créer

if [ -f "menu.sh" ]; then
echo " Le fichier du menu existe "
sleep 3
else
echo " Le fichier du menu n'existe pas encore et va être créé "
sleep 3
exit
fi
# test -d => teste l'existence d'un dossier (un fichier de type "d" )
# test -f => teste l'existence d'un fichier (fichier de type "-" )
# test -L => teste l'existence d'un lien symbolique (fichier de type "l" )
# test -s => teste l'existence d'un socket (fichier de type "s" )
# test -b => teste l'existence d'un fichier I/O en mode bloc (fichier de type "b" )
# test -c => teste l'existence d'un fichier I/O en mode caractère (fichier de type "c" )
# test -e => teste l'existence d'un fichier quel que soit son  
# type mais ne fonctionne qu'en bash. Pour faire pareil en "sh" (vieux Unix), il faut faire "ls -d <fichier> 1>/dev/null 2>&1"
# Petit danger => "test -d" sur un lien symbolique vers un dossier renvoie "vrai" (le test s'applique sur la cible du lien et non sur le lien lui-même).
# Si on veut tester que le fichier est un vrai répertoire, il faut faire un test de ce type # test -d dossier -a ! -L dossier

Utiliser une pause entre deux commandes

Mettre pause avec sleep

# Waits 0.5 second.
sleep .5
# Mettre en pause un script pendant une minute.
sleep 60
sleep 60s
sleep 1m
# Waits 5 hours.
sleep 5h
# Waits 5 days.
sleep 5d

Mettre pause avec read

read -p "Pause Time 5 seconds" -t 5
read -p "Continuing in 5 Seconds...." -t 5
echo "Continuing ...."
Ok-ko.png Tutoriel complémentaire pour utiliser read : http://www.quennec.fr/trucs-astuces/syst%C3%A8mes/gnulinux/programmation-shell-sous-gnulinux/les-bases-de-la-programmation-shell/la-commande-read

Mettre pause avec read

echo "Appuyer sur une touche pour continuer..."
read a

Ou encore :

read -p "Appuyer sur une touche pour continuer..."

Mettre pause avec read

#! /bin/bash

echo "Appuyer la touche <Entrée> pour continuer..."
read touche
case $touche in
*)	echo "Reprise du script..."
	;;
esac

Mettre pause avec read

#! /bin/bash

echo "Voulez-vous continuer ? [O/N]"
read mot
while
[ "$mot" = "O" ]
do
echo "Voulez-vous continuer ? [O/N]"
read mot
done
echo "Programme achevé..."

Utiliser des couleurs dans le shell

# Déclarer les couleurs
noir='\e[0;30m' gris='\e[1;30m' rougefonce='\e[0;31m' rose='\e[1;31m' vertfonce='\e[0;32m' vertclair='\e[1;32m' orange='\e[0;33m' jaune='\e[1;33m' bleufonce='\e[0;34m' bleuclair='\e[1;34m' violetfonce='\e[0;35m' violetclair='\e[1;35m' cyanfonce='\e[0;36m' cyanclair='\e[1;36m' grisclair='\e[0;37m' blanc='\e[1;37m' neutre='\e[0;m'
# Utiliser la couleur
# N'oublies pas le "-e" pour la commande "echo" sans quoi les caractères d'échappement ne seront pas interprétés ;-\
# Si echo -e ne fonctionne pas, tenter avec /bin/echo -e 
echo -e "${rougefonce}Bonjour${neutre} ${jaune}les gens${neutre}"
Ok-ko.png Plus d'informations sur les couleurs et la mise en forme avec shell : https://www.admin-linux.fr/bash-de-la-couleur-dans-le-shell/

Passer root dans un script et poursuivre l’exécution

# On ne peut pas passer root dans un script et poursuivre l'exécution du script en tant que root.
# su, sudo, etc. sont des commandes externes, exécutées dans un autre processus.
# Elles ne peuvent donc pas changer l'uid du script en cours (Le process père).
# Passer les commandes à exécuter en root comme étant des arguments de la commande "su" ou "sudo".

# A la demande du mot de passe, c'est le mot de passe root qu'il faut saisir.

# Passer en root.
su -c '
# Tes commandes à lancer en tant que root, exemple avec le chargement d'une image Docker.
docker load -i /home/user/image.tar
'

# La suite du script.
## Ici du code.

Boucles

Test conditionnel avec if

if [ $? = 0 ]
then
# echo "Oui !"
retour="0"
else
# echo "Non !"
retour="1"
fi

Test conditionnel avec for

MAX=2
for X in $(seq 1 $MAX) ; do
commande
done
Source : https://www.cyberciti.biz/faq/bash-for-loop/
Source : https://www.tutorialspoint.com/unix/unix-loop-control.htm

Test conditionnel avec while

# Initialisation de la boucle.
Var="0"
while [ $Var = 0 ]
do

# La boucle permet de répéter l'action d'ajouter différents canal web tant que la variable réponse est égale à la valeur oui, oui pour ajouter des références supplémentaires.
Question=$(zenity --question \
		--title="Ajouter d'autres liens ?" \
		--ok-label="Oui" \
		--cancel-label="Non" \
		--text="Ajouter d'autres liens ?" 2>/dev/null
);

# Tester le retour de la réponse à la question.
# Si on choisit la réponse Oui, la valeur 0 est retournée.
if [ $? = 0 ]
then
echo "Le choix est Oui !"
Var="0"
else
echo "Le choix est Non !"
Var="1"
fi

echo "Test de la variable Var en fin de script $Var"

done

Barre de progression

Source : https://github.com/adriano-pinaffo/progressbar.sh

Question réponses multiples

read -n 1 -p "Would you like to exit, reboot, or shutdown? (E/r/s) :" ans ;

case $ans in
   r|R)
       sudo reboot;;
   s|S)
       sudo poweroff;;
   *)
       exit;;
esac

Créer un menu à choix multiples

#!/bin/bash
echo " ################################## "
echo " #          Choix du menu         # "
echo " #    Installation automatique    # " 
echo " ################################## "
echo
echo " Cet assistant installe, configure ou supprime vos paquets automatiquement. "
echo
echo " [1] Installer Docker "
echo " [2] Supprimer Docker "
echo " [3] Supprimer les conteneurs et les images de Docker "
echo " [4] Importer l'image Docker de Debian "
echo " [5] Exit "
echo
echo "Choisir une option pour continuer :"

read person
case "$person" in

# "1" | "un" | "UN" | "Un" valeurs acceptées pour lancer ce menu.
  "1" | "un" | "UN" | "Un" )
  echo
  echo " Installer Docker "
  echo " Ajouter les commandes "
  sleep 4
  ;;
# Double points virgule pour fermer chaque option.

# "2" | "deux" | "DEUX" | "Deux" valeurs acceptées pour lancer ce menu.
  "2" | "deux" | "DEUX" | "Deux" )
  echo
  echo " Supprimer Docker "
  echo " Ajouter les commandes "
  sleep 4
  ;;
# Double points virgule pour fermer chaque option.

# "3" | "trois" | "TROIS" | "Trois" valeurs acceptées pour lancer ce menu.
  "3" | "trois" | "TROIS" | "Trois" )
  echo
  echo " Supprimer les conteneurs et les images de Docker "
  echo " Ajouter les commandes "
  sleep 4
  ;;
# Double points virgule pour fermer chaque option.

# "4" | "quatre" | "QUATRE" | "Quatre" valeurs acceptées pour lancer ce menu.
  "4" | "quatre" | "QUATRE" | "Quatre" )
  echo
  echo " Importer l'image Docker de Debian "
  echo " Ajouter les commandes "
  sleep 4
  ;;
# Double points virgule pour fermer chaque option.

# "5" | "cinq" | "CINQ" | "Cinq" valeurs acceptées pour lancer ce menu.
  "5" | "cinq" | "CINQ" | "Cinq" )
  echo
  echo " EXIT "
  echo " L'assistant pour une installation automatique va s'arrêter. "
  echo " Utiliser la commande sh menu.sh pour relancer l'assistant. "
  sleep 4
  exit
  ;;
# Double points virgule pour fermer chaque option.

          * )
  # Réponse par défaut.
  echo "Ce choix n'est pas disponible."
  sleep 2
  echo
  echo "Merci d'utiliser uniquement les options du menu."
  sleep 3
  sh menu.sh
  ;;

esac
exit 0

Lancer une commande si le terminal est fermé avec la croix

Simuler un installateur classique :
#!/bin/bash
set -e
set -v

# Creating an installation directory with a unique name,
# to avoid concurrency issues.
INSTALLDIR="$(mktemp -d installdir.XXXXXX)"

# Setting up cleanup of the installation directory on
# exit.  WARNING: do not use `cd` in the script, as
# INSTALLDIR is a relative path.
clean-installdir () {
rm -r "$INSTALLDIR"
}
trap clean-installdir EXIT

# Installing...
printf "Installation in progress in %s\n" "$INSTALLDIR"
# The sleeping simulates the time it would take for a
# real installation to occur.  You can close the program
# in any way you wish, to do some tests, in this time
# frame.
sleep 10

# Everything went well for the script
printf "%s\n" "Done."

# Note that you should see execution of clean-installdir
# here, as the program is exiting.  
Si je ferme le programme à coup de <C-c>, ou si je clos la fenêtre avec le raccourci clavier de mon gestionnaire de fenêtre, le répertoire d'installation est effacé.
Si je laisse le programme s'exécuter jusqu'au bout, c'est aussi le cas sans appeler explicitement la fonction.
Si je ferme la fenêtre de mon terminal avec le programme xkill, le script reçoit un signal KILL impossible à capter.
Par conséquent, le répertoire d'installation reste présent à côté du script, et doit être effacé manuellement.
Il se peut que certains gestionnaires de fenêtres aient ce genre de comportement pour lutter contre les fenêtres récalcitrantes.
Seul le manager de fenêtre dwm a été testé mais il y en a d'autres : xfwm4, metacity, kwin, awesome, fvwm, openbox...

Créer un fichier temporaire avec mktemp

# Créer un fichier texte aléatoire tmp.EAL1UAauCn dans le dossier /tmp/ et ajouter le résultat de la commande ls.
OUT="$(mktemp)"
ls > $OUT
# Créer un fichier temporaire et ajouter la date du jour.
# Le modèle peut être n'importe quel nom de fichier avec un certain nombre de 'X' ajoutés.
OUT=$(mktemp /tmp/output.XXXXXXXXXX) || { echo "Failed to create temp file"; exit 1; }
echo "Today is $(date)" >> $OUT
Plus d'informations avec man page mktemp

Variable d'environnement TMPDIR

# Par défaut, mktemp utilisera $TMPDIR de l'utilisateur.
# S'il n'est pas défini, il utilisera /tmp.
# Vous pouvez utiliser le répertoire spécifié en tant que préfixe lors de la génération du nom de fichier temporaire.
# Le répertoire sera remplacé par la variable d'environnement TMPDIR de l'utilisateur s'il est défini.
# Dans cet exemple, le fichier temporaire sera créé dans /chroot/apache/var/tmp à moins que la variable d'environnement TMPDIR de l'utilisateur ne spécifie le contraire.
mktemp -p /chroot/apache/var/tmp php.lock.XXXXXXXXXX

Bibliographie

Ok-ko.png Source : https://doc.ubuntu-fr.org/tutoriel/script_shell
Ok-ko.png Source : http://www.dreamsyssoft.com/unix-shell-scripting/ifelse-tutorial.php
Ok-ko.png Introduction à Shell Bash : https://ensiwiki.ensimag.fr/index.php?title=Introduction_aux_scripts_shell
Ok-ko.png Les tests avec Bash : https://fr.wikibooks.org/wiki/Programmation_Bash/Tests
Ok-ko.png Source : https://linuxfrench.wordpress.com/2017/03/07/4-ligne-de-commande-scripts-shell/
Ok-ko.png Source : https://buzut.fr/101-commandes-indispensables-sous-linux/

Programmation avancée avec Bash

Advanced Bash Scripting.
Ok-ko.png Bash scripting Tutorial : https://linuxconfig.org/bash-scripting-tutorial
Ok-ko.png Debian Admin - Advanced Bash-Scripting Guide : http://www.debianadmin.com/advanced-bash-scripting-guide.html
Ok-ko.png ABS-Guide : https://linux.die.net/abs-guide/
Ok-ko.png Advanced Bash-Scripting Guide : Revision 10 - 10 Mar 2014 : http://www.tldp.org/LDP/abs/abs-guide.pdf
Ok-ko.png http://blaireaulinux.free.fr/linux-scripts-bash-1.php
Ok-ko.png https://abs.traduc.org/abs-fr/

Scripts pour Youtube et conversion du format vidéo

Ok.png Source : http://happy-tux.org/marco/scripts-youtube/

Utiliser des commandes Shell avec le terminal

Utiliser des commandes Shell avec le terminal est un pense bête pour administrer GNU/Linux.

Utiliser Zenity

Utiliser Zenity

NAVIGATION

COMPRENDRE LA BLOCKCHAIN PAR LA PRATIQUE

Obtenir gratuitement de la cryptomonnaie sur internet : https://www.visionduweb.eu/forum/bitcoin/1597-gagner-des-bitcoins-miner-des-bitcoins

PARTICIPER ET PARTAGER

Vous êtes sur le HackerSpace de Vision du Web.
Les pages présentées sur le wiki évoluent tous les jours.
Certaines recherches sont peu abouties et incluent des erreurs.
Pour participer sur le wiki, créer un compte utilisateur en haut à droite.
Pourquoi utiliser GNU/Linux ? Y'a moins bien, mais, c'est beaucoup plus cher.
GNU/Linux, hackerspace, opensource, logiciels libres et transition écologique.
La recherche interne du wiki permet de trouver le contenu qui vous intéresse.
Les informations présentes sur cette page sont issues d'une recherche personnelle.
Identifiez-vous pour poser vos questions sur la page de discussion de VisionDuWeb.
Améliorer le contenu des pages en faisant des propositions depuis l'onglet discussion.
Pour écrire en Markdown : Éditeur - Générateur de tableau 1 - Générateur de tableau 2.
Vous pouvez partager les articles du wiki avec l'ensemble de la communauté des internautes.
Les recherches sur la sécurité servent à administrer et protéger votre système informatique.
Les informations du wiki ne doivent pas servir à nuire à autrui ou à un système informatique.
De nombreux outils gratuits sont listés et disponibles dans la boîte à outils de Vision du web.
D'autres pages du wiki peuvent correspondre à vos attentes. La liste de toutes les pages du wiki.

SOUTENIR VISIONDUWEB

Soutenir Vision du web avec des Bitcoins : 33ZsupGQr1rUmwj62HadcZ55hsGJajD9wN
Soutenir Vision du web avec des Bitcoins Cash : 15q5xAVFGpMbqgKsr8uhXymTv7kLfke7hq
Soutenir Vision du web avec des Bitcoins Gold : GNcVseSdiEGRzKYwZWeCbGGg1sZ6Nax172
Soutenir Vision du web avec des Bitcore (BTX) : 1Ks9FDF4FVauAHBCpBFKySiSmD8LaQhqDH
Soutenir Vision du web avec des Blackcoins : BKYBEhQGm9ExrYoWzbvmHA491sK2ArxFM6
Soutenir Vision du web avec des Bytecoins : 241LTEY5L3CSTN2afYf97obxGp4ahUYnq5jDwx5b15NQDothce8fpUeKA32X5SrJuDPBgXTsSmQRoAbCzcDvM2d2Pe9w6AY
Soutenir Vision du web avec des Clams : xMF9u1evuiN2zzEjg2KhgeYPcCLU84Ki5T
Soutenir Vision du web avec des Dash : Xd4vJFnWy27be8cLGSiXVYzP6nKFbdHATU
Soutenir Vision du web avec des Monero : 469EK3yr8JbNe3Gf1rXHD81zcHT7o1hTsDxqvWtxunnaTDLVNiXQ2NyWbwaVe4vUMveKAzAiA4j8xgUi29TpKXpm413rpYt
Soutenir Vision du web avec des Dogecoins : A64jhqCgsUyrUCPte6fV3BcG2Y7daH13Ym
Soutenir Vision du web avec des Ethereum : 0x0E4D6B7A1F88A56A1A66bf408c72FAE3d104D632
Soutenir Vision du web avec des Ethereum Classique : 0x633d83a4ab31e63d76d01edb660ecca4498ef8fa
Soutenir Vision du web avec des Litecoins : 3LKigW6TCS5MvXrZFGh8VMEtZf6MtE86iz
Soutenir Vision du web avec des Potcoins : PUYvjeJ3n2frypgD5yd95yNnwoztnZL5P3
Soutenir Vision du web avec des Solarcoins : 8aYbMcAL68U8f3c3o5pEKUKeWxx48gU1eq
Soutenir Vision du web avec des Zcash : t1Tkiv7nTt9Gwwui9ifsBdp37dTnRG7oYHp