Rust | Cookbook
Fehler und deren Behebung
Problem
cargo build error: no default toolchain configured
Lösung
Ermitteln, welche Toolchains installiert sind
rustup toolchain list
Toolchain installieren
rustup install stable rustup default stable
Tipps und Tricks für Entwickler und IT-Interessierte
cargo build error: no default toolchain configured
Ermitteln, welche Toolchains installiert sind
rustup toolchain list
Toolchain installieren
rustup install stable rustup default stable
Voraussetzung für die Verwendung von Laravel ist eine lauffähige Entwicklungsumgebung.
Der Aufbau einer solchen Umgebung wird hier beschrieben.
WSL ist das Windows Subsystem for Linux 2 (WSL2)
> wsl /mnt/d/Websites $
curl -s https://laravel.build/example-app | bash
Beim Aufruf kann die zu verwendende Dienste mit angegeben werden. Mögliche Werte sind:
mysql, pgsql, mariadb, redis, memcached, meilisearch, selenium, and mailhog
Die Standardwerte sind:
mysql, redis, meilisearch, mailhog und selenium
curl -s "https://laravel.build/example-app?with=mysql,redis" | bash
curl -s https://laravel.build/example-app | bash
Und die letzten Schritte
Starten der Anwendung
$ cd example-app $ ./vendor/bin/sail up
Zugriff auf die Anwendung über http://localhost
List all available versions of a package | pip install --use-deprecated=legacy-resolver <module>== |
wget -q https://pypi.org/pypi/PyJWT/json -O - | python -m json.tool - |
pip config list
pip config set global.cache-dir D:\Temp\Pip\Cache
pip show <module>
pip freeze |Update Packages
requirements.txt
aktualisieren und alle Versionsnummern als Minimalversionnummer setzensed -i '' 's/==/>=/g' requirements.txt pip install -U -r requirements.txt pip freeze > requirements.txtpip install --upgrade --force-reinstall -r requirements.txtpip install --ignore-installed -r requirements.txt
Elixir ist eine dynamische, funktionale Sprache zum Erstellen skalierbarer und wartbarer Anwendungen. Elixir nutzt die Erlang VM, die dafür bekannt ist, verteilte und fehlertolerante Systeme mit geringer Latenz auszuführen.
Außerdem wird Elixir wird erfolgreich in Webentwicklung, eingebetteter Software, Datenaufnahme und Multimediaverarbeitung in einer Vielzahl von Branchen eingesetzt.
Hier ein erster Blick:
iex> "Elixir" |> String.graphemes() |> Enum.frequencies()Oder, wie es Wikipedia beschreibt:
Elixir ist eine funktionale, Elixir Grundlagen
Hier folge eine kleine Einführung in die Programmiersprache Elixir
Grundlegende Datentypen
Elixir supports the basic data types that other programming languages have. You can use integers (whole numbers), floats (decimal numbers), booleans (
true
orfalse
) and strings (which are wrapped in double quotes, are UTF-8 encoded, and support line breaks).Probieren wir in der Elixit Shell einfach die nachfolgenden Beispiele aus.
Starten Sie dazu die Elixit Shell:
iexOder wenn Sie mit Powershell arbeiten
iex.batiex(1)> 5 5 iex(2)> 4.32 4.32 iex(3)> true true iex(4)> "Hello World!" "Hello World!" iex(5)> "Hello ...(5)> World!" "Hello\nWorld!"Beachten Sie, dass wir im letzten Beispiel Umschalt + Eingabetaste verwenden, um einen Befehl auszuführen, der sich über mehrere Zeilen erstreckt.
Sie können auch Variablen und einfache Operatoren verwenden, um Werte zu vergleichen oder Zeichenfolgen zu verketten:
iex(1)> my_number = 6 6 iex(2)> my_number 6 iex(3)> my_number >= 7 false iex(4)> my_number == 6 true iex(5)> my_name = "Tristan" "Tristan" iex(6)> "Hello " <> my_name "Hello Tristan" iex(7)> "Hello #{my_name}" "Hello Tristan"Atoms
Atome sind eine besondere Art von Datentyp, die Konstanten (unveränderlichen Variablen) ähneln, ihr einziger Wert jedoch der ihnen gegebene Name ist.
iex(1)> :my_atom :my_atom iex(2)> :my_atom == "my_atom" false iex(3)> :my_atom == true false iex(4)> :my_atom == :my_atom true iex(5)> :my_other_atom = 4 ** (MatchError) no match of right hand side value: 4Im letzten Beispiel sehen wir, dass wir einem Atom keinen bestimmten Wert zuweisen können. Auch hier ist ihr einziger Wert ihr Name!
Lists
Listen in Elixir können jeden Datentyp enthalten und beliebig lang sein. Sie können mit ++ zwei Listen verketten oder mit — eine Liste von einer anderen subtrahieren.
iex(1)> [5, "Elixir", :ok] [5, "Elixir", :ok] iex(2)> [1, 2] ++ [3] [1, 2, 3] iex(3)> [1, 2, 3] -- [2] [1, 3]Beachten Sie, dass Elixir eine unveränderliche Sprache (immutable language) ist.
Wenn Sie diese Vorgänge ausführen, wird die ursprüngliche Liste also nie geändert. Stattdessen wird eine neue Liste zurückgegeben, die Sie in einer Variablen speichern können:
iex(1)> my_list = [1, 2, 3] [1, 2, 3] iex(2)> my_list ++ [4] [1, 2, 3, 4] iex(3)> my_list [1, 2, 3]Listen in Elixir können auch in zwei Teile aufgeteilt werden: den Kopf (head, der mit der hd-Funktion extrahiert werden kann) und den Schwanz (tail , der mit der tl-Funktion extrahiert werden kann). Der Kopf ist das erste Element der Liste und der Schwanz ist der Rest:
iex(1)> hd [5, "Banana", :ok] 5 iex(2)> tl [5, "Banana", :ok] ["Banana", :ok]Tuples
Tupel ähneln Listen, aber sie speichern ihre Elemente zusammenhängend im Speicher. Dadurch wird der Zugriff auf Tupelelemente schneller als auf Listenelemente, jedoch ist deren Änderung langsamer.
Sie können ein Tupel als eine Ansammlung von Werten sehen, um eine Art Ressource zu bilden, während Listen verwendet werden, um Dinge aufzuzählen.
iex(7)> {"Tristan", 24} {"Tristan", 24}Sie werden feststellen, dass viele Elixir-Funktionen Tupel zurückgeben, um zwischen Erfolgen und Misserfolgen zu unterscheiden, z. B.:
{:ok, value}
oder{:error, error_message}
Maps
Karten (Maps) sind der Schlüsselwertspeicher (key-value store) von Elixir. Die Schlüssel können einen beliebigen Typ haben und zeigen mit => auf einen Wert.
iex(1)> company_phones = iex(2)> company_phones.apple "iphone"Most of the time, you’ll probably want the keys in your map to be atoms, like in the example above. When that’s the case, there’s a nice shorthand syntax where we can use a colon instead of “
=>
” to point to the values, and omit the:
-character at the beginning of our atoms:iex(3)> company_phones =StructsEine Struktur (struct) ist einer Map sehr ähnlich, bietet jedoch einige zusätzliche Funktionen – Sie können die Anzahl der Schlüssel begrenzen und ihnen Standardwerte zuweisen.
Um Strukturen (structs) auszuprobieren, müssen wir eine Elixir-Datei erstellen, also fahren Sie fort und erstellen Sie eine neue Datei namens user.ex. Darin werden wir ein neues Modul definieren, in dem wir auch unsere Struktur definieren:
defmodule User do defstruct name: "Tristan", age: 24 endGehen Sie nun zurück zur IEx-Shell und führen Sie den Befehl c(“user.ex”) aus.
Sie können jetzt eine neue Benutzerstruktur erstellen, indem Sie
❯ iex.bat -S mix Compiling 1 file (.ex) Interactive Elixir (1.12.2) - press Ctrl+C to exit (type h() ENTER for help) iex(1)> c("user.ex") [User] iex(2)> iex(3)>Conditionals
Die grundlegenden if- und else-Anweisungen funktionieren genau so, wie Sie es erwarten. Beachten Sie, dass wir end verwenden müssen, um anzugeben, wo die if-Anweisungen enden.
iex(4)> if 5 > 4 do ...(4)> "It's higher!" ...(4)> else ...(4)> "It's lower" ...(4)> end "It's higher!"Sie können sogar die Umkehrung
unless
verwenden, um Ihren Code lesbarer zu machen:iex(6)> unless 5 > 6 do ...(6)> "The laws of mathematics still work!" ...(6)> end "The laws of mathematics still work!"Was ist mit “else if”?
In Elixir gibt es kein “else if”. Wenn Sie einen Flow mit mehr als nur zwei Ergebnissen haben, sollten Sie stattdessen wahrscheinlich cond verwenden:
iex(5)> cond do ...(5)> 5 > 6 -> ...(5)> "This isn't true" ...(5)> 5 == 8 -> ...(5)> "Neither is this" ...(5)> true -> ...(5)> "But this is!" ...(5)> end "But this is!"Wenn in Ihrer cond-Anweisung nichts als wahr ausgewertet wird, wird eine Ausnahme ausgelöst! Daher ist es normalerweise eine gute Praxis, immer eine letzte true-Bedingung ganz am Ende Ihrer Anweisung hinzuzufügen (wie wir es in unserem obigen Beispiel getan haben), um eventuelle Ausnahmen zu behandeln.
Schließlich gibt es noch eine case-Anweisung, die den Kontrollfluss in Elixir behandelt, aber dazu werden wir im nächsten Kapitel mehr erfahren …
Erstellen einer App
Im ersten Schritt erstellen wir die grundlegende Elixir Anwendung mit Hilfe des Komandos
mix
.❯ mix new starterapp * creating README.md * creating .formatter.exs * creating .gitignore * creating mix.exs * creating lib * creating lib/starterapp.ex * creating test * creating test/test_helper.exs * creating test/starterapp_test.exs Your Mix project was created successfully. You can use "mix" to compile it, test it, and more: cd starterapp mix test Run "mix help" for more commands.Durch dieses Kommando wird der Ordner
starterapp
mit der folgenbden Verzeichnisstruktur erstelltErsten Test starten
❯ cd starterapp❯ mix test Compiling 1 file (.ex) Generated starterapp app .. Finished in 0.07 seconds (0.00s async, 0.07s sync) 1 doctest, 1 test, 0 failures Randomized with seed 697266Ersten Programmcode schreiben
Funktion say_hello
defmodule StarterApp do def hello do :world end def say_hello do IO.puts("Hello World") end endInteractive Shell mit unserer App starten
iex -S mixUnter Poweshell gibt es bereits einen Alias
iex
. Hier nutzen wir diesen Aufrufiex.bat -S mix❯ iex.bat -S mix Compiling 1 file (.ex) Generated starterapp app Interactive Elixir (1.12.2) - press Ctrl+C to exit (type h() ENTER for help) iex(1)>Aufruf unserer Funktion
❯ iex.bat -S mix Compiling 1 file (.ex) Generated starterapp app Interactive Elixir (1.12.2) - press Ctrl+C to exit (type h() ENTER for help) iex(1)> StarterApp.say("Hello", "World") Hello World! :ok iex(2)>Erweitern der Funktion um Paramter
def say(greeting, name) do IO.puts "#{greeting} #{name}!" end❯ iex.bat -S mix Compiling 1 file (.ex) Generated starterapp app Interactive Elixir (1.12.2) - press Ctrl+C to exit (type h() ENTER for help) iex(1)> StarterApp.say("Hello", "World") Hello World! :ok iex(2)>Funktion mit mehrerer, auch optionalen Parametern festlegen
defmodule StarterApp do def main() do name = IO.gets("Bitte geben Sie Ihrem Name an: ") |> String.trim say(name) end def say("") do IO.puts "Sie muessen einen Namen angeben!" main() end def say(name) do IO.puts "Hallo #{name}!" end def say(greeting, name) do IO.puts "#{greeting} #{name}!" end endIn der Elixir Shell das Modul neu laden
iex(2)> r StarterApp warning: redefining module StarterApp (current version defined in memory) lib/starterapp.ex:1 {:reloaded, StarterApp, [StarterApp]} iex(3)>Aufruf ohne Parameter
iex(3)> StarterApp.say() ** (UndefinedFunctionError) function StarterApp.say/0 is undefined or private. Did you mean one of: * say/1 * say/2 (starterapp 0.1.0) StarterApp.say() iex(4)>iex(4)> StarterApp.say("") Sie muessen einen Namen angeben! Bitte geben Sie Ihrem Name an: World Hallo World! :ok iex(5)>Aufruf mit zwei Parametern
iex(8)> StarterApp.say("Hallo", "Welt") Hallo Welt! :ok iex(5)>
FastAPI basiert auf den nachfolgenden leistungsfähigen Paketen:
pip install fastapi
Oder die Installation von FastAPI mit allen Komponenten
pip install fastapi[all]
pip install uvicorn[standard]
Alembic ist ein leichtgewichtiges Datenbankmigrationstool zur Verwendung mit dem SQLAlchemy Database Toolkit für Python.
pip install alembic alembic init alembic alembic list_templates alembic init --template generic ./scripts
Migrationsskript zur Erstellug der Tabelle ‘account’
alembic revision -m "create account table"
Migrationsskript bearbeiten
def upgrade(): op.create_table( 'account', sa.Column('id', sa.Integer, primary_key=True), sa.Column('name', sa.String(50), nullable=False), sa.Column('description', sa.Unicode(200)), ) def downgrade(): op.drop_table('account')
Migration durchführen
alembic upgrade head
Migrationsskript erstellen für das Hinzufügen einer Spalte
alembic revision -m "Add a column"
Migrationsskript bearbeiten
def upgrade(): op.add_column('account', sa.Column('last_transaction_date', sa.DateTime)) def downgrade(): op.drop_column('account', 'last_transaction_date')
Migration durchführen
alembic upgrade head
Der Code für die in diesem Post erstelle Anwendung liegt hier.
Laravel Breeze ist eine minimale, einfache Implementierung aller Authentifizierungsfunktionen von Laravel, einschließlich Anmeldung, Registrierung, Paßwortzurücksetzung, E-Mail-Bestätigung und Paßwortbestätigung.
Die Standardansichtsebene von Laravel Breeze besteht aus einfachen Blade-Vorlagen, die mit Tailwind CSS gestaltet sind. Breeze bietet einen wunderbaren Ausgangspunkt für den Beginn einer frischen Laravel-Anwendung.
Laravel Breeze bietet auch eine Frontend-Implementierung von Inertia.js die von Vue oder React unterstützt wird.
Jetstream bietet ein schön gestaltetes Anwendungsgerüst für Laravel und umfasst Anmeldung, Registrierung, E-Mail-Verifizierung, Zwei-Faktor-Authentifizierung, Sitzungsverwaltung, API-Unterstützung über Laravel Sanctum und optionales Teammanagement.
Jetstream wurde mit Tailwind CSS entwickelt und bietet Ihre Wahl zwischen Livewire oder Inertia.js-gesteuertem Frontend-Gerüst.
Während Laravel Breeze einen einfachen und minimalen Ausgangspunkt für die Erstellung einer Laravel-Anwendung bietet, erweitert Jetstream diese Funktionalität mit robusteren Funktionen und zusätzlichen Frontend-Technologie-Stacks.
Für Laravel-Neulinge empfehlen wir, sich mit Laravel Breeze vertraut zu machen, bevor sie Laravel Jetstream abschließen.
Jetstream bietet ein wunderschön gestaltetes Anwendungsgerüst für Laravel und umfaßt Anmeldung, Registrierung, E-Mail-Verifizierung, Zwei-Faktor-Authentifizierung, Sitzungsverwaltung, API-Unterstützung über Laravel Sanctum und optionales Teammanagement.
Jetstream wurde mit Tailwind CSS entwickelt und bietet Ihre Wahl zwischen Livewire – oder Inertia.js-gesteuertem Frontend-Scaffolding.
Laravel Fortify ist eine Frontend-agnostische Authentifizierungs-Backend-Implementierung für Laravel.
Fortify registriert die Routen und Controller, die zur Implementierung aller Authentifizierungsfunktionen von Laravel erforderlich sind, einschließlich Anmeldung, Registrierung, Zurücksetzen des Paßworts, E-Mail-Verifizierung und mehr.
Nach der Installation von Fortify können Sie den route:list
Artisan-Befehl ausführen, um die von Fortify registrierten Routen anzuzeigen.
Da Fortify keine eigene Benutzeroberfläche bereitstellt, soll es mit Ihrer eigenen Benutzeroberfläche gekoppelt werden, die Anfragen an die registrierten Routen stellt. Wir werden im Rest dieser Dokumentation genau besprechen, wie Anfragen an diese Routen gestellt werden.
Voraussetzung für die Verwendung von Laravel ist eine lauffähige Entwicklungsumgebung. Der Aufbau einer solchen Umgebung wird hier beschrieben.
Wenn auf Ihrem Computer bereits PHP und Composer installiert sind, können Sie ein neues Laravel-Projekt erstellen, indem Sie Composer direkt verwenden.
composer create-project laravel/laravel app cd app
Nachdem die Anwendung erstellt wurde, können Sie den lokalen Entwicklungsserver von Laravel mit dem nachfolgenden Befehl starten:
php artisan serve
Am einfachsten wird eine neuen Anwendung installiert mit Hilfe der Laravel CLI laravel
. Sie installieren diese über
composer global require laravel/installer
Der Laravel Installer verwendet für die neue Anwendung die vorgegebenen Standardeinstellungen (z., B. Registrierungsmöglichkeit ohne Mailbestätigung).
Hinweis: Im Laufe diese Posts werden Sie diese anpassen.
laravel new app --stack=livewire --jet --teams
Die Konfiguration der Datenbank erfolgt in der bereits vorhandenen Datei .env
.
Nach der Installation finden Sie dort die folgenden Einträge für eine MySQL Datenbankanbindung:
Wir wollen uns hier auf die Einrichten der Laravel Anwendung beschränken und nicht noch zusätzlich die Installation einer MySQL Datenbank beschreiben. Hierzu finden Sie mehr Informationen an anderer Stelle.
Ändern Sie den nachfolgenden Eintrag (im obigen Beispiel in Zeile 10):
DB_CONNECTION=sqlite
Im nächsten Schritt erstellen wir eine leeren Datenbank, indem wir im Ordner database
eine Datei database.sqlite
erstellen
Hinweis: Sie können eine leere Datei auch über die Kommandozeile erstellen. Voraussetzung ist das Tool sqlite3 (hier geht’s zum Download)
sqlite3 database\database.sqlite "create table a(f int); drop table a;"
Eine leere SQlite-Datenbank können sie auch mit diesem Kommando erstellen:
touch database/database.sqlite
Im letzten Schritt werden in der Datenbank die für Laravel notwendigen Tabellen eingerichtet:
php artisan migrate
Hinweis: Die vorhandenen Tabellen können Sie sich über die Kommandozeile anzeigen lassen:
sqlite3.exe .\database\database.sqlite ".tables"
Um mit dem Frontend arbeiten zu können müssen zu ersten die notwendigen Komponenten installiert und das Frontend erstellt werden:
npm install npm run dev
Die grundlegende Installation und Konfiguration ist abgeschlossen. Starten Sie die Anwendung durch das nachfolgende Kommando:
php artisan serve
Öffnen Sie die Anwendung im Browser über den Link http://127.0.0.1:8000
Die erstelle Laravel-Anwendung enthält bereits die Funktionalität, das sich Benutzer Registrieren und Anmelden können. Hierzu finden Sie auf der Startseite rechts oben entsprechende Links.
Mit den verwendeten Standardeinstellungen reicht zum Einrichten des neuen Benutzer der Name, die E-Mail und das Passwort.
Um eine höhere Sicherheit zu erreichen, werden diese Einstellungen so geändert, das einen Bestätigungsmail an den Benutzer gesendet wird. Erst durch den Klick auf den darin enthaltenen Bestätigungslink wird die Einrichtung des Benutzers abgeschlossen.
Das Einrichten dieser E-Mail Verification erfolgt in mehreren Schritten:
emailVerification
in der Datei config/fortify.php
app/Models/User.psp
class User extends Authenticatable implements MustVerifyEmail
Damit Laravel eine E-Mail versenden kann wird der Zugang zu einem E-Mail Server verwendet. Hier benötigen wir die Zugangsdaten für den SMTP-Versand.
Festgelegt werden diese Parameter wieder in der Datei .env
:
Die entsprechenden Werte hängen vom verwendeten Mailserver ab.
Zuerst müssen Sie bei ihrem Provider ein Mailkonto einrichten (Benutzer und Passwort). Testen Sie am besten diese Daten über den von ihrem Provider bereitgestellten Webmailer.
Die weiteren Werte (Port, Protokoll) entnehmen Sie der Dokumentation ihres Providers.
Nachfolgend zwei Beispiele:
Provider | Strato | United Domains |
---|---|---|
MAIL_MAILER | smtp | smtp |
MAIL_HOST | smtp.strato.de | smtps.udag.de |
MAIL_PORT | 587 | 587 |
MAIL_ENCRYPTION | tls | tls |
Starten Sie die Anwendung neu und richten Sie einen weiteren Benutzer ein
php artisan serve
Starten Sie die Registrierung über den Link Register auf der Startseite.
Geben Sie die notwendigen Benutzerdaten ein. Bestätigen Sie ebenfalls die Terms of Services, falls diese aktiviert sind.
Bei erfolgreichen Versand der Bestätigungsmail erscheint diese Anzeige. Sie erhalten ebenfalls eine Bestätigungsmail an die verwendete E-Mail-Adresse.
Öffnen Sie die E-Mail und klicken Sie auf den Bestätigungslink. Achten Sie darauf, das der Link im gleichen Browser geöffnet wird, mit dem Sie die Registrierung durchgeführt haben.
Alternativ kopieren Sie einfach den Link, wechseln wieder zurück in das Registrierungsfenster und fügen den kopierten Link ein.
Danach befinden Sie sich auf dem Dashboard der Anwendung. Die Registrierung hat somit funktioniert.
Fehlermeldung: Der angegebene Host ist unbekannt
Fehlermeldung: Es konnte keine Verbindung hergestellt werden, da der Zielcomputer die Verbindung verweigerte
Fehlermeldung: Authentication failed: wrong user/password
Die erstelle Laravel-Jetstream Anwendung beinhaltet bereits “von Haus aus” einen großen Funktionsumfang. Jede einzelnen Funktionalität wird in den meisten Fällen durch mindestens zwei Dateien realisiert:
Die Views werden z. B in dem nachfolgendem Ordner gespeichert:
vendor\laravel\jetstream\resources\views
Um diese Views innerhalb unserer Anwendung anpassen zu können, müssen sie an einer anderen Stelle gespeichert werden. Sonst werden unsere Änderungen z. B. nach jedem Update wieder gelöscht.
Wie kopieren diese durch den nachfolgenden Befehl:
php artisan vendor:publish --tag=jetstream-views
Die Kopien finden Sie im Ordner
resources\views\vendor\jetstream
php artisan livewire:publish
Dadurch werden die nachfolgenden Dateien und Ordner erstellt:
config/livewire.php
public/vendor/
config/livewire.php public/vendor/livewire/livewire.js public/vendor/livewire/livewire.js.map public/vendor/livewire/manifest.json resources/views/vendor/livewire/bootstrap.blade.php resources/views/vendor/livewire/simple-bootstrap.blade.php resources/views/vendor/livewire/simple-tailwind.blade.php resources/views/vendor/livewire/tailwind.blade.php
Aktivieren Sie dazu das Feature termsAndPrivacyPolicy
in der Datei config/jetstream.php
Dadurch sehen sie im Registrierungsdialog ein zusätzliches Optionsfeld
Bearbeiten Sie in der Datei config/app.php
die Einstellung locale
. Ändern Sie den Wert auf 'de'
.
Nach einem Neustart der Anwendung werden aber weiterhin die englischen Texte angezeigt.
Die Ursache liegt an der nicht vorhandenen deutschen Übersetzung der verwendeten Texte. Prüfen Sie einfach den Ordner mit den vorhandenen Übersetzungen: resources/lang
Es gibt nur einen Unterordner en
für die englischen Texte:
Zusätzlich zu den Übersetzungen muss noch ein weiterer Schritt erfolgen. Um ihre Anwendung komplett auf Mehrsprachlichkeit umzustellen dürfen keine Texte direkt angegeben werden.
Betrachten wir hierzu die Startseite, speziell die Links in der rechten oberen Ecke:
Der View für die Startseite wird in der Datei resources/views/welcome.blade.php
definiert:
Wir sehen, das hier der Text direkt in englischer Sprache angegeben wird.
<a href="{{ route('register') }}" class="...">Register</a>
Es ist sehr schwierig, eine automatische Übersetzung für alle Texte durchzuführen, wenn nicht angegeben wird, ob ein bestimmter Text übersetzt werden soll. Einfach alle Texte zu übersetzen kann zu Problemen führen.
Daher wird bei Laravel der Weg gewählt, explizit anzugeben, ob ein Text übersetzt werden soll.
Diese Angabe der nachfolgende Text soll übersetzt werden erfolgt mit Hilfe der Funktion __
(Der Name der Funktion lautet tatsächlich __
, als zwei Unterstriche)
Anstatt
Register
schreiben wir nun
{{ __('Register') }}
Dadurch erkennt Laravel (speziell die Blade Template Engine), das hier eine Übersetzung durchgeführt werden soll und sucht eine passenden Übersetzungstext.
Hier kommt nun der bereits angesprochen Ordner resources/lang
ins Spiel. Erstellen Sie in diesem Ordner eine Datei de,json
und verwenden Sie als Inhalt den nachfolgenden Text:
Nach einen Neustart der Anwendung sehen wir gewünschte Ergebnis:
Den gewünschten Übersetzungstext findet Blades anhand des angegebenen Textes innerhalb der Funktion __:
welcome.blade.php | de.json |
---|---|
Die Übersetzung der Anwendung erfordert somit für alle Texte die gleichen Schritte
{{ ('Sample text') }}
de.json
, z. B. "Sample text
“: Beispieltext“Die Startseite entspricht immer noch der Standardanwendung. Der entsprechende View ist welcome.blade.php
.
Zur Startseite wird dieser View aber nicht durch den Namen, sondern durch eine Einstellung in der Datei routes/web.php
Mit Hilfe des von Laravel verwendeten Routing, wird festgelegt, welcher View angezeigt wird, wenn eine bestimmte URI aufgerufen wird.
In der vorhandenen Einstellung legt fest, das bei der Uri '/'
der View 'welcome'
angezeigt wird.
Wir verwenden hier das in der Laravel Dokumentation beschrieben einfache Beispiel.
Erstellen Sie die Datei Datei resources/views/home.blade.php
. Verwenden Sie als Inhalt den nachfolgenden Text
<html> <body> <h1>Hello, {{ $name }}</h1> </body> </html>
Passen Sie dann die Datei routes/web.php
an.
Route::get('/welcome', function () { return view('welcome'); })->name('welcome'); Route::get('/', function () { return view('home', ['name' => 'Laravel']); });
Wir ändern die neue Startseite mit der Uri /
und stellen die alte Startseite unter einer neuen Uri /welcome
bereit.
Öffnen Sie nun wieder die Seite http://localhost:8000
oder aktualisieren Sie ein bereits geöffnetes Browserfenster:
Die vorherige Startseite können wir über die Uri /welcome
erreichen
Erweitern Sie die Daten resources/views/navigation-menu.blade.php um einen Eintrag:
<!-- Navigation Links --> <div class="hidden space-x-8 sm:-my-px sm:ml-10 sm:flex"> <x-jet-nav-link href="{{ route('dashboard') }}" :active="request()->routeIs('dashboard')"> {{ __('Dashboard') }} </x-jet-nav-link> </div> <div class="hidden space-x-8 sm:-my-px sm:ml-10 sm:flex"> <x-jet-nav-link href="{{ route('welcome') }}" :active="request()->routeIs('welcome')"> {{ __('Welcome') }} </x-jet-nav-link> </div>
php artisan make:component MyComponent
You can register your jetstream blade components in App\Providers\JetstreamServiceProvider.php
located in app\Providers
folder.
Fügen sie die nachfolgende Funktion hinzu:
protected function registerComponent(string $component) { \Illuminate\Support\Facades\Blade::component('jetstream::components.'.$component, 'jet-'.$component); }
Der nachfolgende Programmcode registriert ihre Komponente:
public function register() { $this->registerComponent('subform'); }
Sie können diese nun wie folgt nutzen:
<x-jet-subform>
Laravel bietet mit Eloquent ORM ein leistungsfähiges Datenbank-Framework.
Mit Hilfe von Modellen werden die Datenbankobjekte (z. B. Benutzer) definiert. Diese Objekte können dabei einfach durch zusätzliche Felder erweitert werden.
Im nachfolgenden Beispiel wollen wir das vorhandene Objekt User
einer initialen Laravel-Installation durch ein Feld username
erweitern.
Erstellen eines Datenbank-Migrationsskriptes, das unser gewünschtes Feld zur Tabelle users
hinzufügt.
php artisan make:migration add_column_username_to_users_table --table users
Hinzufügen des Felder Username in der neu erstellten Datei. Dies liegt unter database/migrations.
public function up() { Schema::table('users', function (Blueprint $table) { $table->string('username')->nullable(); }); } public function down() { Schema::table('users', function (Blueprint $table) { $table->dropColumn('username'); }); }
Hinzufügen des Feldes Username im Datenbankmodel User in der Datei app\Models\User.php
protected $fillable = [ 'name', 'email', 'password', 'username' ];
Dieser Schritt entfernt alle Tabellen und erstellt sie neu. Dadurch gehen natürlich alle bereits vorhandenen Daten verloren!
❯ php artisan migrate:fresh --seed Dropped all tables successfully. Migration table created successfully. Migrating: 2014_10_12_000000_create_users_table Migrated: 2014_10_12_000000_create_users_table (2,326.47ms) Migrating: 2014_10_12_100000_create_password_resets_table Migrated: 2014_10_12_100000_create_password_resets_table (1,789.28ms) Migrating: 2014_10_12_200000_add_two_factor_columns_to_users_table Migrated: 2014_10_12_200000_add_two_factor_columns_to_users_table (1,010.74ms) Migrating: 2019_08_19_000000_create_failed_jobs_table Migrated: 2019_08_19_000000_create_failed_jobs_table (2,399.99ms) Migrating: 2019_12_14_000001_create_personal_access_tokens_table Migrated: 2019_12_14_000001_create_personal_access_tokens_table (2,313.60ms) Migrating: 2021_06_19_085151_create_sessions_table Migrated: 2021_06_19_085151_create_sessions_table (5,279.76ms) Migrating: 2021_06_19_102316_add_username_to_users_table Migrated: 2021_06_19_102316_add_username_to_users_table (432.59ms) Database seeding completed successfully.
Hinzufügen des Feldes Username in der Datei resources\views\profile\edit.blade.php
<x-slot name="form"> ... <!-- Email --> ... <!-- column username --> <div class="form-group row"> <label for="username" class="col-md-4 col-form-label text-md-right">{{ __('Benutzername') }}</label> <div class="col-md-6"> <input id="username" type="text" class="form-control @error('username') is-invalid @enderror" name="email" value="{{ old('email') ?? auth()->user()->email }}" required autocomplete="email" autofocus> @error('username') <span class="invalid-feedback" role="alert"> <strong>{{ $message }}</strong> </span> @enderror </div> </div> </x-slot>
Wir passen die PHP Komponente UpdateUserProfileInformation
an, so das die neuen Werte gespeichert werden
app\Actions\Fortify\UpdateUserProfileInformation.php
public function update($user, array $input) { ... if ($input['email'] !== $user->email && $user instanceof MustVerifyEmail) { $this->updateVerifiedUser($user, $input); } else { $user->forceFill([ 'name' => $input['name'], 'email' => $input['email'], 'username' => $input['username'], ])->save(); } }
Voraussetzung für die Verwendung von Laravel ist eine Web-Server, der eine PHP Umgebung unterstützt bzw bereitstellt.
Eine einfache Umgebung wird durch XAMPP bereitgestellt. Eine Implementierung kann man bei Apache Friends herunterladen.
XAMPP ist hier ein Akronym für X (Beliebiges Betriebssystem) Apache + MariaDB + PHP + Perl
Im Laufe dieses Post werden mehrerer Pakete und Programme installiert. Alle werden unter einem Startorder installiert. Diese benennen wir im nachfolgenden mit $LARAVEL_TUTORIAL_ROOT
mkdir C:\LARAVEL_TUTORIAL
Setzen der Umgebungsvariablen unter Windows Command Line cmd
set LARAVEL_TUTORIAL_ROOT="C:\LARAVEL_TUTORIAL"
Setzen der Umgebungsvariablen unter Poweshell
$ENV:LARAVEL_TUTORIAL_ROOT="C:\LARAVEL_TUTOPRIAL"
Download des Installer: https://www.apachefriends.org/index.html
Um mehrerer Versionen parallel zu installieren, stehen ZIP-Dateien zur Verfügung. Die aktuelle Version ist Installation mit dem Composer Diese Verzeichnis als Umgebungsvariable festlehen Fügen Sie die beiden nachfolgenden Pfad ihrer Der Composer ist ein PHP Archiv mit der Dateierweiterung Hierzu erstellen wir einfach ein Skript, das diese Aufgabe für uns übernimmt. Erstellen Sie dazu die Datei composer.bat im Verzeichnis Um weniger Meldungen anzuzeigen kann die nachfolgenden Konfigurationseinstellung verwendet werden: https://nodejs.org/en/download/ Der Laravel Installer erleichterter das Einrichten und Erstellen neuer Laravel Anwendungen. Installiert wird er mit Hilfe des Composer:Zielverzeichnis erstellen
mkdir $LARAVEL_TUTORIAL_ROOT\composer
cd $LARAVEL_TUTORIAL_ROOT\composer
$ENV:COMPOSER_HOME = $ENV:LARAVEL_TUTORIAL_ROOT\composer
set COMPOSER_HOME
Composer herunterladen
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === '756890a4488ce9024fc62c56153228907f1545c228516cbf63f885e036d37e9a59d27d63f46af1d4d07ee0f76181c7d3') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
Pfad erweitern um
PATH
Variablen hinzu:composer.bat erstellen
phar
. Diese Dateien können nicht direkt aufgerufen werden, sondern stellen ein PHP Programm dar. Es muss als über PHP gestartet werden.php
composer.ps1 erstellen
php $env:composer_home\composer.phar $args
composer Tipps und Tricks
composer global config bin-dir --absolute --quiet
Installation von NodeJS
Installation des Laravel Installer
composer global require "laravel/installer"
Installation einer Beispielanwendung
laravel new blog
Nächste Schritte
proc freq
proc freq data=mydata; tables myvar / nocol nopercent nocum; run;
mydata.myvar.value_counts().sort_index()
proc freq order=freq data=mydata; tables myvar / nocol nopercent nocum; run;
mydata.myvar.value_counts()
proc freq order=freq data=mydata; tables myvar / nocol nopercent nocum missing; run;
mydata.myvar.value_counts(dropna=False)
proc means
proc means data=mydata n mean std min max p25 median p75; var myvar; run;
mydata.myvar.describe()
proc means data=mydata n mean std min max p1 p5 p10 p25 median p75 p90 p95 p99; var myvar; run;
mydata.myvar.describe(percentiles=[.01, .05, .1, .25, .5, .75, .9, .95, .99])
data
stepdata concatenated; set mydata1 mydata2; run;
concatenated = pandas.concat([mydata1, mydata2])
proc contents
proc contents data=mydata; run;
mydata.info()
proc contents noprint data=mydata out=contents; run;
contents = mydata.info() # check this is right
* Try this for size: http://www2.sas.com/proceedings/sugi26/p095-26.pdf;
len(mydata)
laravel new app --jet
cd app
DB_HOLST=
composer update php artisan key:generate php artisan migrate
php artisan vendor:publish --tag=jetstream-views
npm install npm run dev php artisan serve
composer self-update --2
https://laravelarticle.com/laravel-ajax-datatable-crud
https://postsrc.com/posts/how-to-implement-visitor-views-or-visitor-counter-in-laravel-application