一、安装laravel
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');
四、laravel验证器
引入: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、模型基本设置
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、简单模型关联一对一
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']; | |
} | |
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方法中增加如下代码:
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(); |