php 框架 laravel 简介

目录

一、laravel简介

二、版本选择

三、laravel下载安装以及开发环境搭建

(一):环境搭建

(二):下载、安装及大致介绍

四、laravel路由

  (一):简介

  (二):路由学习

五、控制器

六、模型

  (一)、新建模型及使用

  (二)、数据库操作

七、视图

 (一)、新建视图

 (二)、输出视图

 (三)、模板详解


一、laravel简介

laravel是一套优雅简介的PHP开发框架,受欢迎程度非常之高,功能强大,工具齐全;以下是本人在学习过程中记录的laravel比较基础的资料,权当学习笔记,请大神们多多指教

二、版本选择

本篇学习笔记以laravel5.2.15版本为框架的版本基础;更多版本请移步https://www.golaravel.com/

三、laravel下载安装以及开发环境搭建

(一):环境搭建

  由于laravel使用较多的php新特性,所以新版本的laravel对PHP的版本要求比较高,这里选择的laravel5.2.15要求 PHP>5.5.9+ 。Win系统下推荐使用集成的开发环境比如wamp、phpStudy、Xampp都可以,下载安装的时候需要注意PHP版本,Linux系统下需要编译安装,这里推荐一篇博客https://www.linuxidc.com/Linux/2016-10/136327.htm(ubuntu下lamp开发环境搭建)。本篇学习笔记也是基于lamp环境下

(二):下载、安装及大致介绍

  1、安装包下载安装

  原本laravel中文网是可以下载一键安装包的,但是等我去下载的时候发现没地方可以下载,也只能通过度娘找其它下载资源下载安装包然后安装;我的资源:https://github.com/yuwenbo5/laravel5.2.15.git;下载安装包后解压更改名称(laravel),直接拷贝到环境根目录www(win下wamp环境)或者 /var/www/html(linux下lamp环境)中;打开浏览器输入url:localhost/laravel/public 然后回车,出现如下画面表示安装成功:

  2、composer安装

  cd到环境根目录,使用命令:composer create-project --prefer-dist laravel/laravel=5.2.15  laravel(项目名称,可修改)

  3、简单介绍

  laravel是基于mvc模式的php框架,m——模型层,v——视图层,c——控制器层;以下为laravel框架的目录文件,框出来的文件目录将在后续中用到:

  

  app是应用的核心代码文件目录,以后的代码基本都在这里完成;app/Http/Controller目录是应用的控制器文件;routes.php是框架的路由文件,负责路由分配和映射;Http下的类文件,比如上面目录中的User.php、Menu.php文件是应用的模型文件;config目录是所有应用的配置文件目录;public是框架的入口文件及静态资源文件目录;resources/views则是应用的视图文件目录。

四、laravel路由

  (一):简介

  用过thinkPHP的开发者都知道,传统的MVC的url都是对应应用的控制器及控制器中的方法,laravel中的MVC则是通过路由功能映射到对应的程序(控制器方法),通过路由将用户的请求发送到对应的程序进行处理,其作用就是建立url和处理程序之间的映射关系,这样做有一个好处,对url进行美化只需要修改路由而无需对程序本身进行修改。

  laravel中请求类型包括:get、post、put、patch、delete。

  前面说了route.php是laravel的路由文件,所有的路由映射都要通过编辑route.php文件进行代码书写。

  (二):路由学习

    1、基本路由

    get请求:

 

 

<?php
//基本路由的get请求
Route::get('get_base', function(){
    return 'get request base';
});
浏览器输入:http://127.0.0.1/laravel/public/get_base
页面输出:get request base

 

 

    post请求:

 

 

<?php
//基本路由的post请求
Route::post('post_base', function(){
    return 'post request base';
});
以上路由需要通过post方式请求,这里不做演示
请求后页面输出:post request base

 

 

    2、多请求路由

    顾名思义,多请求路由则是可以通过多种请求方式进行请求,多请求路由主要有两种方式,match和any

    (1)、match接收请求类型的数组从而限定请求的类型:

 

 

<php

//多请求路由match

