简单快速的开发 Web 应用, PHP 框架 Lemon 介绍

喜欢(❤ ω ❤) laravel 但是它太笨重了
想快速简洁的开发小项目,试一试 chanywn 在业余时间写的垃圾框架吧,chanywn 叫它 Lemon 。

Lemon 是一个现代的 PHP 框架,采用 composer 管理组件依赖。

抽根烟,然后由我简单介绍一下如何使用 Lemon

安装

前面已经说过 Lemon 采用 composer 加载。

第一步,使用 composer 安装

mkdir lemon
cd lemon
composer require chanywn/lemon dev-master

第二步,新建 index.php 文件

require 'vendor/autoload.php';

use Lemon\Route;

Route::get('/', function($request, $response){
    return $response->write('Hello lemon');
});

Route::run();

第三步,执行内置服务器

php -S localhost:4000

接下来,打开浏览器,访问 http://localhost:4000

接下来,再由我简单介绍一下 Lemon 的功能

路由

在 Lemon 中的路由是通过匹配的URL模式与回调函数。

Route::get('/', function($request, $response) {
  echo 'index';
});

当然也可以这样表示

Route::get('/', 'hello');

function hello($request, $response){
    echo 'index';
}

请求方式

Route 是路由模块的静态类,您可以通过执行route类的各种静态方法来响应特定方法。

Route::get('/method/1', function($request, $response) {
    echo '我收到了一个 GET 请求';
});

Route::post('/method/2', function($request, $response) {
    echo '我收到了一个 POST 请求';
});

Route::put('/method/3', function($request, $response) {
    echo '我收到了一个 GET 请求';
});

Route::delete('/method/4', function($request, $response) {
    echo '我收到了一个 POST 请求';
});

Route::any('/method/5', function($request, $response) {
    echo sprintf('我收到了一个 %s 请求', $request->method);
});

哈哈,可以愉快的开发 restful api 了。

你可能已经注意到了回调函数中的 $request$response,这两个参数,这两个参数是RequestResponse类的实例,是回调函数的必须参数。这两个参数很有用,之后会介绍。

通配符路由

route::get('/hello/(:any)', function($request, $response, $name) {
    echo 'hello ' . $name;
});

该方法第一个参数是要匹配的路由URL,其中(:any) 通配符用来匹配任意值。在回调函数中我们使用了$name参数来接收这个值。

上面典型的路由匹配的是一个,匹配多个值的时候,回调函数中的参数位置对应匹配的值,参数名自定

route::get('/(:num)/(:num)/(:num)', function($request, $response, $year, $month, $day) {
    echo $year . '/' . $month . '/' . $day;
});

(:num) 匹配只含有数字的一段。 (:any) 匹配含有任意字符的一段。

Request(请求)

得到当前请求的路径、方法、ip

route::get('/', function($request, $response) {
    echo $request->path .'<br>';
    echo $request->method .'<br>';
    echo $request->ip .'<br>';
});

接受get参数
localhost:3000/home?name=razor&age=0

route::get('/home', function($request, $response) {
    var_dump($request->get());
    // or
    echo $request->get('name');
});

接受post参数

route::any('/home', function($request, $response) {
    var_dump($request->post());
    // or
    echo $request->post('name');
});

判断当前请求类型

route::any('/', function($request, $response) {
    if($request->isGET()) {
        echo '当前是 GET 请求';
    }

    if($request->isPost()) {
        echo '当前是 Post 请求'; 
    }
});

Response(响应)

重定向

route::get('/', function($request, $response) {
    return $response->redirect('/home');
});

返回HTTP状态码

route::get('/', function($request, $response) {
    return $response->statusCode(404);
});

渲染视图

route::get('/', function($request, $response) {
    return $response->view('index');
});

或者

route::get('/', function($request, $response) {
    return $response->view('index', ['title' => '首页']);
});

表单验证

<?php
require '../vendor/autoload.php';

use Lemon\Route;
use Lemon\Validation;

