zoukankan      html  css  js  c++  java
  • laravel 5.6初学笔记

    laravel 5.6初学笔记

    http://note.youdao.com/noteshare?id=bf4b701b49dd035564e7145ba2d978b4
    框架简介
    * laravel文档齐全 * 社区活跃 * 后期维护好,强大的工具 ---
    下载安装
    • 环境要求,php版本在7以上(要与框架所需一致)
    • 集成环境,建议使用laralgon(适应laravel框架开发)
    • 安装可使用conposer(自行看官方文档),也可在laravel学院下载一键安装包(不用再配置环境和下载安装依赖)
    • 环境配置根目录要指向项目目录中的public
    项目目录
    - app/Http/Controllers [控制器存放的位置,MVC中的C] - bootstrap 包含框架启动和自动加载配置的文件(app.php和autoload.php) - config 包含所有应用程序的配置文件(缓存数据库队列) - database 包含数据库的迁移和数据填充文件 - public 包含入口和项目静态资源文件(js,cs) - resources/view 包含了视图和原始的资源文件 - routes 路由入口文件目录 - storage 包含了编译后的模板文件和缓存文件,日志文件 - tests 单元测试目录文件 - vendor 加载的依赖模块 ---
    路由
    • 概括 将用户的请求转发给相应的程序进行处理,建立程序和url之间的映射。
    • laravel 中的请求方式有:get post put pacth any
      delete
    // 基础路由 get
    // http://localhost/testGet
    Route::get('testGet', function(){
        return 'HELLO WORLD';
    });
    
    // 基础路由 post
    Route::post('testPost', function (){
        return 'Hello Post';
    });
    
    // 多请求路由 match
    // http://localhost/testMatch
    Route::match(['get','post'],'testMatch', function (){
        return 'Hello match';
    });
    
    // 多请求路由 any
    // http://localhost/testAny
    Route::any('testAny', function(){
        return 'Hello any';
    });
    
    // 路由参数
    // http://localhost/testGetUser/12
    /*Route::get('testGetUser/{id}', function ($id){
        return 'testGetUserId='.$id;
    });*/
    
    /*// 路由参数
    // http://localhost/testGetUser/name
    Route::get('testGetUser/{name?}', function ($name = 'NULL'){
        return 'testGetUserName='.$name;
    })->where('name','[A-za-z]+')*/;
    
    // 路由参数
    // http://localhost/testGetUser/1/name
    /*Route::get('testGetUser/{id}/{name?}', function ($id, $name = 'NULL'){
        return 'id='.$id.'testGetUserName='.$name;
    })->where(['id'=>'[0-9]+','name'=>'[A-za-z]+']);*/
    
    // 路由别名[为整个路由取别名]
    // http://localhost/testGetUser/center
    Route::get('testGetUser/center',['as' => 'center', function(){
       return  route('center');
    }]);
    
    // 路由群组
    // http://localhost/member/testAny
    Route::group(['prefix' => 'member'], function (){
        Route::any('testAny', function(){
            return 'Hello member-any';
        });
    });
    
    // 路由中输出视图
    // http://localhost/view
    Route::get('view', function (){
       return view('welcome');
    });
    
    

    一次访问周期 【流程】
    * 入口 public/index.php * 创建服务器容器(用于管理类依赖和执行依赖注入的工具) * 发送请求到http内核和consle内核(分别用来处理web请求和 Artisan命令) * 内核启动载入服务提供者,注册提供者,服务提供者启动lavavel框架中的各种重要组件(例如,数据库,路由,队列,验证器)【最为重要的部分】。 * 请求教友路由器进行分发,并运行路由器制定的中间件。
    服务器容器
    * 概括:用于管理依赖和执行依赖注入的工具 * 绑定:几乎所有的服务器容器都在服务提供者中完成的
    门面
    * 概括:门面就是为容器对象提供一个访问方式的类
    中间件
    * 概括:中间件为过滤进入应用的HTTP请求提供了一套便利的机制。 * 用法:
    一,类似于tp框架中的Behavior,或钩子的用法。用于请求的前期验证或后期验证处理。
    二,CORS 中间件可以用于,请求方法增加请求头。
    三,日志中间件可以记录所有进入站点的请求。
    * 中间件组:更为快捷的实现一次分配给路由多个中间件组;指定一个中间键名将相关中间件放到一个组里。 * 中间件参数,中间件可以传递额外的自定义参数。 * 终端中间件,用于请求完成之后的善后操作。
    CSRF保护
    * 概括:跨站请求伪造,通过伪装成授权用户去访问攻击网站的恶意漏洞。 * lavavel自带CSRF中间件,会自动为应用授权保护的有效用户会话创建一个CSRF令牌,并存在session中,用于验证授权用户和访问用户是否是同一个人。
    控制器[MVC中的C]
    • 路由指向控制器[同理:其它请求方式做相应更改]
    // http://localhost/testController
    Route::get('testController', 'TestController@testController');
    
    • 路由取别名[可以通过route('testInfo'),获取路由地址]
    Route::get('testController',[
        'uses' => 'TestController@testController',
        'as' => 'testInfo',
    ]);
    
    • 参数绑定
    // [路由文件]http://localhost/testController/1
    Route::get('testController/{id}',['uses' => 'TestController@testController']);
    
    <?php
    /**
     * Created by PhpStorm.
     * User: admin
     * Date: 2018/6/5
     * Time: 15:45
     */
    namespace  AppHttpControllers;
    
    class  TestController extends  Controller
    {
        // [控制器文件] TEST
        public function testController ($id)
        {
            return 'id-'.$id;
    //        return route('testInfo');
    //        phpinfo();
        }
    }
    

    // 参数验证

    // http://localhost/testController/1
    Route::get('testController/{id}',['uses' => 'TestController@testController'])
    ->where('id', '[0-9]');
    
    视图
    • 位置,resources/views
    • 创建新视图时,按控制器名创建新文件夹
    // 新建视图文件testview.php,输出testview php
    // 控制器输出 return view('testview');
    
    
    • 模板传参
    // controller文件
    public function testController ($id)
        {
            return view('test/test',[
                'id' => $id
            ]);
        }
    
    • 视图文件显示
    test/test blade
    {{$id}}
    
    模型
    • 位置 app根目录
    • 模型文件
    <?php
    /**
     * Created by PhpStorm.
     * User: admin
     * Date: 2018/6/5
     * Time: 17:37
     */
    namespace App;
    use IlluminateDatabaseEloquentModel;
    
    class Test extends Model
    {
        public static function getTestInfo () {
            return 'THIS IS A GOOD IDEA';
        }
    }
    
    • controller 文件
      public function testController ($id)
        {
            return Test::getTestInfo();
        }
    
    数据连接
    • 文件位置 config/database.php vendor/.env
    • 链接数据库
    // 路由
    Route::get('getUserInfo', ['uses' => 'userController@getUserInfo']);
    
    <?php
    namespace AppHttpControllers;
    use IlluminateSupportFacadesDB;
    
    class userController extends  Controller {
        public function getUserInfo ()
        {
            // 返回的bool值
            $res['res'] = DB::insert('insert into user(name,age) values(?,?)', ['name2',18]);
            // 返回影响行数
            $res['changeRes'] = DB::update('update user set age = ? where id = ?', [17,1]);
            $res['userData'] = DB::select('select * from user');
            // 返回删除的行数
            <!--$res['userData'] = DB::delete('delete from user where id = ?', [5]);-->
            <!--return $res;-->
            // 格式化
            dd($res);
        }
    }
    
    
    // 输出显示
    array:1 [▼
      "userData" => array:4 [▼
        0 => {#202 ▼
          +"id": 1
          +"name": "maomao"
          +"age": 17
        }
        1 => {#204 ▼
          +"id": 2
          +"name": "xinxin"
          +"age": 18
        }
        2 => {#205 ▼
          +"id": 3
          +"name": "name"
          +"age": 18
        }
        3 => {#206 ▼
          +"id": 4
          +"name": "name2"
          +"age": 18
        }
      ]
    ]
    
    查询构造器
     // 查询构造器  新增
        public function queryBuilder()
        {
            // 返回的bool值
            $res['bool'] = DB::table('user')->insert(
                ['name' => 'queryBuilder', 'age' => 19],
                ['name' => 'queryBuilder2', 'age' => 19]
            );
            // 获取
            $res['id'] = DB::table('user')->insertGetId(
                ['name' => 'queryBuilder', 'age' => 19]
            );
            var_dump($res);
        }
    
        // 查询构造器 更新
        public function queryBuilder2()
        {
            // 返回的影响行数
            $res['num'] = DB::table('user')
                ->where('id', 1)
                ->update(
                ['name' => 'queryBuilderMao', 'age' => 19]
            );
            // 更新自增
            $res['incrementNum'] = DB::table('user')
                ->where('id', 1)
                ->increment('age',1);
            // 更新自减
            $res['decrementNum'] = DB::table('user')
                ->where('id', 1)
                ->decrement('age',1);
            // 更新自增自减时修改其它条件信息
            $res['decrementNum'] = DB::table('user')
                ->where('id', 1)
                ->decrement('age',1,['name' => 'lala']);
            var_dump($res);
        }
    
        // 查询构造器 删除
        public function queryBuilder3()
        {
            // 返回的影响行数
            $res['deleteNum'] = DB::table('user')
                ->where('id', 6)
                ->delete();
            // 区间条件删除
            $res['deleteNum2'] = DB::table('user')
                ->where('id','>=', 5)
                ->get();
            // 清除表信息
            $res['truncateNum'] = DB::table('user')
                ->truncate();
            var_dump($res);
        }
    
        // 查询构造器 查询
        public function queryBuilder4()
        {
            // 第一条
            $res['frist'] = DB::table('user')
                ->orderBy('id', 'desc')
                ->frist();
            // 全部
            $res['user'] = DB::table('user')
                ->get();
            // 清除表信息
            $res['truncateNum'] = DB::table('user')
                ->truncate();
            var_dump($res);
        }
    
    ORM
    • 简介据说时一个优美的activeRecord实现,用来实现数据库的操作
    • 每个数据表对应一个model,用来和数据表的数据交互
    <?php
    namespace AppHttpControllers;
    
    use AppStudent;
    
    class StudentController extends  Controller
    {
        public  function orm()
        {
            // 查询 all()
            $student = Student::all();
            dd($student);
    
            // find() 一条
            $findData = Student::find(2);
            dd($findData);
    
            // findOrFail() 根据逐渐查找,没有则抛出异常
            $findData = Student::findOrFa (3);
            dd($findData);
    
            // 查询第一条
            $findData = Student::where('id','>', '1')
                        ->orderBy('id', 'desc')
                        ->first();
            dd($findData);
    
            // 分组
            echo '<pre>';
            Student::chunk(1,function ($students)
            {
             var_dump($students);
            });
    
            // 聚合函数(count, max, min, avg)
            $num = Student::count();
        }
    
        // 使用模型新增数据
        public function orm1()
        {
            // student模型对象
            $student = new Student();
            $student ->name = 'name133';
            $student ->age = 12;
            $bool = $student->save();
            dd($bool);
    
            $student = Student::find(5);
            echo date('Y-m-d H:i:s', $student->created_at);
    
            // 使用模型的Create方法新增数据
            $addRes = Student::create(
                ['name'=>'llll','age'=>12]
            );
    
            // 使用模型的firstOrCreate方法新增数据
            $addRes = Student::firstOrCreate(
                ['name'=>'lll','age'=>12]
            );
    
            // 使用模型的firstOrNew方法新增数据,通过属性查询用户没有则建立新的实例
            $student = Student::firstOrNew(
                ['name'=>'ll','age'=>12]
            );
            // 需要保存则自行调用save
            $addRes = $student->save();
            dd($addRes);
        }
    
        // 更新
        public function orm2()
        {
            // 返回更新行数
            $num = Student::where('id','>',2)
                    ->update(['name'=> 'sb']);
            var_dump($num);
        }
    
        // 删除
        public function orm3() {
            $students = Student::find(1);
            $bool = $students->delete();
    
            // 通过主键删除
            $num = Student::destroy(1);
    
            $num2 = Student::where('id', '<',12)
                            ->delete();
    
        }
    }
    
  • 相关阅读:
    Centos7上安装docker
    另类SQL拼接方法
    多平台Client TCP通讯组件
    Redis协议详解
    .net下简单快捷的数值高低位切换
    beetle 2.7海量消息广播测试
    FileSync文件同步更新工具
    简单实现TCP下的大文件高效传输
    感知机原理小结
    日志和告警数据挖掘经验谈
  • 原文地址:https://www.cnblogs.com/maomojun/p/9141121.html
Copyright © 2011-2022 走看看