0.前言
slim是一个简单而又强大的PHP5框架,可以用来创建RESTful的web应用。可以借助slim框架设计一个简化版的yeelink平台。RESTFul架构对物联网非常重要,通过Slim的学习也加深对RESTFul框架和相关技术的理解。
1.安装wampserver
WampServer是一款由法国人开发的Apache Web服务器、PHP解释器以及MySQL数据库的整合软件包。免去了开发人员将时间花费在繁琐的配置环境过程,从而腾出更多精力去做开发。在windows下将Apache+PHP+Mysql 集成环境,拥有简单的图形和菜单安装和配置环境。PHP扩展、Apache模块,开启/关闭鼠标点点就搞定,再也不用亲自去修改配置文件了,WAMP它会去做。再也不用到处询问php的安装问题了,wampserver一切都搞定了。这个软件是完全免费的,可以在其官方网站下载到最新的版本。【来自百度百科】
安装完成打开apache服务,在浏览器中输入localhost可查看到以下网页。
服务器根目录位于 wampserver安装目录下的www文件夹,例如d:/wamp/www
图1 wamp安装成功
2.apache配置
slim采用了前端控制器模式,利用.htaccess文件中的重写规则,把HTTP请求转给了 index.php。所以还需要启用 mod_rewrite,并修改httpd.conf文件中相应Directory指令的AllowOverride None为AllowOverride All。【来自CSDN博客中的描述】http.conf位于wampserver安装目录\bin\apache\Apache2.4.4\conf
【1】启动mod_rewrite——去掉#,#代表注释
LoadModule rewrite_module modules/mod_rewrite.so
【2】修改AllowOverride None为AllowOverride All
#
# Deny access to the entirety of your server‘s filesystem. You must
# explicitly permit access to web content directories in other
# <Directory> blocks below.
#
<Directory />
AllowOverride All
Require all granted
</Directory>
【3】访问服务器合法IP——任何IP均可以访问服务器。
注释Deny from all,插入Allow from all任何
DocumentRoot "D:/wamp/www"
<Directory "D:/wamp/www">
Options Indexes FollowSymLinks
AllowOverride All
Order Deny,Allow
# Deny from all
Allow from all
</Directory>
【4】重启apache服务
3.slim安装和使用初步
最简单粗暴和直接的方法——到github下载zip文件,slim github【链接】。解压之后把【1】Slim文件夹,【2】.htaccess文件和【3】index.php文件复制到www目录中。若看到以下网页说明slim安装成功。
图2 slim安装成功
4.简单的修改和测试
Slim提供完善的REST框架,支持GET、POST、PUT和Delete等方法,可以把index.php修改的更简单一些。可从以下代码中可以熟悉Slim的基本框架和使用方法。
<?php /** * Step 1: Require the Slim Framework * * If you are not using Composer, you need to require the * Slim Framework and register its PSR-0 autoloader. * * If you are using Composer, you can skip this step. */ require ‘Slim/Slim.php‘; \Slim\Slim::registerAutoloader(); /** * Step 2: Instantiate a Slim application * * This example instantiates a Slim application using * its default settings. However, you will usually configure * your Slim application now by passing an associative array * of setting names and values into the application constructor. */ $app = new \Slim\Slim(); /** * Step 3: Define the Slim application routes * * Here we define several Slim application routes that respond * to appropriate HTTP request methods. In this example, the second * argument for `Slim::get`, `Slim::post`, `Slim::put`, `Slim::patch`, and `Slim::delete` * is an anonymous function. */ // GET route $app->get( ‘/‘, function () { echo ‘Hello Slim‘; } ); // POST route $app->post( ‘/post‘, function () { echo ‘This is a POST route‘; } ); // PUT route $app->put( ‘/put‘, function () { echo ‘This is a PUT route‘; } ); // PATCH route $app->patch(‘/patch‘, function () { echo ‘This is a PATCH route‘; }); // DELETE route $app->delete( ‘/delete‘, function () { echo ‘This is a DELETE route‘; } ); /** * Step 4: Run the Slim application * * This method should be called last. This executes the Slim application * and returns the HTTP response to the HTTP client. */ $app->run(); 此时再打开浏览器输入localhost将只能看到以下内容,其实浏览器使用get方法,在slim的Get路由中输出了Hello Slim。 $app->post( ‘/post‘, function () { echo ‘This is a POST route‘; } );
在slim中, ‘/post‘为相对路径,该路径可支持变量。 function ()为后续的处理函数。其他HTTP方法也类似。
图3 Slim Get路由
其他类型的测试方法可借助cURL工具
【1】测试post
curl --request POST http://localhost/post
【2】测试put方法
curl --request PUT http://localhost/put
【3】测试delete
curl --request DELETE http://localhost/delete
【火狐浏览器】
如果你不喜欢使用curl工具,也可以选择火狐浏览器中的HTTPRequest工具,那么命令操作就成了愉快的GUI操作了。
图4 火狐浏览器中 HTTPRequest工具测试Slim
5.后记
接着借助树莓派做一个类似于yeelink平台的服务器,可以接收来自树莓派的HTTP请求,通过请求和响应实现LED灯的远程控制。
URI设计 \leds\{led}
JSON数据包设计 {“status”:"on"} 或 {“status”:"off"}