简易 PHP API 测试

PHP代码

/*

======================================================================================

Author : James

Date : 2020/3/21

Versions: Beta v2

HEPL :

HTTP POST :

1.{ "select": "mock_data", "where": [{ "id": "1" },{ "username": "james" }], "limit": [1, 2] };

2.{ "insert": "mock_data", "values": [{ "username": "james" }, { "email": "james@domain.com" }] };

3.{ "update": "mock_data", "set": [{ "username": "james" }, { "email": "james@domain.com" }], "where": [{ "id": "1" }] };

4.{ "delete": "mock_data", "where": [{ "id": "1" }] }

5.{ "query": "mock_data", "where": [{ "username": "james" }], "page": [1,10] }; page参数[当前页,页大小]

======================================================================================

*/

header("Content-type: application/json");

header("Content-type:text/html;charset=utf-8");

header("Access-Control-Allow-Origin:*");

//初始化参数

define("HOST", "localhost");

define("DBNAME", "test");

define("USER", "root");

define("PASSWORD", "");

define("ACCESSPERMISSION", json_encode(array('query', 'select', 'update', 'insert', 'delete')));

define("PAGESIZE", 10);

global $MySQL;

if (count($_POST) < 1) {

render(null, array("Error" => "Not POST Param"));

}

$GLOBALS["MySQL"] = new PDO("mysql:host=" . HOST . ";dbname=" . DBNAME . ";charset=utf8", USER, PASSWORD, array(PDO::ATTR_PERSISTENT => true));

$SQL_TYPE = strtolower(array_keys($_POST)[0]);

if (in_array($SQL_TYPE, json_decode(ACCESSPERMISSION)) && !empty($_POST[$SQL_TYPE])) {

if (!isTable($_POST[$SQL_TYPE])) {

render(null, array("Error" => "Not Exist Table " . $_POST[$SQL_TYPE]));

}

$POST = $_POST;

unset($POST[$SQL_TYPE]);

call_user_func($SQL_TYPE, $_POST[$SQL_TYPE], $POST);

} else {

render(null, array("Error" => "POST Param " . $SQL_TYPE));

}

//拼凑 WHERE 语句

function where($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = ' WHERE ';

foreach ($SQL as $item) {

foreach ($item as $key => $val) {

$sql .= sprintf("%s='%s' and ", $key, $val);

}

}

return substr($sql, 0, -4);

}

//拼凑 VALUES 语句

function values($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = '';

$k = '';

$v = '';

foreach ($SQL as $item) {

foreach ($item as $key => $val) {

$k .= sprintf("%s,", $key);

$v .= sprintf("'%s',", $val);

}

}

$sql .= sprintf("(%s)VALUES(%s)", substr($k, 0, -1), substr($v, 0, -1));

return $sql;

}

//拼凑 SET 语句

function set($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = ' SET ';

foreach ($SQL as $item) {

foreach ($item as $key => $val) {

$sql .= sprintf("%s='%s',", $key, $val);

}

}

return substr($sql, 0, -1);

}

//拼凑 ORDER BY 语句

function orderby($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = ' ORDER BY ';

foreach ($SQL as $item) {

foreach ($item as $key => $val) {

$sql .= $key . " " . $val . ",";

}

}

return substr($sql, 0, -1);

}

//拼凑 LIMIT 语句

function limit($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = ' LIMIT ';

foreach ($SQL as $item) {

$sql .= $item . ",";

}

return substr($sql, 0, -1);

}

//拼凑 PAGE 语句

function page($SQL)

{

if (count($SQL) < 1) {

return "";

}

$sql = ' LIMIT ';

foreach ($SQL as $item) {

$sql .= $item . ",";

}

return substr($sql, 0, -1);

}

//装配SQL的条件语句

function AssembleSQL($SQL)

{

//die(var_dump($SQL));

if (isset($SQL) && !empty($SQL)) {

$sql = "";

foreach ($SQL as $key => $value) {

$sql .= call_user_func(strtolower($key), $value);

}

return $sql;

}

}

//执行分页数据库

function query($TABLE, $SQL)

