Thinkphp5.0极速搭建restful风格接口层

下面是基于ThinkPHP V5.0 RC4框架,以restful风格完成的新闻查询(get)、新闻增加(post)、新闻修改(put)、新闻删除(delete)等server接口层。

1、下载ThinkPHP V5.0 RC4版本;

2、配置虚拟域名(非必须,只是为了方便);

Apache\\conf\\extra\\httpd-vhosts.conf

3、开启伪静态支持.htaccess文件

apache方法:

a)在conf目录下httpd.conf中找到下面这行并去掉#

LoadModule rewrite_module modules/mod_rewrite.so

b)将所有AllowOverride None改成AllowOverride All

public\\.htaccess文件内容:

4、创建测试数据

tprestful.sql

5、修改数据库配置文件

application\\database.php

6、定义restful风格的路由规则,

application\\route.php

7、新建模型

application\\index\\model\\News.php

8、新建控制器

application\\index\\controller\\News.php

9、测试

a)、访问入口文件,默认在public\\index.php

b)、客户端测试restful的get、post、put、delete方法

client\\client.php

请求工具类

client\\ApiClient.php

完整代码从我github下载:

https://github.com/phper-hard/tp5-restful

PHP Laravel定时任务Schedule

前提:本文方法是利用Linux的crontab定时任务来协助实现Laravel调度(Mac也一样)。

一、首先添加Crontab定时任务,这里只做简单介绍:

用命令crontab -e 添加如下内容

如图:

上面命令Crontab会每分钟去调Laravel的schedule命令,然后Laravel判断执行任务。

注意:要注意php和artisan的目录,which php可以查看php目录

另外上面的命令前面的5个*分别代表分钟、小时、天、月、星期。

  • 分钟:0-59的整数,默认*和*/1 代表1分钟。
  • 小时:0-23的整数。
  • 天:1-31的整数。
  • 月:1-12的整数。
  • 星期:0-7的整数,0和7都代表星期日。
  • crontab -l 可以列出当前的定时任务。

二、添加Laravel调度任务:

1、在App\\Console\\Kernel类中定义你的调度任务:

上面举例了两种实现方法,方法一是用闭包,方法二是用Artisan命令实现的。

调度的时间可以有多种:

下面继续方法二的操作:

三、定义Artisan命令的方法:

好了,以上就可以执行定时任务了,有个小技巧如果上面的任务没执行可以用命令php artisan list 可以打印出一些错误信息。

一个简单的部门案例详解(PHP代码实例)

本文为php中文网认证作者:“易达”投稿,欢迎加入php中文网有偿投稿计划!

案例:

要求:

其中必须要使用的知识点:

1. 类的定义

2. 类的实例化

3. 对象的引用赋值=&

4. 析构函数

5. 构造函数

这个案例要实现的效果其实算很简单,但是重点是,你的思路很清楚吗?你的思路是否具备一定的条理性,或者说做了许多项目,你有没有总结出一套你自己的系统性的思路方案呢?我的总结如下:

3个分析:

1、流程分析

2、具体的实现分析

3、 数据库分析

3个执行:

1.创建数据库,初始化数据库数据( 项目的启动数据 )

2.创建类,实现类

3.写流程

接下来我们一个一个的分析

1、流程分析

1、获取所有部门信息

2、获取单个部门信息

3、写一个对象引用赋值=&的测试

例如$jordon1=&$jordon

4、在所有逻辑最后写一句话:应用程序到此为止

5、执行了一个类的析构函数

2、具体的实现分析

1、第一步:识别对象(找名词)

根据上面的流程我们得出的对象只有一个:

1.部门

2、第二步:识别对象的属性( 数据名词+结合现实世界去分析+结合具体的场景 )

1.部门:属性有:id,名称

3、第三步:识别对象的方法( 动词+结合现实世界去分析+结合具体的场景 )

1.部门 方法有

1.获取所有部门信息

2.获取单个部门信息

因为所有的数据都要保存到数据库,所有的数据都要从数据库获取,所以接下来

数据库分析:

表:(有多少个对象 至少就有多少个表)

1.部门 字段 = 对象的属性

分析完成后,我们接下来做具体的操作