Route::match(['get','post'], 'multi', function(){
    return 'multi post or get';
});
url:http://127.0.0.1/laravel/public/multi
此路由可通过get、post请求
请求后返回字符串:multi post or get

 

 

    (2)、any方式

 

 

<?php
//any方式
Route::any('multi', function(){
   return 'multi get or post';
});
url:http://127.0.0.1/laravel/public/multi
请求返回字符串:multi get or post

 

 

    3、路由参数

    给路由绑定参数,接收参数进行处理

    (1)、必选参数

 

 

<?php
//带参数的路由
Route::get('myname/{name}', function($name){
    return 'my name is '.$name;
});
url:http://127.0.0.1/laravel/public/myname/yuwenbo
get访问后页面输出:my name is yuwenbo

 

 

     (2)、可选参数($userid=null表示默认值,可设置没有参数时的默认值)

 

 

<?php
//可选参数绑定
Route::get('user/{userid?}', function($userid=null){
    return 'userid is '.$userid;
});
访问url:http://127.0.0.1/laravel/public/user/username
输出:userid is username

访问url:http://127.0.0.1/laravel/public/user
输出:userid is

可选参数绑定使得路由很灵活

 

 

    (3)、路由参数过滤(用正则表达式对传入的参数进行过滤)

可使用数组形式过滤多个参数

 

 

 

 

    4、路由别名

    给路由通过['as' => 'alias']数组使用别名后,可通过route('别名')生成url,请看代码理解:

<?php
//路由别名
Route::get('student/info',['as' => 'studentInfo' ,function(){

    //通过route('studentInfo')生成完成url后返回
    return route('studentInfo');

}]);

访问url:http://127.0.0.1/laravel/public/student/info
页面返回:http://127.0.0.1/laravel/public/student/info

注:别名的好处在于,以后在控制器中使用route('别名')的方式生成url后,即便修改了路由的名字,也不用再修改控制器程序,因为通过别名程序能自动生成修改后的url

 

 

 

 

 

    5、路由群组

    通过关键字group创建路由群组

 

 

<?php
/*
*路由群组
*/
Route::group(['prefix' => 'admin'], function(){
    
    //此时的访问地址:http://127.0.0.1/laravel/public/admin/student/info
    Route::get('student/info',['as' => 'studentInfo' ,function(){
        return route('studentInfo');
    }]);

    //此时的访问地址:http://127.0.0.1/laravel/public/admin/info/yuwenbo/20
    Route::get('info/{name}/{age?}', function($name,$age=null){
        return 'name is '.$name.', age is '.$age;
    })->where(['name' => '[a-zA-Z]+', 'age' => '[1-9]+']);
    
});
此时的访问地址url必须要加上群组前缀,否则将不能访问

 

 

    6、路由中输出视图

    通过view()函数输入视图

<?php
/**
* 路由中输出视图
*/
//框架的欢迎界面路由
Route::get('/',function(){
   return view('welcome');
});

访问url:http://127.0.0.1/laravel/public
浏览器显示laravel的欢迎界面


//做如下修改
Route::get('welcome',function(){
   return view('welcome');
});

修改后访问url:http://127.0.0.1/laravel/public/welcome 浏览器同样显示laravel的欢迎界面

 

 

 

 

一般情况是不会在路由中输出视图的。

 

五、控制器

  控制器目录app/Http/Controller,此目录下有一个基本的控制器Controller,新增的控制器统一继承此Controller;

  命名空间:namespce  App\Http\Controller;

  命名规则:控制器文件名跟类名统一首字母大写,以 控制器名+Controller 为命名规则,比如新建一个控制器 :AdminController.php

<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;

class AdminController extends Controller
{
    public function index()
    {
        return view('admin/index');
    }
}

新建控制器AdminController继承于基类Controller

 

 

 

 

 1、路由关联控制器,通过路由访问控制器程序:

 

 

 

 

<?php
//路由关联映射控制器方法一:
Route::get('admin/index', 'AdminController@index');

//路由关联控制器方法二:
Route::get('admin/index', ['uses' => 'AdminController@index']);

