日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

接口测试php代码,简易 PHP API 测试

發布時間:2023/12/2 php 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 接口测试php代码,简易 PHP API 测试 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

簡易 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 测试的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。