提前声明:
此篇文章只是对laravel5的入门,伴随着敝人的学习laravel5的过程一点一点堆出来的,基本上是对于我们开发项目有用的部分,可以说这些内容全部源自laravel的中文官网。如果想看高级特性,可以看laravel5的官方文档。
准备工作:
打开浏览器,执行http://localhost/laravel/public/index.php,可以看到效果,index.php也就是Laravel的入口文件。
Route::get('/', function() { return 'Hello World'; });请求方式: http://localhost/laravel/public/index.php
②post
Route::post('foo/bar', function() { return 'Hello World'; });
Route::any('foo', function() { return 'Hello World'; });请求方式: http://localhost/laravel/public/index.php/foo
那么路由中带有参数如何处理?比如经常可以看到的index.php?id=22
④带有参数的路由
Route::get('user/{id}', function($id) { return 'User '.$id; });请求方式: http://localhost/laravel/public/index.php/user/22
⑤参数带有默认值路由
Route::get('user/{name?}', function($name = 'John') { return $name; });请求方式: http://localhost/laravel/public/index.php/user/azxuwen 后面的/azxuwen可有可没有,如果没有$name默认为John
⑥带有正则表达式约束的路由
Route::get('user/{name}', function($name) { // }) ->where('name', '[A-Za-z]+');
上面只是一些基本的路由定义方法,当然Laravel对路由的支持不止于此,Laravel提供了对路由的过滤器,在app/filter.php中,下面是一个简单的例子。
在app/filter.php中添加,old过滤器,如果路由参数age如果小于200,则会执行跳转。
Route::filter('old', function() { if (Input::get('age') < 200) { return Redirect::to('home'); } });然后在app/routes.php中使用过滤器old
Route::get('user', array('before' => 'old', function() { return 'You are over 200 years old!'; }));
三、中间件
普通的框架来讲,一个请求过来会首先经过路由,然后由路由分发到controller,这个中间件是laravel提供在路由和控制器中间的一个基础检查工具,在这里可以做一些预先的检查工作,比如用户验证之类的工作。
laravel的中间件应用的也是很简单,在laravel5中,/app/Http/Middleware目录中存放着中间件的类,laravel预先提供了Authenticate等中间件。
下面,我们自己定义中间件OldMiddleware,该中间件做到age如果大于200就执行跳转到首页的功能。
1.打开cmd,进入项目根目录,执行命令。
<span style="font-size:14px;">php artisan make:middleware OldMiddleware</span>如果创建成功,会提示Middleware created successfully.
2.打开IDE,找到OldMiddleware,修改function handle()
public function handle($request, Closure $next) { $age = 201; if ($age > 200) { return redirect('/'); } return $next($request); }
protected $routeMiddleware = [ 'auth' => 'App\Http\Middleware\Authenticate', 'auth.basic' => 'Illuminate\Auth\Middleware\AuthenticateWithBasicAuth', 'guest' => 'App\Http\Middleware\RedirectIfAuthenticated', 'old' => 'App\Http\Middleware\OldMiddleware' ];
Route::get('/user/{id}', ['middleware' => 'old', function(){ return '某用户'; }]);
会发现,浏览器跳转到了首页 http://localhost/laravel/public/index.php
那么能不能将定义的中间件应用到所有路由呢?肯定是可以的,就需要将中间件定义到全局的配置中去,打开Kernel.php,找到静态数组$middleware,添加一个键值即可。
其实laravel中间件的功能还是很多的,这里只是冰山一角。
四、控制器
laravel的控制器可以分为 基础控制器、控制器中间件、隐式控制器、RestFul资源控制器、依赖注入和控制器和路由缓存。下面演示如何使用基础控制器。
1.在routes.php中新建路由,此路由也就是说将交给UserController类下的getUser()来接管
Route::get('user/{id}', 'UserController@getUser');
2.因为laravel的控制器放在app/Http/controllers/下,在此目录下新建类UserController.php,并写入以下代码
<?php namespace App\Http\Controllers; use App\Http\Middleware\OldMiddleware; use Illuminate\Http\Request; use Illuminate\Foundation\Bus\DispatchesJobs; use Illuminate\Routing\Controller as BaseController; use Illuminate\Foundation\Validation\ValidatesRequests; class UserController extends Controller{ public function getUser($id){ echo "Hello " . $id; } }
那么如果没错的话,会看到 Hello 33
看到其中那么多的命名空间,我想一般人都已经疯了,其实我也疯了,慢慢学习慢慢熟悉它们吧。
五、请求
也就是处理客户端浏览器的form表单数据,Laravel使用了Symfony的Request,所以这里需要使用这个东东,下面做一个简单的表单提交功能,比如登录。
1.新建两个路由,一个用于处理表单页面的显示,一个用于处理表单
//登录页表单 Route::get('form', ['uses' => 'UserController@form', 'as' => 'name']); //处理表单登录的action Route::post('signup', 'UserController@signup');
public function form(){ return response()->view('form')->header('Content-Type', 'text/html'); } public function signup(Request $request){ $input = $request->all(); var_dump($input); }
<html> <head> </head> <body> <form method="post" action="{{{ URL::action('UserController@signup') }}}"> <input type="text" name="username" /><br/> <input type="password" name="password" /><br/> <input type="hidden" name="_token" value="{{ csrf_token() }}" /> <input type="submit" value="提交"/> </form> </body> </html>
Note:这里只是一个简单的表单提交页面,Laravel提供的响应机制还有其他功能,比如取得cookie,处理文件上传。
六、响应
说白了也就是返回给用户的结果。
1.由路由直接返回一段字符串,前面说的laravel的路由中一项牛逼的东东是可以直接构造响应数据,下面的路由构造方式是当用户访问出错的时候,直接在页面中打印出“您访问的页面出错”
Route::get('/error', function() { return '您访问的页面出错'; });
请求方式:http://localhost/laravel/public/index.php/error
Route::get('/error', function(){ return View::make('error'); });请求方式: http://localhost/laravel/public/index.php/error 会发现跟上面一样的效果
Route::get('/error', 'UserController@error');
public function error(){ return (new Response('您访问的页面出错', 200)) ->header('Content-Type', 'text/html'); }
use Illuminate\Http\Response;
另外,这里还是可以使用视图文件的方式来响应,而在这只是以简单的字符串的方式返回给了浏览器,那么如何使用视图?
修改上面的error()方法
public function error(){ return response()->view('error')->header('Content-Type', 'text/html'); }并且还是使用上面在 resources/views下建立的error.blade.php文件
请求方式:http://localhost/laravel/public/index.php/error 还是会发现跟上面一样的效果
所以laravel的响应机制真的是非常灵活,还有其他功能,比如
七、视图
之前说过,视图文件放在resources/views文件夹下,也就是一些HTML代码和由控制器分配给视图文件的一些变量,下面来做一个简单的例子。
1.新建一个路由
Route::get('testView', 'UserController@testView');
public function testView(){ $data = array( 'name' => 'Laravel' ); return view('testview', $data); }
Hello <?php echo $name;?> !
所以一个基本的视图使用就OK了,除了这些你可能还有些疑问,那JS、Css文件该如何搞,一般的搞法也就是将这些前端库文件放在resources文件夹内,统一处理前端资源,另外视图还有一个高级特性,就是视图组件,使用视图组件可以在渲染页面之前对需要处理的内容预先处理到模板中,这只是我的浅显理解,需要了解的同学可以到官网查看这部分内容。
八、数据库
暂时不知道laravel操作数据库有多牛逼,可以查看config目录下的database.php文件,这里是数据库的配置文件,laravel支持4种数据库,包括Mysql,Postgres,SQLLite和SqlServer。在database.php中找到connections变量,这里定义了数据库的连接信息,找到Mysql那里,将数据库按照你的实际情况补全,我的是这样的
'mysql' => [ 'driver' => 'mysql', 'host' => 'localhost', 'database' => 'ishare_school', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', 'strict' => false, ],
1.定义路由
Route::get('user/{id}', 'UserController@getUser');
public function getUser($id){ $sql = "select * from user where id = $id"; $results = DB::select($sql); var_dump($results); }
use Illuminate\Support\Facades\DB;
说点稍微高级的
读写分离 :
在database.php中connections那部分,可以将读写分离开来,例如下面的配置,在配置中会发现加了两个键read和write,可以通过配置不同的host来做到读写分离,或主从分离。
'mysql' => [ 'read' => [ 'host' => '192.168.1.1', ], 'write' => [ 'host' => '196.168.1.2' ], 'driver' => 'mysql', 'database' => 'database', 'username' => 'root', 'password' => '', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', 'prefix' => '', ],
事务:
Laravel对于事务的处理上也是很方面和灵活,提供了两种提交事务的方法
DB::transaction(function() { DB::table('users')->update(['votes' => 1]); DB::table('posts')->delete(); });
//开始事务 DB::beginTransaction(); //回滚 DB::rollback(); //提交事务 DB::commit();
查询构造器:
Laravel专门为SQL建立了构造器,说白了也就是定义了SQL的规范,通过一系列的链式操作达到查询的目的,从此再也不需要写sql语句了。
下面来将上面使用纯sql实现的查询进行修改,找到刚刚的getUser()方法,对其进行修改,这种写法同样可以达到刚刚的效果。
public function getUser($id){ $user = DB::table('user')->where(array('id'=> 1))->first(); var_dump($user); }
另外,也支持修改、更新和删除操作。
Note:上面基本的SQL操作完全可以达到基本需求了,如果想用的更爽,Laravel还支持ORM数据绑定、以及数据迁移工作和Redis缓存等的支持,想要了解这些更高级的特性,可以查看Laravel5的官方文档。
laravel的入门,我想上面的已经足够了,当然这里仅仅是一个超级简单的入门教程,如需转载请注明出处,谢谢合作。