BashStarter
Bash is een programma dat in de terminal kan worden gebruikt om shell bestanden (scripts) te maken of interactief terminalcommando's uit te voeren.
Het is de taak van de kernel om de hardware af te schermen, terwijl de shell dient om toegang tot het systeem te geven.
De shell wordt vaak afgekort tot sh en is de Engelse term voor omhulsel of schil om een reeks commando's.
Inhoud
Wat is bash
Bash is een handige commandoverwerker voor interactief gebruik, maar ook een programmeertaal. Het is de afkorting van Bourne Again Shell en is een woordgrapje op de naam van de originele shell die voluit Bourne shell heet, naar de auteur Stephen Bourne (zie bron 1). De naam Bourne again wordt in het Engels uitgesproken als born again en betekent wedergeboren.
De bash is geschreven door Brian Fox (zie bron 1), een werknemer van de Free Software Foundation GNU, en sterk geïnspireerd op de Unix shell /bin/sh die Bourne ontwikkelde voor Bell Labs.
Bash streeft ernaar om volledig achterwaartse compatibiliteit te zijn met sh, de afkorting voor shell.
Gebruik
De shell werkt op POSIX systemen en wordt onder andere gebruikt in Linux en OS X.
Met bash is het mogelijk om ingewikkelde opdrachtregels uit te voeren. Deze opdrachten of verzamelingen kunnen in een bestand worden opgeslagen en vormen dan een script.
Er worden drie soorten tekens gebruikt:
- reserved words - zijn woorden met een speciale bedoeling om gegevens te sturen of te onderzoeken zoals if en while.
- words - speciale tekens om verbinden tussen gegevens aan te geven zoals | en >.
- operators - de rest van de input zijn gewone woorden waarvan sommige een speciaal doel hebben.
Zoals in elke programmeertaal heeft bash variabelen die refereren aan een alfanumerieke naam en zijn verbonden door de formule naam=waarde.
Een 'word' variabele begint met een $ en vertegenwoordigt een variabele die de waarde daarvan overneemt.
Een commando wordt uitgevoerd door de regelvolgorde: commandonaam opties argumenten.
Maken
Maak met fe (je favoriete editor) b.v. gedit of tunar.
- 1. sudo fe 'naam bestand', b.v. sudo gedit /mijndirectory/Mijnbestand
- Met deze commandoregel opent gedit de file 'Mijnbestand in de directory 'mijndirectory'.
Als het bestand niet bestaat wordt het hiermee gemaakt.
- 2. Bewerken
Daarna
- 3. Opslaan
- 4. Sluiten
Startbaar maken
- 5. chmod 755 Mijnbestand
- Met chmod wordt de toegang tot de file geregeld waarmee kan worden aangegeven wie wel en niet van de file gebruik kunnen maken.
- Het nummer "755" zorgt er voor dat de eigenaar lees, schrijf en uitvoer rechten heeft en alle anderen kunnen alleen lezen en uitvoeren. Met "700" is het file prive en helemaal afgesloten voor anderen.
Inhoud
De eerste regel is:
- #!/bin/bash of #!/bin/sh
In de eerste regel staat achter #! welk programma het script moet uitvoeren.
Normaliter is dat de shell waarmee u inlogt; u kunt hiermee voorkomen dat een programma niet werkt als het bijvoorbeeld vanaf de C-shell wordt gestart.
Aan de andere kant zal een script dat begint met #!/bin/bash niet werken op een systeem waar die shell in /usr/local/bin staat of afwezig is. Deze eigenschap is vooral handig voor scripts in andere talen.
Regels met uitleg over het programma (# betekent, is geen programma onderdeel)
- #dit is alleen uitleg
Daarna volgen de opdrachten in de gewenste volgorde b.v.:
- programmanaam variabele
- variabele commando
- commando programmanaam
Voorbeeld
Voorbeeld
- sudo gedit Dirlist
- #!/bin/bash
- #Plaats de directory en de errorcode in een file
- ls > Dirlist 2>&1
- Opslaan
- Afsluiten
- chmod 755 Dirlist
Let er op dat de volgorde van commando's en opties gevolgen hebben b.v.:
- ls > dirlist 2>&1
Lees 'ls' de bestandslijst van een directory en schrijf '>' die naar de file (bestand) 'dirlist' en schrijf daarna '2>' de foutcode '&1' in dat file.
terwijl
- ls 2>&1 > dirlist
alleen de bestandslijst plaatst omdat de foutcode al verwerkt is voor het bestand is geschreven.
Ander voorbeeld:
De string variabele wordt STR aangemaakt en gevuld met de alfanumerieke karakters Hallo Wereld!
Daarna wordt de string op het scherm getoond door 'echo'
- sudo gedit Werelddag
- #!/bin/bash
- #Dit programma groet de wereld
- STR="Hallo wereld!"
- echo $STR
- Opslaan
- Afsluiten
- chmod 755 Werelddag
Programma starten
Toets in de terminal ./prgrammanaam
- ./Dirlist plaatst in de terminal en in een file in de gebruikersmap met de hele map inhoud.
- ./Werelddag groet de gebruiker in de terminal met de tekst uit het programma.
Shellshock
In september 2014 ontdekte Stephane Chazelas een beveiligingskwetsbaarheid in Bash versies 1.14 tot en met 4.3 en kreeg de naam "shellshock". Ontwikkelaar Chet Ramey, die Bash voor de laatste tweeëntwintig jaar heeft onderhouden, zegt dat hij waarschijnlijk in 1992 de bug per ongeluk aan Bash heeft toegevoegd Het haalde de hoogst mogelijke NCSC- en CVSS-score, wat inhoudt dat er zeer eenvoudig misbruik van te maken was en de potentiële schade hiervan zeer groot kon zijn. Voor zover bekent is er voor de ontdekking nooit misbruik van gemaakt, ondanks dat Bash in Linux, OS X en Unix op dat moment mogelijk op honderden miljoenen systemen aanwezig was.