關(guān)于laravel的介紹就不講了,總之laravel是款比較強(qiáng)大的框架,它是國(guó)外框架所以在安裝的上面可能比較麻煩。
laravel的安裝
首先安裝laravel之前要安裝composer,如果是linux系統(tǒng)即可直接下載安裝,下載完后不能安裝記得修改下文件權(quán)限用命令chmod,這邊主要講下window下如何使用composer這個(gè)工具。?
首先百度搜索中國(guó)composer鏡像,就可以找到composer config -g repositories.packagist composer?
http://packagist.phpcomposer.com這條命令,運(yùn)行cmd在命令行運(yùn)行上面的命令,就可以下載composer工具,
下載成功后可以看到composer文件底下有個(gè)composer.json文件這是一個(gè)配置文件,打開配置文件寫明php版本信息和要下載的laravel信息,格式如下:
{ "name": "laravel/laravel", "description": "The Laravel Framework.", "keywords": ["framework", "laravel"], "license": "MIT", "type": "project", "require": { "php": ">=5.5.9", "laravel/framework": "5.1.*" }, "require-dev": { "fzaninotto/faker": "~1.4", "mockery/mockery": "0.9.*", "phpunit/phpunit": "~4.0", "phpspec/phpspec": "~2.1" }, "autoload": { "classmap": [ "database" ], "psr-4": { "App\\": "app/" } }, "autoload-dev": { "classmap": [ "tests/TestCase.php" ] }, "scripts": { "post-install-cmd": [ "php artisan clear-compiled", "php artisan optimize" ], "pre-update-cmd": [ "php artisan clear-compiled" ], "post-update-cmd": [ "php artisan optimize" ], "post-root-package-install": [ "php -r \"copy('.env.example', '.env');\"" ], "post-create-project-cmd": [ "php artisan key:generate" ] }, "config": { "preferred-install": "dist" }, "repositories": [ {"type": "composer", "url": "http://packagist.phpcomposer.com"}, {"packagist": false} ] }```
配置好之后輸入composer install 進(jìn)行安裝laravel,這邊要比較注意的是安裝目錄的路徑問(wèn)題,如果你想安裝在d盤底下就在把命令行切到d目錄底下進(jìn)行安裝(在此操作之前要配置好環(huán)境變量)。
laravel的目錄結(jié)構(gòu)介紹
安裝完的第一次肯定是要想怎么去運(yùn)行它,很簡(jiǎn)單,直接進(jìn)入public文件就可以打開一個(gè)開始頁(yè)面,如果在本地的話那就是localhost/laravelproject/public,就可以運(yùn)行。
接下來(lái)介紹下laravel目錄結(jié)構(gòu),首先介紹下public的index.php文件 里面主要是加載了開始文件然后才能成功運(yùn)行l(wèi)aravel,具體的兩個(gè)文件你可以在根目錄下bootstrap文件夾中找到?,F(xiàn)在看下app中的結(jié)構(gòu):
view中主要放的是視圖文件(創(chuàng)建文件時(shí)要用到blade模板,比如創(chuàng)建test.blade.php,laravel中是結(jié)合blade模板引擎來(lái)調(diào)用視圖模板)
controller放的是控制器(手動(dòng)創(chuàng)建時(shí)記得要用composer 命令進(jìn)行更新)
config中主要是配置文件(比如配置數(shù)據(jù)庫(kù)時(shí)要用到database.php文件)
models主要是放模型(也就是數(shù)據(jù)庫(kù)的表)
routes則是路由配置,
filters則是過(guò)濾器。
laravel是怎么運(yùn)行的
剛學(xué)習(xí)時(shí)肯定是要先嘗試下如何運(yùn)行這個(gè)laravel,首先手動(dòng)創(chuàng)建一個(gè)controller,文件命名為TestController.php,然打開命令行進(jìn)入項(xiàng)目的根目錄下 執(zhí)行 composer dumpautoload,里面內(nèi)容可以模仿homeController.php。
然后編輯routes.php文件,將原來(lái)的Route::GET(‘/’,function()…);修改為Route::Get(‘/’,’TestController@showWelcome’); 然后運(yùn)行也會(huì)跳到laravel歡迎界面。
如果Route::Get(‘test’,’TestController@showWelcome’);則在網(wǎng)站根目錄下后面直接增加test就可以訪問(wèn)了,到了這里應(yīng)該明白了怎么到Controller,Controller怎么到View了。
laravel數(shù)據(jù)庫(kù)配置
這邊用到的是mysql,進(jìn)行了簡(jiǎn)單的配置
'mysql' => array( 'driver' => 'mysql', 'host' => 'localhost', 'database' => 'oss', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', )
laravel的數(shù)據(jù)庫(kù)使用
<?php use Illuminate\Auth\UserTrait; use Illuminate\Auth\UserInterface; use Illuminate\Auth\Reminders\RemindableTrait; use Illuminate\Auth\Reminders\RemindableInterface; class User extends Eloquent implements UserInterface, RemindableInterface { use UserTrait, RemindableTrait; /** * The database table used by the model. * * @var string */ protected $table = 'users'; /** * The attributes excluded from the model's JSON form. * * @var array */ protected $hidden = array('password', 'remember_token'); }
即可以直接使用 User ::all() 查詢所有結(jié)果 ,User::find(2)查詢一個(gè),Post::findOrFail(2)
如果沒(méi)找到就會(huì)返回錯(cuò)誤,Post::save()、Post::where()->find()、Post::add()、Post::delete()
數(shù)據(jù)庫(kù)的簡(jiǎn)便操作:
DB::table(‘tablename’)->insert([ 插入多個(gè)時(shí)要再加一個(gè)數(shù)組 ['title'=>'title','name'=>'name'] ['title'=>'title'] ['title'=>'title'] ]) 插入時(shí)要想得到ID DB::table('tablename')->insertGetId(['title'=>'titles']) 更新數(shù)據(jù)要有ID DB::table('tablename')->where('id',1)->update(['title'=>'titles']) 刪除數(shù)據(jù) DB::table('tablename')->where('id',1)->delete(); 查詢數(shù)據(jù) DB::table('tablename')->get(); 得到全部的值 DB::table('tablename')->get(['title']); 只查詢title的值 DB::table('tablename')->first(); 只拿第一個(gè) DB::table('tablename')->orderBy('id','desc')->first(); 根據(jù)id排序 DB::table('tablename')->where('id','!=',2)->get(); 不等于2 DB::table('tablename')->where('id','!=',2)->where('id','>',5)->get(); 可以使用多個(gè)where DB::table('tablename')->where('id','!=',2)->OrWhere('id','>',5)->get(); 或者 DB::table('tablename')->whereBetween('id',[2,5])->get(); 閉包之間 DB::table('tablename')->whereIn('id',[2,5,9])->get(); DB::table('tablename')->whereNotIn('id',[2,5,9])->get(); DB::table('tablename')->whereNull('id')->get(); 為空的話就可以查詢出來(lái) DB::table('tablename')->take(3)->get(); 只查詢3個(gè) DB::table('tablename')->limit(3)->get(); 只查詢3個(gè) DB::table('tablename')->skip(2)->take(3)->get(); 只查詢3個(gè)跳過(guò)第二個(gè) DB::table('tablename')->where('id','!=',2)->pluck('title'); 只返回它的title DB::table('tablename')->count(); 有多少條記錄 DB::table('tablename')->max('id'); DB::table('tablename')->min('id'); DB::table('tablename')->avg('id'); DB::table('tablename')->sum('id');
多表關(guān)聯(lián)
在Post中定義
public function comment(){ return $this->hasMany('Comment','post_id') } 正向關(guān)聯(lián) 一對(duì)多 一對(duì)一是hasOne
在Comment中定義
public function post(){ return $this->belongsTo('Post','post_id') } 反向關(guān)聯(lián)
取得關(guān)聯(lián)值
Post::find(2)->comment 就可以得到Comment這張表的內(nèi)容 //這樣查詢一個(gè)是可以的 查詢多個(gè)就要設(shè)置預(yù)載入 查詢多個(gè) Post::with('comment')->get(); Post::with(['comment'=>function($query){$query->where('id','>',2)}])->get(); 加條件
感謝大家的閱讀,希望大家有所收益。
本文轉(zhuǎn)自:https://blog.csdn.net/Happy_CSDN/article/details/49363219
推薦教程:《php教程》
Das obige ist der detaillierte Inhalt vonSo lernen Sie das Laravel-Framework in PHP (Anf?nger). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

Zu den effizienten Methoden zum Testen von Laravel-API-Schnittstellen geh?ren: 1) Verwenden von Tools von Laravels eigenem Test-Framework und Drittanbieter wie Postman oder Schlaflosigkeit; 2) Schreiben von Unit -Tests, Funktionstests und Integrationstests; 3) Umgebungsumgebung nachahmen und den Datenbankstatus verwalten. Durch diese Schritte k?nnen die Stabilit?t und funktionale Integrit?t der API sichergestellt werden.

Die benutzerdefinierte Laravel -Benutzerauthentifizierungslogik kann in den folgenden Schritten implementiert werden: 1. Fügen Sie zus?tzliche überprüfungsbedingungen bei der Anmeldung hinzu, z. B. die überprüfung der Mailbox. 2. Erstellen Sie eine benutzerdefinierte Schutzklasse und erweitern Sie den Authentifizierungsprozess. Die benutzerdefinierte Authentifizierungslogik erfordert ein tiefes Verst?ndnis des Authentifizierungssystems von Laravel und achtet auf Sicherheit, Leistung und Wartung.

Zu den Schritten zum Erstellen eines Pakets in Laravel geh?ren: 1) Verst?ndnis der Vorteile von Paketen wie Modularit?t und Wiederverwendung; 2) nach Laravel -Namen und strukturellen Spezifikationen; 3) Erstellen eines Dienstanbieters mithilfe von Artisan Command; 4) Konfigurationsdateien korrekt ver?ffentlichen; 5) Verwaltung der Versionskontrolle und Ver?ffentlichung an Packagist; 6) strenge Tests durchführen; 7) detaillierte Dokumentation schreiben; 8) Gew?hrleistung der Kompatibilit?t mit verschiedenen Laravel -Versionen.

Die Integration von Social -Media -Anmeldungen in das Laravel -Framework kann durch die Verwendung des Laravelsocialite -Pakets erreicht werden. 1. Installieren Sie das Socialite -Paket: Verwenden Sie CompoSerRequirelaravel/Socialite. 2. Konfigurieren Sie den Dienstanbieter und Alias: Fügen Sie die relevante Konfiguration in config/app.php hinzu. 3. Setzen Sie API -Anmeldeinformationen: Konfigurieren von Social -Media -API -Anmeldeinformationen in .Env und config/dienste.php. 4. Schreiben Sie die Controller -Methode: Hinzufügen von Umleitungs- und Rückrufmethoden, um den Anmeldungsprozess für soziale Medien zu bew?ltigen. 5. FAQs handhaben: Stellen Sie die Einzigartigkeit der Benutzer, die Datensynchronisation, die Sicherheits- und Fehlerbehandlung sicher. 6. Optimierungspraxis:

Die implementierende Funktion für das Kennwortreset in Laravel erfordert die folgenden Schritte: 1. Konfigurieren Sie den E -Mail -Dienst und setzen Sie relevante Parameter in der Datei .env; 2. Definieren Sie das Zurücksetzen von Kennwortrücksetzen in Routen/web.php; 3.. Anpassen von E -Mail -Vorlagen; 4. Achten Sie auf E -Mail -Sendeprobleme und die Gültigkeitsdauer der Token und passen Sie die Konfiguration gegebenenfalls an. 5. Sicherheit in Betracht ziehen, um Brute-Force-Angriffe zu verhindern; 6. Zweiten Sie den Benutzer, nach dem Erfolg des Kennworts, den Benutzer, sich von anderen Ger?ten anzumelden.

Zu den h?ufigen Sicherheitsbedrohungen in Laravel-Anwendungen geh?ren die SQL-Injektion, Cross-Site-Scripting-Angriffe (XSS), CSRF-Cross-Site-Anfrage (CSRF) und Datei-Upload-Schwachstellen. Zu den Schutzma?nahmen geh?ren: 1.. Verwenden Sie Eloquentorm und QueryBuilder für parametrisierte Abfragen, um die SQL -Injektion zu vermeiden. 2. überprüfen und filtern Sie die Benutzereingabe, um die Sicherheit der Ausgabe zu gew?hrleisten und XSS -Angriffe zu verhindern. 3. Setzen Sie CSRF -Token in Formularen und AJAX -Anfragen, um die Anwendung vor CSRF -Angriffen zu schützen. 4. überprüfen und verarbeiten Sie die Datei -Uploads streng, um die Sicherheit der Datei sicherzustellen. 5. Es werden regelm??ige Code -Audits und Sicherheitstests durchgeführt, um potenzielle Sicherheitslücken zu entdecken und zu beheben.

Middleware ist ein Filtermechanismus in Laravel, mit dem HTTP -Anforderungen abgefangen und verarbeitet wird. Verwenden Sie Schritte: 1. Middleware: Verwenden Sie den Befehl "phpartisanMake: MiddleWareCheckrole". 2. Definieren Sie die Verarbeitungslogik: Schreiben Sie eine spezifische Logik in die generierte Datei. 3. Registrieren Sie Middleware: Middleware in kernel.php hinzufügen. 4. Verwenden Sie Middleware: Middleware in Routing Definition anwenden.

Laravel bietet eine Vielzahl von Strategien, um die Datensicherheit zu gew?hrleisten: 1. Verwenden Sie Cryptfacade, um Daten zu verschlüsseln, um vertrauliche Informationen zu schützen. 2. Aktivieren Sie die Zugriffskontrolle durch Autorisierungsrichtlinien (AuthorizationPolicies), um Datenleckage zu verhindern. 3. Passen Sie die Protokollierungsrichtlinie an und verwenden Sie die Protokollrotation, um sensible Datenlecks zu vermeiden.