//路由别名关联控制器:
Route::get('admin/index', [
    'uses' => 'AdminController@index',
    'as' => 'adminindex'
]);

 2、路由关联控制器进行参数绑定:

 

 

//路由书写 route.php
<?php
//结合之前学习的参数过滤
Route::get('admin/index/{num}', [
    'uses' => 'AdminController@index',
    'as' => 'adminindex'
])->where('num', '[0-9]+');
?>

//控制器代码 AdminController.php
<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;

class AdminController extends Controller
{
    public function index($num)
    {
        return 'num is '.$num;
    }
}
?>
访问url:127.0.0.1/laravel/public/admin/index/5
页面输出:num is 5

 

 

 

六、模型

   laravel框架的模型文件在app目录下,统一首字母大写,文件名与类名一致,统一继承于 Illuminate\Database\Eloquent\Model 基类;

  (一)、新建模型及使用

 

 

//模型文件 Admin.php
<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 13:35
 */
namespace App;
use Illuminate\Database\Eloquent\Model;

class Admin extends Model
{
    public static function getAdmin()
    {
        return 'this is admin model static getAdmin action';
    }

}

?>


//控制器文件 AdminController.php
<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;

class AdminController extends Controller
{
    public function index()
    {
        return Admin::getAdmin();
    }
}

 

 

  (二)、数据库操作

  连接数据库mysql,laravel的数据库连接只需要配置好数据库的配置文件即可,也就是config目录下的database.php

 

 

//database.php文件
'mysql' => [
            'driver' => 'mysql',
            'host' => env('DB_HOST', 'localhost'),
            'port' => env('DB_PORT', '3306'),
            'database' => env('DB_DATABASE', 'forge'),
            'username' => env('DB_USERNAME', 'forge'),
            'password' => env('DB_PASSWORD', ''),
            'charset' => 'utf8',
            'collation' => 'utf8_unicode_ci',
            'prefix' => 'shop_',
            'strict' => false,
            'engine' => null,
     ]
//配置文件读取的是.env文件的内容

 

 

  打开.env文件,做如下配置修改即可连接到mysql数据库

APP_ENV=local
APP_DEBUG=true
APP_KEY=base64:IxkVvrRLqdJeU9h8vGu1W58OG3NVuDtkMWyC6nIT4qs=
APP_URL=http://localhost

//mysql连接配置
DB_CONNECTION=mysql
DB_HOST=localhost
DB_PORT=3308
DB_DATABASE=shop
DB_USERNAME=root
DB_PASSWORD=root

CACHE_DRIVER=file
SESSION_DRIVER=file
QUEUE_DRIVER=sync

REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379

MAIL_DRIVER=smtp
MAIL_HOST=mailtrap.io
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null

 

 

 

 

   1、使用DB facade操作数据库

     类似原生的sql语句进行curd操作,例如:新建一个表user包含id、username、passwrod、email、sex、create_time、update_time字段

