BashStarter: verschil tussen versies
(Nieuw) |
(Aangepast) |
||
Regel 31: | Regel 31: | ||
== Maken == | == Maken == | ||
Maak met '''fe''' (je <u>'''f'''</u>avoriete <u>'''e'''</u>ditor) b.v. gedit of tunar. | Maak met '''fe''' (je <u>'''f'''</u>avoriete <u>'''e'''</u>ditor) b.v. gedit of tunar. | ||
− | :1. sudo '''fe''' 'naam bestand', b.v. sudo gedit /mijndirectory/Mijnbestand | + | :1. sudo /'''fe'''/'naam bestand', b.v. sudo gedit /mijndirectory/Mijnbestand |
:Met deze commandoregel opent ''gedit'' de file 'Mijnbestand in de directory 'mijndirectory'. | :Met deze commandoregel opent ''gedit'' de file 'Mijnbestand in de directory 'mijndirectory'. | ||
Als het bestand niet bestaat wordt het hiermee gemaakt. | Als het bestand niet bestaat wordt het hiermee gemaakt. | ||
:2. Bewerken | :2. Bewerken | ||
+ | :De gegevens die nodig zijn om het programma te starten. | ||
Daarna | Daarna | ||
:3. Opslaan | :3. Opslaan | ||
Regel 40: | Regel 41: | ||
Startbaar maken | Startbaar maken | ||
:5. chmod 755 Mijnbestand | :5. chmod 755 Mijnbestand | ||
− | :Met chmod | + | :Met chmod worden de toegangsrechten voor het bestand 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. | :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. | ||
Regel 47: | Regel 48: | ||
:<nowiki>#</nowiki>!/bin/bash of <nowiki>#</nowiki>!/bin/sh | :<nowiki>#</nowiki>!/bin/bash of <nowiki>#</nowiki>!/bin/sh | ||
In de eerste regel staat achter #! welk programma het script moet uitvoeren. | 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. <br /> | + | Normaliter is dat de shell waarmee u inlogt (in ons geval bash in de directie biin); u kunt hiermee voorkomen dat een programma niet werkt als het bijvoorbeeld vanaf de C-shell wordt gestart. <br /> |
− | Aan de andere kant zal een script dat begint met #!/bin/ | + | Aan de andere kant zal een script dat begint met #!/bin/ 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) | Regels met uitleg over het programma (# betekent, is geen programma onderdeel) | ||
Regel 70: | Regel 71: | ||
Let er op dat de volgorde van commando's en opties gevolgen hebben b.v.: | Let er op dat de volgorde van commando's en opties gevolgen hebben b.v.: | ||
:ls > dirlist 2>&1 | :ls > dirlist 2>&1 | ||
− | Lees 'ls' de bestandslijst van een directory en schrijf '>' die naar de file (bestand) 'dirlist' en schrijf daarna '2>' | + | Lees 'ls' de bestandslijst van een directory en schrijf '>' die naar de file (bestand) 'dirlist' en schrijf daarna de foutcode '2>' in dat file '&1'. |
terwijl | terwijl | ||
Regel 78: | Regel 79: | ||
'''Ander voorbeeld:''' | '''Ander voorbeeld:''' | ||
− | De string variabele wordt | + | De string variabele STR wordt aangemaakt en gevuld met de alfanumerieke karakters Hallo Wereld!<br /> |
Daarna wordt de string op het scherm getoond door 'echo' | Daarna wordt de string op het scherm getoond door 'echo' | ||
:sudo gedit Werelddag | :sudo gedit Werelddag | ||
Regel 89: | Regel 90: | ||
:chmod 755 Werelddag | :chmod 755 Werelddag | ||
− | == Programma starten == | + | === Programma starten === |
Toets in de terminal ./prgrammanaam | Toets in de terminal ./prgrammanaam | ||
− | :./Dirlist plaatst in de terminal en in een file in de gebruikersmap | + | :./Dirlist plaatst de hele map inhoud in de terminal en in een file in de gebruikersmap. |
:./Werelddag groet de gebruiker in de terminal met de tekst uit het programma. | :./Werelddag groet de gebruiker in de terminal met de tekst uit het programma. | ||
== Shellshock == | == Shellshock == | ||
In september 2014 ontdekte Stephane Chazelas een beveiligingskwetsbaarheid in Bash versies 1.14 tot en met 4.3 en kreeg de naam "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 | + | 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. | 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. | 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. |
Versie van 19 dec 2014 om 17:59
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
- De gegevens die nodig zijn om het programma te starten.
Daarna
- 3. Opslaan
- 4. Sluiten
Startbaar maken
- 5. chmod 755 Mijnbestand
- Met chmod worden de toegangsrechten voor het bestand 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 (in ons geval bash in de directie biin); 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/ 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 de foutcode '2>' in dat file '&1'.
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 STR wordt 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 de hele map inhoud in de terminal en in een file in de gebruikersmap.
- ./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.