1、创建数据库,初始化数据库数据( 项目的启动数据 )

创建数据库,名字我们就叫做depart

为数据库创建表,表明就做叫部门表

分析是否有初始化数据,(我们可以称之为项目的启动数据,没有这些数据,项目无法启动,)然后将这些初始化数据写入数据库

综上分析,初始化数据就是3个部门

所以接下来我们初始化数据库

2.创建类,实现类

创建部门类:

为了方便管理,我们把所有的类放到model文件夹中,然后这个类文件我们就叫做Depart.class.php,然后我们把上面分析得出来的类的属性和方法,写入部门类中

model/Depart.class.php

<?php

//部门类

class Depart{

//定义属性 id,名称

public $id = \”\”;

public $name = \”\”;

public $conn = \”\”;//数据库连接

public $tableName = \”depart\”;//表名

//构造函数

public function __construct( $id,$name ){

//初始化属性

$this->id = $id;

$this->name = $name;

//初始化行为 初始化方法

$this->initConn();

}

//析构函数 销毁数据库连接

public function __destruct(){

//销毁连接

if( $this->conn ){

mysqli_close( $this->conn );

echo \”销毁了连接<br/>\”;

}

}

//定义方法

//创建公共的方法 获取数据库连接

public function initConn(){

$config = Array(

\”hostname\”=>\”127.0.0.1\”,

\”database\”=>\”depart\”,

\”username\”=>\”root\”,

\”password\”=>\”root\”

);

$this->conn = mysqli_connect( $config[\’hostname\’],$config[\’username\’] ,$config[\’password\’],

$config[\’database\’]);

}

// 1.获取所有部门信息

public function getAll(){

//创建数据库连接

$conn = $this->conn;

//写sql

$sql = \” select * from \”.$this->tableName;

//执行sql

$result = mysqli_query( $conn,$sql );

//获取数据

// mysqli_fetch_all($result)//特点:不会包含字段名

$list = Array();

while( $row = mysqli_fetch_assoc( $result ) ){

$list[] = $row;

}

//返回数据

return $list;

}

// 2.获取单个部门信息

public function getOne( $id ){

//创建数据库连接

$conn = $this->conn;

//写sql

$sql = \” select * from \”.$this->tableName.\” where id= \”.$id;

//执行sql

$result = mysqli_query( $conn,$sql );

//获取数据

// mysqli_fetch_all($result)//特点:不会包含字段名

$list = Array();

while( $row = mysqli_fetch_assoc( $result ) ){

$list[] = $row;

}

//返回数据

return $list;

}

}

?>

3.写流程

接下来,我们根据流程分析的结果来写具体的流程,流程代码如下:

<?php

//引入类文件

require_once \”model/Depart.class.php\”;

//写流程

// 1.获取所有部门信息

//

$humanResourseDepartment = new Depart(2,\”行政部门\”);

//通过对象调用方法

$alllist = $humanResourseDepartment->getAll();

echo \”<b>所有部门信息为:</b><br/>\”;

print_r( $alllist );

echo \”<br/>\”;

// 2.获取单个部门信息 = 开发部门

$devDepartment = $humanResourseDepartment ->getOne( 1 );

echo \”<b>开发部门信息:</b> <br/>\”;

print_r( $devDepartment );

echo \”<br/>\”;

// 3.对象引用赋值=&的测试

// $jordon1=&$jordon

$humanResourseDepartment1 =& $humanResourseDepartment;

echo \”修改前:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;

//修改

$humanResourseDepartment1->name = \”人力部门\”;

echo \”修改后:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;

// 4.在所有逻辑最后写一句话:应用程序到此为止

echo \”<b>应用程序到此为止</b> <br/>\”;

// 5.执行了一个类的析构函数

?>

运行结果如下:

所有部门信息为:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) [1] => Array ( [id] => 2 [name] => 行政部门 ) [2] => Array ( [id] => 3 [name] => 后勤部门 ) )开发部门信息:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) )修改前:行政部门的名字为:行政部门修改后:行政部门的名字为:人力部门应用程序到此为止销毁了连接

本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com

点赞 0
收藏 0

文章为作者独立观点不代本网立场,未经允许不得转载。