<?php
/**
 * 使用DB facade进行CURD操作
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class AdminController extends Controller
{

    public function query()
    {
        //查询
        $user_list = DB::select('select * from user');//返回数组


        //新增
        $bool = DB::insert('insert into user(username,email,sex) values(?, ? ,?)',
['admin', 'example@mail.com', '1']);//返回布尔值

        //修改
         $rows = DB::update('update user set password=? where username=?',['123456', 'admin']);//返回影响的行数

        //删除
        $rows = DB::delete('delete from user where username=?', ['admin']);//返回删除的行数

    }
}

 

 

 

 

   使用DB facade操作数据库,初学还是很简单的,因为原生的sql还是比较熟的。

 

   2、使用查询构造器操作数据库

   使用查询构造器进行数据库操作使得操作简介、方便,示例使用上面的user表进行演示

    查询构造器----新增数据

<?php
/**
 * 查询构造器之新增数据
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class AdminController extends Controller
{

    public function query()
    {
        //插入一条数据
        $bool = DB::table('user')->insert(
            ['username' => 'yuwenbo', 'email' => 'example@mail.com', 'sex' => 1]
        );//返回布尔值

        //插入一条数据返回插入的id
        $insert_id = DB::table('user')->insertGetId(
            ['username' => 'yuwenbo', 'email' => 'example@mail.com', 'sex' => 1]
        );


        //插入多条数据
        $bool = DB::table('user')->insert([
            ['username' => 'yuwenbo', 'email' => 'example@mail.com', 'sex' => 1],
            ['username' => 'tom', 'email' => 'example@mail.com', 'sex' => 0]
        ]);

    }

}

 

 

 

 

    查询构造器-----更新数据:更新指定内容和自增自减两种方式

<?php
/**
 * 查询构造器之更新数据
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;11 use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class AdminController extends Controller
{

    public function query()
    {
        //更新指定内容
        $rows = DB::table('user')->where('username','admin')->update(['password' => '123456']);//返回影响的行数

        //更新自增自减
        $rows = DB::table('user')->where('username','admin')->increment('sex');//自增1
        $rows = DB::table('user')->where('username','admin')->increment('sex',$n);//自增n

        $rows = DB::table('user')->where('username','admin')->decrement('sex');//自减1
        $rows = DB::table('user')->where('username','admin')->decrement('sex',$n);//自减n

        //自增同时修改其它内容
        $rows = DB::table('user')->where('username','admin')->increment('sex', 3, ['email' => '4546464684@mail.com']);//自增同时修改内容

    }

}

 

 

 

 

    查询构造器----删除数据

 

 

 

 

<?php
/**
 * 查询构造器之删除数据
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class AdminController extends Controller
{

    public function query()
    {
        //删除数据
        $rows = DB::table('user')->where('username','admin')->delete();

        //清空数据(危险,谨慎使用)
        DB::table('user')->truncate();

    }

}

    查询构造器-----查询数据

 

 

<?php
/**
 * 查询构造器之查询数据
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class AdminController extends Controller
{

    public function query()
    {
        //返回所有的数据get()
        $user_list = DB::table('user')->get();
        $user_list = DB::table('user')->where('id','>=',2)->get();

        //多条件查询
        $user_list = DB::table('user')->whereRaw('id >= ? and sex = ?', ['5' ,'1'])->get();

        //按照默认排序返回第一条数据first()
        $user = DB::table('user')->first();
        $user = DB::table('user')->orderBy('id','desc')->first();
        $user = DB::table('user')->where('id', 2)->first();

        //返回结果集中指定的字段pluck
        $usernames = DB::table('user')->whereRaw('id >= ? and sex = ?', ['5' ,'1'])->pluck('username');

        //返回指定字段的下标lists
        $usernames = DB::table('user')->whereRaw('id >= ? and sex = ?', ['5' ,'1'])->lists('username', 'id');//以id作为下标

        //返回指定的多个字段select()
        $user_list = DB::table('user')->where('id', '>=', '1')->select('username','email','sex')->get();

        //每次查指定的条数chunk
        DB::table('user')->chunk(2, function($user_list){
            dd($user_list);
        });

    }

}

 

  mysql中的聚合函数对应的构造器方法count()、max()、min()、avg()、sum(),使用都比较简单也很好理解,这里不再赘述

 

七、视图

  laravel框架的视图支持原生的php文件,视图的目录 resources/views;

  命名:统一以.php为后缀的PHP文件,规则:视图名+.+blade,例如新建一个视图文件:index.blade.php

  一般情况下一个控制器会建一个视图目录,例如AdminController控制器,我们将在views下新建一个admin目录

 (一)、新建视图

1 //模板文件 views/admin/index.blade.php
2 
3 this is views/admin/index.blade

 (二)、输出视图

 

 

//路由文件
<?php
    //绑定控制器方法
    Route::get('admin/index', 'AdminController@index');

?>


//控制器文件 AdminController.php
<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2018/8/25/025
 * Time: 0:51
 */
namespace App\Http\Controllers;