{

$pageNumber = 1;

$pageSize = PAGESIZE;

$totalPage = 1;

$totalRow = 1;

$start = 0;

if (!empty($SQL) && count($SQL['page']) > 0) {

if (count($SQL['page']) == 1) {

$pageNumber = $SQL['page'][0] < 1 ? 1 : $SQL['page'][0];

}

if (count($SQL['page']) == 2) {

$pageNumber = $SQL['page'][0] < 1 ? 1 : $SQL['page'][0];

$pageSize = $SQL['page'][1] < 1 ? 10 : $SQL['page'][1];

}

$start = ($pageNumber - 1) * $pageSize;

}

$SQL['page'] = array($start, $pageSize);

$sql = sprintf("SELECT * FROM %s %s", $TABLE, AssembleSQL($SQL));

$sql_count = substr($sql, 0, strpos($sql, "LIMIT"));

$sql_count = str_replace("*", "count(*)", $sql_count);

$dbcount = $GLOBALS["MySQL"]->query($sql_count);

$totalRow = $dbcount->fetchColumn();

$db = $GLOBALS["MySQL"]->query($sql);

$reslut = $db->fetchAll(PDO::FETCH_ASSOC);

$totalPage = ceil($totalRow / $pageSize);

$page = array("list" => $reslut, "pageNumber" => intval($pageNumber), "pageSize" => $pageSize, "totalPage" => $totalPage, "totalRow" => intval($totalRow));

render($page);

}

//执行查询数据库

function select($TABLE, $SQL)

{

$sql = sprintf("SELECT * FROM %s %s", $TABLE, AssembleSQL($SQL));

$db = $GLOBALS["MySQL"]->query($sql);

$reslut = $db->fetchAll(PDO::FETCH_ASSOC);

render($reslut);

}

//执行插入数据库

function insert($TABLE, $SQL)

{

$sql = sprintf("INSERT INTO %s %s", $TABLE, AssembleSQL($SQL));

$reslut = $GLOBALS["MySQL"]->exec($sql);

render($reslut);

}

//执行更新数据库

function update($TABLE, $SQL)

{

$sql = sprintf("UPDATE %s %s", $TABLE, AssembleSQL($SQL));

$reslut = $GLOBALS["MySQL"]->exec($sql);

render($reslut);

}

//执行删除数据库

function delete($TABLE, $SQL)

{

$sql = sprintf("DELETE FROM %s %s", $TABLE, AssembleSQL($SQL));

$reslut = $GLOBALS["MySQL"]->exec($sql);

render($reslut);

}

//视图

function render($reslut, $msg = null)

{

$GLOBALS["MySQL"] = null;

if (empty($msg)) {

die(json_encode($reslut));

} else {

die(json_encode($msg));

}

}

//判断表是否存在

function isTable($table)

{

$result = $GLOBALS["MySQL"]->query("SHOW TABLES LIKE '" . $table . "'")->fetchAll(PDO::FETCH_GROUP);

if ($result) {

return true;

} else {

return false;

}

}

HTTP代码

Test

Test Ajax POST Request


GET select


GET delete


GET update


GET insert


GET query

$(function () {

$("#but5").on("click", function () {

let URL = "http://127.0.0.1/index.php";

let param = { "query": "mock_data", "page": [1] };

$.post(URL, param, function (data) {

$("span").html(data);

})

})

$("#but4").on("click", function () {

let URL = "http://127.0.0.1/index.php";

let param = { "insert": "mock_data", "values": [{ "username": "james" }, { "email": "james@domain.com" }] };

$.post(URL, param, function (data) {

$("span").html(data);

})

})

$("#but3").on("click", function () {

let URL = "http://127.0.0.1/index.php";

let param = { "update": "mock_data", "set": [{ "username": "james" }, { "email": "james@domain.com" }], "where": [{ "id": "1" }] };

$.post(URL, param, function (data) {

$("span").html(data);

})

})

$("#but2").on("click", function () {

let URL = "http://127.0.0.1/index.php";

let param = { "delete": "mock_data", "where": [{ "id": "1" }] };

$.post(URL, param, function (data) {

$("span").html(data);

})

})

$("#but1").on("click", function () {

let URL = "http://127.0.0.1/index.php";

let param = { "select": "mock_data", "where": [{ "id": "2" }], "limit": [0, 1] };

$.post(URL, param, function (data) {

$("span").html(data);

})

})

})

