1. 目前我用的laravel 5.2.36版本web中间件成为全局中间件(不知道从5.2.26以上就改变了还是怎样,没有深究),也就是之前的版本路由里默认会有一个Route::group的web中间件组,然后看上面有段注释大致意思就是加入web中间价组受到csrf保护?那目前我用的5.2.36这个版本取消了下面的默认的web中间件组,即便把整个项目都添加到web中间件里。看起来还是挺方便,所以添加中间件组的时候不用在次定义一便web中间件组。例子:
1 Route::group([‘middleware‘=>[‘admin.login‘],‘prefix‘=>‘admin‘,‘namespace‘=>‘Admin‘],function(){ 2 Route::get(‘index‘,‘[email protected]‘); 3 Route::get(‘info‘,‘[email protected]‘); 4 Route::get(‘quit‘,‘[email protected]‘); 5 Route::any(‘pass‘,‘[email protected]‘); 6 Route::resource(‘category‘,‘CategoryController‘); 7 Route::post(‘cate/changeorder‘,‘[email protected]‘); 8 });
‘middleware‘=>[‘admin.login‘] 这个中间件里面就不用在添加web中间件。之前的版本都要这样写:‘middleware‘=>[‘web’,‘admin.login‘],所以还是比较方便。//自己添加中间件的时候不要忘了在routes.php同级目录下的Kernel.php
2. 还有就是csrf验证,通俗点说就是防跨站攻击、大致意思 就是 每一个表单都会发送一个token,token就是一大串字符串。我是这样理解csrf的 [ 比如说你要登陆一个网站的后台,然后表单都会附带一个随机的token值发送给后台来验证是否有效。然后才允许你登陆进去] 那么如何添加token呢? 平常的前端html文件在laravel 使用的是blade模版引擎。然后随便说下。laravel前端的文件存在在哪、resources/views 这目录下 然后里面的html文件,改为blade模版引擎的话,要修改后缀为 index.blade.php 然后在路由里分配一个视图就可以看到了、或者在分配一个控制器。在控制器里面分配视图也都是可行的。我觉得blade模版在laravel中还是非常方便不得不感叹框架原来如此方便,哈哈 [ 我也是第一次学框架,TP也挺火的。然后我没有学TP就直接学了laravel] 、扯远了。然后先把csrf 验证如何给做到再说其他的、比如说这个index.blade.php 前端文件下有一个后台登陆的表单,你可以在表单里面添加{{csrf_field()}} 即可,文档上{!!csrf_field()!!}这样也可以、还有其他的直接添加input的我就不说了,自行看文档。官方文档才是学习最重要的、我这里只是帮助大家还有自己记忆一下、
忘了说一点就是使用表单的时候路由尽量使用 Route::any(‘‘,‘‘) 不然有些get方法或者post传不过去 会报错的、
3. 顺便说下blade模版引擎吧,blade注释方法上面也看到了{{--我是注释哦--}},然后下面那个 {{url(‘admin/code‘)}}这个是引用了一个验证码类、就是别人封装好的验证码,拿过来直接用 [拒绝偷懒从大家做起],然后这个就是 blade模版引擎的url引用方式。
还有一点就是。我这个版本的laravel里面的引用的js css 、img等这些文件如果你要用 blade模版引擎里 asset 的话就是
{{asset(‘style/index.css‘)}} 这些链接都会被laravel 指引到public入口文件下面。意思就是说你要用到asset引用的css js img等等文件都要放到public目录下,然后5.2.2X的版本的话可以直接放在你想要的目录都可以的。别人说是入口文件的问题,也可以修改。具体没有深究。等把laravel基本知识点学完了在深究它、
再说一个blade模版引擎用共同文件的方法,( 头部和底部 ),比如说你的头部和底部是同样的,那么在blade使用方法:
打个比方你的前端的目录都在views下。只需要你把相同的文件保存在一个文件里面并放到同级目录下。比如说你这文件保存为admin.blade.php. 然后里面不一样的内容添加 @yield(‘content‘); 看图:
然后在其他文件需要用到的文件中 这样写:
1 @extend(‘admin‘){{--你保存相同的那个文件后缀.balde.php不用填写--}} 2 @section(‘content‘){{--之前定义的不相同的文件变量名--}} 3 4 5 <div>这里是html不同的</div> 6 <p></p> 7 <script></script> 8 9 10 @endsection
如果你保存的相同文件下存在一个目录里:你要这样写@extend(‘ever.admin‘) //注意不能使用 /
可见blade还是挺有讲究的 每小段代码也都有@endif 类似的结束语句。 blade还可以使用 @if @else{} @endif ;这样的类似。还可以使用@foreach 遍历 三元运算符 等等等 ——具体点我去文档更详细的介绍
4. 说下连接数据库吧,laravel 连接数据库先去修改 .env 文件
DB_PREFIX=blog_这个是表前缀、如果想要在.env里使用的话。要到config/database.php下 找到
‘mysql‘=[
//一些mysql信息
‘prefix‘ => ‘‘ //修改为:‘prefix‘ =>env(‘DB_PREFIX‘,‘‘) 即可
]
先用路由随便分配一个控制器在里面操作演示:
1 Route::get(‘admin/test‘,‘[email protected]‘);
然后在用 php artisan make:controller IndexController创建控制器即可。
添加一下内容。
public function index(){ $PDO = DB::connection()->getPdo(); dd($PDO);//这个dd()和print_r();效果一样 }
然后进入admin/test 会打印一些PDO这个对象..等等一些信息. 即表示连接成功。报错的话,
如果你使用的编辑器不是phpstrom 的话。你的命名空间可能不会自动加载进来。也就是上方的
use Illuminate\Support\Facades\DB (这个很容易遗漏,phpstrom编辑器里打出 DB 代码提示出直接回车会自动帮你加载 而且之后获取的要使用的Input 类似这写的等等都要添加。所以使用phpstrom开发还是很方便,不过wim10下phpstrom 输入法不跟随光标日了狗了,一直在右下角呆着..看起来真难受)
如果还是报错的话。看看.env文件修改了没。
连表操作:
1 public function index(){ 2 $table = DB::table(‘user‘)->get(); 3 dd($table); 4 }
1 public function index(){ 2 $table = DB::table(‘user‘)->where(‘user_id‘,1)->get();//table(‘表名‘),如果你配置表前缀后不需要添加前缀。添加条件 我只要字段user_id 为1的数据 3 dd($table); 4 }
还有就是使用 Eloquent ORM 控制数据库,也挺方便的:
laravel默认的Model/User.php 可以控制和修改数据库的表名等等。不然laravel的外国佬会给你添油加醋的给你后缀加上 s 啊。等等... 所以在模型里可以自行定义:
class User extends Model { protected $table = ‘user‘;//设置表名 protected $primaryKey = ‘user_id‘;//设置主键 public $timestamps = False;//禁用默认时间戳,防止执行updata()等更新操作报错 }
然后在控制器里面使用 User:: 来控制数据库就可以了。别忘了有没有自动引入加载命名空间。
public function index(){
$table = User::find(1);$table->user_name=‘秋田嘉‘;$table->update(); dd($table); }
还有更多关于 Eloquent ORM操作查看文档吧。我只是一个文档搬运工、就是多了点自己的黑白色彩