class AdminController extends Controller
{
    public function index()
    {
        return view('adminindex');//传入要输出的模板名即可
    }
}
访问url:http://127.0.0.1/laravel/public/admin/index
页面显示:this is views/admin/index.blade

 

 

 输出视图时可以携带变量然后在模板中输出出来,这点将在后面的模板的详细使用中用到;

 (三)、模板详解

  1、模板继承

  由于多数页面有相同部分,所以使用模板继承简化模板使用;以下首先在views/common下新建一个基本的公共模板文件base.blade.php,公共的模板文件放在views/common文件夹下

 base.blade.php

  在views下新建首页index.blade.php继承公共模板文件

 index.blade.php

  模板继承语法:@extends('目录.文件名');例如:@extends('common.base'),就可以继承common目录下的base.blade.php模板

  使用@section重写子模板,使用@yield展示某个指定的section的内容;

  @yield不能被子模板扩展,@section可以被子模板扩展

  如果需要展示父模板内容,可使用@parent;例如:

@extends('common.base')

@section('header')
    @parent
    header
@stop

  2、基础语法及使用

  输出变量,使用{{ $变量名 }},如下所示:

 

 

//例如控制器中
public function index(){
        return view('index',['name' => 'yuwenbo']);
}

//模板中输出index.blade.php
<p>{{ $name }}</p>
结果输出:yuwenbo

 

 

  使用php函数,blade模板允许我们使用原生的php,也可以在模板中使用函数及运算符

 

 

//模板中使用php函数

//输出时间戳
<p>{{ time() }}</p>

//格式化当前时间
<p>{{ date('Y-m-d H:i:s', time()) }}</p>

//三元运算符
<p>{{ in_array($name,$array) ? 'true' : false }}</p>

 

 

  模板中短语法:{{ isset($age) ? $age : 'default value' }}  等同于  {{ $age or 'default value' }}

  原样输出:

  使用@{{ $count }}即可原样输出 ‘{{ $count }}’。

  子视图引入

  使用@include关键字;例如在views下新建模板leftmenu.blade.php

 

 

 

 

@extends('common.base')

@section('header')
    @parent
    header
@stop