接口测试php代码,简易 PHP API 测试相关推荐

  1. 新课推荐 | 用 Django 快速搭建 API 测试工具

    API,即:应用编程接口(Application Programming Interface),就是软件系统不同组成部分衔接的约定. 由于近年来软件的规模日益庞大,常常需要把复杂的系统划分成小的组成部 ...

  2. 新手入门API测试必要了解的知识

    什么是API?API是Application Programming Interface的简写.实现了两个或多个独立系统或模块间的通信和数据交换能力. 什么是API测试?API测试是不同于UI级自动化 ...

  3. API测试工具SoapUI Postman对比分析

    版权声明:本文为博主原创文章,未经博主允许不得转载.    https://blog.csdn.net/powertoolsteam/article/details/83012359 本文由葡萄城技术 ...

  4. API测试| 了解API接口测试| API接口测试指南

    什么是API? API是一个缩写,它代表了一个 pplication P AGC软件覆盖整个房间.API是用于构建软件应用程序的一组例程,协议和工具.API指定一个软件程序应如何与其他软件程序进行交互 ...

  5. API测试-接口测试基础(1)

    由于自己想学习API方面的测试,但是市面上搜不到相关的图书可以系统学习,网上的内容又零零散散,适合有点API开发基础的人去搜索.为了方面新手学习API测试,现在整理了他人的宝贵经验和自己的学习心得,尽 ...

  6. stm32c8t6的can通信实验代码_TCP的连接建立与关闭状态及数据传输通信过程【含有 PHP socket API 测试实验代码】...

    php中文网最新课程 每日17点准时技术干货分享 本文章使用 PHP 代码来测试 TCP 传输层的一个通信过程.TCP/IP 协议关于该协议的详细内容可自行查阅 <>PHP 的 tcp/u ...

  7. java api 测试工具_Java 实现在线HTTP接口测试 - HTTP GET/POST模拟请求测试工具

    本站工具,在线HTTP接口测试 - HTTP GET/POST模拟请求测试工具后台所有实现代码.支持的请求协议有:Post.GetDelete.Put.Trace.Head.Options.特色是加了 ...

  8. 一个标准的REST API测试代码

    代码及过程都非常标准;以后可能会很少做Rest API测试了,权且作为纪念 @Test(author="elbert.chenh", description="测试用例描 ...

  9. android服务器接口测试,使用Retrofit和Mockito进行可靠的Android API测试

    测试与API交互的HTTP调用是一件令人生厌的复杂事情.测试一个真实的Web服务器时,一大堆问题随之产生:脆性测试(brittle test,因为网络或API本身的问题而导致的测试失败).速度减慢测试 ...

最新文章

  1. Ansible的安装及部署
  2. 查看linux上面是否有安装redis,redis启动
  3. 设计模式:常见模式案例
  4. httpd四之CGI、HTTPS、压缩配置
  5. git reset git stash
  6. org.apache.poi.openxml4j.exceptions.InvalidOperationException: Can't open the specified file
  7. Springcloud整理
  8. 深入入门正则表达式(java) - 1 - 入门基础
  9. 美国AI出口限令倒计时,硅谷直喊“下手轻点”,担心推动中国技术发展
  10. VM虚拟机系统时间同步网络时间并登录用户自动校正时间
  11. cryptojs des php,前端CryptoJS AES/DES加解密与后端PHP AES/DES加解密
  12. 利用matlab描点绘制平滑曲线
  13. 计算机基础知识经典问答题,计算机基础知识问答题及答案一
  14. 主流的web前端开发及调试工具
  15. 手把手教你安装Xposed框架+JustTrustMe抓取手机APP数据
  16. cf黑机器多久解除_CF永久解除机器码|CF机器码硬解封详细步骤教程+工具|CF辅助-QQ知啦娱乐网...
  17. python编程一球从100米_Python一个球100米高空落下,每次落下后反弹高度是原高度的一半,再落下...
  18. 论文选题的原则、来源与方法
  19. 计算机毕设存档袋子,关于做好2018届毕业论文(设计)材料整理存档的通知
  20. list to torch

热门文章

  1. 【渝粤教育】国家开放大学2018年春季 3897T商务英语1 参考试题
  2. 【渝粤教育】电大中专职业生涯规划 (2)_1作业 题库
  3. 【渝粤教育】电大中专电子商务网站建设与维护 (25)作业 题库
  4. 【渝粤题库】陕西师范大学200781 数据库原理及应用 作业
  5. linux gdb网络调试工具,Linux--gdb调试工具
  6. 美国凯斯西储大学计算机硕士专业怎么样,在凯斯西储大学读硕士大约需要多少花费?...
  7. JVM内存管理(一)--GC简介
  8. SqlServer 时间格式化
  9. os sys hashlib
  10. @RequestMapping