route::get('/', function($request, $response) {
    /*
    * 规则数组,键为要验证的字段,值为要验证的规则
    * :姓名 这是别名的写法,可以加也可以不加
    */
    $rules = [
            'name:姓名'     => 'required|min:3|max:9',
            'age:年龄'      => 'required|integer',
            'email:邮箱'    => 'required|email',
    ];
    $validator = new Validation($request->get(), $rules);
    // 判断是否成功验证
    if(!$validator->success) {
        //输出[数组]错误
        debug($validator->errors);
    } 
});

目前支持的规则有以下几点

return [
            'email'     => ':attribute 格式不可用',
            'min'       => ':attribute 长度必须大于或等于 :min',
            'max'       => ':attribute 长度必须小于 :max.',
            'required'  => ':attribute 是必填项',
            'numeric'   => ':attribute 必须为数字',
            'integer'   => ':attribute 必须为整数',
            'alpha'     => ':attribute 必须仅包含字母字符', 
            'alpha_dash'=> ':attribute 必须仅包含字母、数字、破折号',
            'alpha_num' => ':attribute 必须仅包含字母、数字'
        ];

如果你感兴趣,欢迎扩充验证规程,比如httpurl、ip等等

数据库操作

数据库操作类的命名空间在 Lemon\Database; ,Database 基于Pdo实现的数据库链式查询。

配置

Lemon\Database::set([
        'driver'    => 'mysql',
        'host'     => 'localhost',
        'port'     => '3306',
        'username' => 'root',
        'password' => '',
        'database' => '',
        'charset'  => 'utf8'
    ]);

基本使用的例子

<?php

require '../vendor/autoload.php';

use Lemon\Route;
use Lemon\Database;

Route::get('/', function($request, $response){
    $users = Database::table('users')->get();
});

Route::run();

get 方法有一个参数,默认是*,执行成功返回一个数组。

从数据表中获取单个列或行

如果你只需要从数据表中获取一行数据,则可以使用 first 方法。这个方法将返回单个关联数组:

$user = db::table('users')->where('name', 'John')->first();

echo $user['name'];

如果你不需要一整行数据,则可以带上参数来从单条记录中取出单个值。此方法将直接返回字段的值:

$name= db::table('users')->where('name', 'John')->first(‘name’);

echo $name;

find 子句

如果你的某个表主键名正好叫id,你可以这样找到它。

db::table('users')->find($id);

如果它叫其它什么名

db::table('users')->find($id, 'user_id');

orderBy 子句

orderBy 方法允许你根据指定字段对查询结果进行排序。orderBy 方法的第一个参数是你想要用来排序的字段,而第二个参数则控制排序的顺序,可以为 asc 或 desc:

 db::table('users')->orderBy('id')->get();

Where 子句

你可以在查询构造器实例中使用 where 方法从而把 where 子句加入到这个查询中。基本的 where 方法需要3个参数。第一个参数是字段的名称。第二个参数是要对字段进行评估的值。第三个参数是运算符,可选参数默认为=,它可以是数据库所支持的任何运算符。

$users = db::table('users')->where('votes', 100)->get();

$users = db::table('users')->where('votes', 100, '>')->get();

take 子句

你可以使用take 方法来限制查询结果数量,两个参数第一个是起始位置,第二个是取多少条数据:

$users = db::table('users')->take(10, 20)->get();

insert 方法

查询构造器也提供了 insert 方法,用来插入记录到数据表中。insert 方法接收一个包含字段名和值的数组作为参数:

db::table('users')->insert(
    ['email' => 'john@example.com', 'votes' => 0]
);

执行成功返回受影响的行,失败返回false.

自增 ID

(无)

Updates 方法

当然,除了在数据库中插入记录外,你也可以使用 update 来更新已存在的记录。update 方法和 insert 方法一样,接收含有字段及值的数组,其中包括要更新的字段。可以使用 where 子句来约束 update 查找:

db::table('users')->where('id', 1)->update(['votes' => 1]);

自增或自减

(无)

Delete 方法

查询构造器也可使用 delete 方法从数据表中删除记录。在 delete 前,还可使用 where 子句来约束 delete 语法:

db::table('users')->delete();

db::table('users')->where('votes', '>', 100)->delete();

github

https://github.com/chanywn/lemon

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!