1、安裝composer
2、執行命令:
composer create-project laravel/laravel 專案資料夾名 --prefer-dist
app
:應用程式的核心程式碼bootstrap
:一個引導框架的app.php檔案,一個cache目錄(包含路由及快取檔案),框架啟動檔案,一般情況不動。config
:所有配置檔案database
:其中migrations目錄可以生成資料表。public
:入口檔案存放地,以及靜態資源(和tp類似)resources
:routes
:應用的所有路由定義tests
:可用來單元測試vendor
:所有composer依賴包
1、常見的幾種請求
- Route::get($url,$callback);
- Route::post($url,$callback);
- Route::put($url,$callback);
- Route::delete($url,$callback);
2、匹配指定的請求方式
Route::match(['get','post'],'/',function(){
});
3、配置任意請求方式
Route::any('/home', function () {
});
4、給路由加必填引數
Route::get('/home/{id}', function ($id) {
echo 'id為:'.$id;
});
5、給路由增加可選引數
Route::get('/home/{id?}', function ($id = '') {
echo 'id為:'.$id;
});
6、透過?形式傳遞get引數
Route::get('/home', function () {
echo 'id為:'.$_GET['id'];
});
7、給路由增加別名
Route::any('/home/index', function () {
echo '測試';
})->name('hh');
8、設定路由群組
例如有如下路由:
- /admin/login
- /admin/index
- /admin/logout
- /admin/add
如果一個一個新增是比較麻煩的,他們有一個共同的區別,都是有/admin/字首,可設定一個路由群組進行新增:
Route::group(['prefix'=>'admin'], function () {
Route::get('test1', function () {
echo 'test1';
});
Route::get('test2', function () {
echo 'test2';
});
});
此時就可透過/admin/test1來進行訪問了。
9、路由配置控制器
控制器可以建一個前臺和一個後臺:
命令列建立路由:
php artisan make:controller Admin/IndexController
基本路由建立:
Route::get('test/index','TestController@index');
分目錄路由建立:
Route::get('/admin/index/index','Admin\IndexController@index');
引入:use Illuminate\Support\Facades\Validator
$param = $request->all();
$rule = [
'name'=>'required|max:2',
];
$message = [
'required' => ':attribute不能為空',
'max' => ':attribute長度最大為2'
];
$replace = [
'name' => '姓名',
];
$validator = Validator::make($param, $rule, $message,$replace);
if ($validator->fails())
{
return response()->json(['status'=>0,'msg'=>$validator->errors()->first()]);
}
在控制器中如果要使用一個類,例如use Illuminate\Http\Request
,就可以簡寫為use Request
。
但是需要在config目錄下的app.php配置檔案中加入:
'aliases' => [
'App' => Illuminate\Support\Facades\App::class,
'Arr' => Illuminate\Support\Arr::class,
'Artisan' => Illuminate\Support\Facades\Artisan::class,
'Auth' => Illuminate\Support\Facades\Auth::class,
'Blade' => Illuminate\Support\Facades\Blade::class,
'Request' => Illuminate\Support\Facades\Request::class,
],
1、獲取使用者單個輸入值:
Input::get('id')
2、獲取使用者輸入的所有值:
Input::all()
列印出來的是陣列
關於dd(dump+die)
3、獲取使用者輸入指定的值:
Input::only(['id','name'] //只接收id,其餘不接受
4、獲取使用者輸入指定值之外的值:
Input::except(['name'] //不接收name,其餘都接收
5、判斷某個值是否存在
Input::has('name') //存在返回true 不存在返回false 其中0返回true
1、檢視的建立
檢視也可分目錄管理:
控制器語法:
return view('home/test');
也可寫為:
return view('home.test');
2、變數對映
控制器中:
return view('home/test',['day'=>time()]);
檢視中:
{{$day}}
其中控制器中變數對映有三種:
- view(模板檔案,陣列)
- view(模板檔案)->with(陣列)
- view(模板檔案)->with(陣列)->with(陣列)
瞭解一下compact陣列。
3、檢視渲染
3.1 foreach的使用
控制器中:
public function index(){
$arr = [
0 => [
'name' => 'tom',
'age' => '12',
],
1 => [
'name' => 'bby',
'age' => '13',
]
];
return view('home/test',['data'=>$arr]);
}
檢視中:
@foreach($data as $k=>$v)
鍵:{{$k}}
值:{{$v['name']}}
<br/>
@endforeach
3.2 if的使用
@if(1==2)
是的
@else
不是的
@endif
4、檢視之間的引用
@include('welcome')
1、建立模型的命令
php artisan make:model Model/Admin/Member
此時,就會在app目錄內建立:
2、模型基本設定
<?php
namespace App\Model\Admin;
use Illuminate\Database\Eloquent\Model;
class Member extends Model
{
//定義表名
protected $table = 'student';
//定義主鍵
protected $primaryKey = 'id';
//定義禁止操作時間
public $timestamps = false;
//設定允許寫入的欄位
protected $fillable = ['id','sname'];
}
3、模型資料新增
方式一:
$model = new Member();
$model->sname = '勒布朗';
$res = $model->save();
dd($res);
方式二:
$model = new Member();
$res = $model->create($request->all());
dd($res);
4、模型的表連線
//查詢客戶與銷售顧問的客資列表
$data = Custinfo::select(['custinfo.*', 'customers.name'])
->join('customers', 'customers.id', '=', 'custinfo.cust_id')
->where($where)
->get()
->toArray();
5、簡單模型關聯一對一
<?php
namespace App\Model\Admin;
use Illuminate\Database\Eloquent\Model;
class Phone extends Model
{
//定義表名
protected $table = 'phone';
//定義主鍵
protected $primaryKey = 'id';
//定義禁止操作時間
public $timestamps = false;
//設定允許寫入的欄位
protected $fillable = ['id','uid','phone'];
}
<?php
namespace App\Model\Admin;
use Illuminate\Database\Eloquent\Model;
class Member extends Model
{
//定義表名
protected $table = 'student';
//定義主鍵
protected $primaryKey = 'id';
//定義禁止操作時間
public $timestamps = false;
//設定允許寫入的欄位
protected $fillable = ['id','sname'];
/**
* 獲取與使用者關聯的電話號碼記錄。
*/
public function getPhone()
{
return $this->hasOne('App\Model\Admin\Phone', 'uid', 'id');
}
}
//物件轉陣列
public function Arr($obj)
{
return json_decode(json_encode($obj), true);
}
public function index(){
$infoObj = Member::with('getPhone')->get();
$infoArr = $this->Arr($infoObj);
print_r($infoArr);
}
1、自定義日誌目錄
在config
目錄下的logging.php
中的channels
配置:
'custom' => [
'driver' => 'single',
'path' => storage_path('logs/1laravel.log'),
'level' => 'debug',
]
控制器中:
$message = ['joytom','rocker'];
Log::channel('custom')->info($message);
建立一個遷移檔案:php artisan make:migration create_shcool_table
會在database\migrations
下建立一個檔案:
在up方法中增加如下程式碼:
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
class CreateShcoolTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('shcool', function (Blueprint $table) {
$table->bigIncrements('id');
$table->string('school_name','20')->notNull()->unique();
$table->tinyInteger('status')->default(1);
$table->timestamps();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('shcool');
}
}
更詳細的生成SQL方法請參考:資料遷移檔案常用方法速查表
寫好SQL檔案以後,執行:php artisan migrate
將會生成資料表,其中操作日誌將記錄在這個表中:
php artisan migrate:rollback
:回滾最後一次的遷移操作, 刪除(回滾)之後會刪除遷移記錄,並且資料表也會刪除,但是遷移檔案依舊存在,方便後期繼續遷移(建立資料表)。
1、將DB查出後的物件轉為陣列
$info = DB::table('sd_note')->get()->map(function ($value){
return (array)$value;
})->toArray();
本作品採用《CC 協議》,轉載必須註明作者和本文連結