@section('leftmenu)
    //引入子视图
    @include('leftmenu')
@stop

  3、流程控制

  if判断语句

//if流程判断语句
@if($user == 'admin')
   i am admin
@elseif($user == 'yuwenbo')
   i am yuwenbo
@else
   i am default
@endif

 

 

 

 

  for循环语句

//for循环语句
@for($i = 1; $i <= 10; $i ++)
    <p>i is {{ $i }}</p>
@endfor

  foreach循环语句

 

 

//控制器
public function index()
{
     $data_list = array('name' => 'yuwenbo', 'age' => 22, 'job' => 'php');

     return views('index', ['data' => $data_list]);
}


//视图输出
@foreach($data as $key => $val)
    {{ $key }} => {{ $val }}
@endforeach

 

 

 

 

//控制器
public function index()
{
     $data_list = array(
         array('name' => 'admin', 'age' => 20),
         array('name' => 'word', 'age' => 18)
     );

     return views('index', ['data' => $data_list]);
}


//模板输出
@foreach($data as $key => $val)
    <p>name is {{ $val->name }}, age is {{ $val->age }}</p>
@endforeach

 

 

 

  4、模板中使用url

  url()-->通过路由的名字生成url

  action()-->通过指定控制器及方法名生成url

  route()-->通过路由别名生成url

 

 

//路由 route.php
Route('index',[
    'uses' => 'IndexController@index', 
    'as' => 'in'
]);


//模板中生成url的方式
<a href="{{ url('index') }}">url方式</a>
<a href="{{ action('IndexController@index') }}">action方式</a>
<a href="{{ route('in') }}">route方式</a>

 

 

以上三种方式均生成url: http://127.0.0.1/laravel/public/index

以上三种方式在实际使用时都可以用,一般情况下,使用url()和route()较多,因为写法简介方便

==========================================================

1.请求类型

get , put , post , patch , delete 等

2.路由访问方式

get , post , any , match(['get',post])

3.路由传参

Route::get('user/{id}' ,function ($id){

});

Route::get('user/{name}/{id}',function($name,$id){

});

4.传递可选参数

Route::get('user/{name?}',function($name = value){

});

5.参数限制

Route::get('user/{name}',function(){})->where('name','[A-Za-z] + ');

Route::get('user/{id}/{name}',function(['id'=>'[0-9]+','name'=>'[a-z]+']));

6.模版中的写法

<h1><?php echo $title; ?></h1>

<p> {{$msg}}</p>

7.创建数据库

create database 库名 charset utf8

8.修改配置文件

在.env文件中进行修改

9.创建迁移文件

php artisan make:migration create_good_table --create=goods

执行这句命令 php artisan migrate

10.创建Model 文件控制表名,主键

php artisan make:model 表名

11.迁移文件操作

up()负责建表,加列,加索引

down()负责删表,减列,去索引

public function up(){

Schema::table('goods',function(Blueprint $table){

   添加

   $table->char('email',50);

});

Schema::table('goods',function ($table{

删除

$table->dropColumn('email');

}));

}

12.数据库迁移一操作

php artisan migrate:rollback 会退

php artisan migrate:reset 回退到初始状态

13.DB类操作数据库(Model)

insert 添加操作

DB::table()->insert(插入字段);(插入一维多维数组,返回true,false)

14.插入后返回主键值,获取主键值  insetrGetld();

$id = DB::table('goods')->insertGetId($rows);

15.update 修改操作

.典型的修改

DB::table('users')->where('id',1)->update(['age'=>19]);

相当于

update users set age = 19 where id =1;

在某值的基础上增长或者减少(默认1)

增长increment('健',步长);减少decrement();

16.delete删除操作

var_dump(DB::table('goods')->where('id','>',3)->delete());

where 有三个参数是,第二个参数当做运算符

17.select查找

DB::table('goods')->get();

DB::table('goods')->where('id','>',6)->get();

DB::table('goods')->select('id','email')->where()->get();

DB::table('goods')->where('id',6)->first();

18.表单提交要加一段_token();

<input type="hidden" name="_token" value="<?php echo csrf_token(); ?>">

19.不解析模版和防xss 攻击

在前段模版引擎中,用{{}}做表签边界

为防止blade 模版去解析前面加@

例如@{{$jang}}

['code'=>'<script>alert(1)</scriptt>']

&lt;script&gt;alert(1)&lt;/script&gt;

20.Model 放在/app目录下面,命名空间App

Model 继承Illuminate\Database\Eloquent\Model

引入new \App\Msg()

21.自动生成和实例化

php artisan make:model Msg

22.增加 

$msg->save();

23.查找

按键值查找

Msg::find($id);

按where 条件查找具体的那一条

Msg::where('id','>',3)->first();

查找多行all() 和 get()

24.delete 删除

Msg::where('id',$id)->delete();

25.复杂查询

asc   升序        desc 降序

orderBy('id','desc')  根据id排序

Msg::count();数数

Msg::avg('id');求平均值

Msg::min('id');最小值最大值

Msg::sum('id');求和

26.与Model有个约定

调整表名,主键值,屏蔽新增键值

27.控制器的生成

php artisan make:controller ArticleController --plain

--plain 去掉默认显示的

28.缓存位置

config/cache.php 默认用到的缓存驱动 file  其他缓存Memcached 和Redis

30.缓存调用

use Illuminate/Support/Facades/Cache

Cache::put('key','value',$minutes);

31.添加缓存

换存不存在添加缓存,缓存已经存在返回true,否则false

Cache::add('key','value',缓存时间);

持久话存储缓存

Cache::forever('key','val');

储存缓存放在storage/framework/

32.获取缓存

Cache::get('key','default');

如果有缓存输出缓存如果没有缓存返回default

pull 获取缓存后删除

33.删除缓存

Cache::forget('key');

清除所用缓存

Cache::flush();

判断缓存是否存在

Cache::has('key');

34.Request对象

请求方式(get/post)

请求参数($\post,$\FILES)

请求路径(域名后的部分)

请求Cookie等诸多信息

input 函数

35.利用Request对象做文件上传

Route::get('msg/fil','MsgController@fil');

Route::post('msg/ups','MsgController@ups');

控制器

public function fil(){

return view('msg.fil');

}

public function ups(){

$req->file()->move('上传文件地址',为文件起的名字);

}

判断文件上传是否成功

isvalid();即实例变量的值是否是个有效的对象句柄

hasFile();属性获取一个值,该值指示 FileUpload 控件是否包含要上载的文件。 在对要上载的文件执行操作之前,使用该属性来验证该文件是否存在

 

36.隐式控制器

Route::controller('article','ArticleController');

 

37.资源控制器

make:controller ArtisanController

Route::resource('article','ArticleController');

查看功能

php artisan route:list

 

38.laravel 缓存应用

静态缓存,查询缓存,数据缓存

静态缓存:缓存的整个页面;

动态缓存:存储数据库中的数据进行了缓存,既“通过动态缓存,不需要再读取数据库了,直接通过缓存文件来调取相应的数据”;

动态缓存:直接从缓存中读取,不经过数据查询;

 

39.缓存

存储缓存

Cache::put('key','value',$minutes);

 

40.laravel 中的路由与TP中的相比较

laravel 中的路由非常灵活,TP的路由是  模块/控制器/方法 TP 不能叫路由,只是URL与控制器的对应关系,或者叫URL分发;

41.设计区别laravel 连接网站的全过程,数据库+MVC+错误处理

 

42.laravel

array_collapse  函数将数组的每一个数组折合成单个数组:

str_limit('字符串',$num);  该函数接受一个字符串作为参数,以及最大字符数量作为第二个参数;

str_random();函数生成指定长度的随机字符串

e 函数对指定字符串进行实体转义,相当于htmlentities;

echo e('<html>foo<html>');

&lt;html&gt;foot;/html&gt

app_path()  返回当前项目的绝对路径 app 目录下的绝度路径

$path = app_path();

base_path() 返回项目的绝对路径

$path= base_path();

config_path() 返回项目的配置文件所在目录

public_path() 返回项目的公共文件所在目录(js,css,img ...)

attempt()  验证信息

url() 生成规则url

action() 配合路由器,生成规范 URl

bcrypt() 加密密码  (用户密码加密可以在创建数据库时进行加密)

config()  读取 配置值

csrf_field()  laravel 防止跨网站请求伪造攻击 用该命令用于验证授权用户和发送请求是否是同一个用户

<form method="post" actisan="/">

{{ csrf_field() }}

...........

</form>

request() 得到当前的request 对象

$req = request();

dd($req);

 

43.表单类型

primary (key)      主键值

string          字符串

enum          选择(‘男’,‘女’)

integer        整形

tinyint         整形(占一个字节)

int                整形(占四个字节)

auto_increment   属性自增

rememberToken()  laravel 中记录用户cookie

 

 

44.在模版中直接打印出错情况

{{print_r($errors)}}

 

45.路由分组

Route::group(

['prefix'=>'auth','namespace'=>'Auth'],

function(){

Route::get();

Route::post();

}

);

 

46.获取登入用户信息

$user = Auth::user();

$user = $request->user();

通过$user 实例化,可以拿到当前登入用户的信息

public function jiePost(Request $req){

$user = $req->user();

 

}

 

47.控制器模版展示view('she',['pro'=>$pro,'att'=>$att]);  已数组的形式进行展示

 

48.页面跳转

redirect('/prolist');

 

49.where 的用法

where('name','like','T%')

whereBetween('votes',[1,100]);    在某值的范围中

whereNotBetween();                      不在某值的范围中

insertGetId   自增ID

intval();                                             将变量转成整形

 

50.中间件

if else 判断的越来越多,会使代码更加难维护,系统间的的偶合性会增加,中间件解决了这个问题

生成中间件

php artisan make:middleware EmailMiddleware

生成的中间件位于

/app/Http/Middleware/EmailMiddleware

 

51.strtoupper()     函数把字符串转化为大写

52.分页功能

DB::table()->paginate(2);

return view('myze',['hks'=>$h]);

 

  • 6
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值