设为首页 收藏本站
查看: 548|回复: 0

[经验分享] PHP API接口测试小工具

[复制链接]

尚未签到

发表于 2015-8-24 16:36:20 | 显示全部楼层 |阅读模式
  前端时间给手机客户端做接口,当时弱爆了,写完API接口后,也不怎么测试,最后是等客户端调用的时候检验API的正确性。
  后面利用PHP的curl实现Post请求,检验API接口的正确性;配合前面做的一个查看Apache错误日志的小工具,可将将错误一览无余;利用firebug或fiddler可以查看http通讯。
  

一、功能说明

样式firebug中的http通信信息
  
  1、client_name、client_version、api_debug和url这几个是每次都需要传的参数,除了url其他3个参数都可以根据实际情况修改,url是每个接口的地址
  2、一行两个输入框的地方是可变参数,就是每个接口特有的需要传递的参数,参数名和参数值都可以自定义
  3、点击添加参数可以增加那行可变参数
  4、点击测试,将输入框中的数据发送到接口中
  5、从接口端返回JSON格式的数据直接打印出来
  

二、html部分



<style type="text/css">
.mb20{margin-bottom:20px}
.title{display:inline-block;width:150px;text-align:right}
.w100{width:100px}
.mr10{margin-right:10px}
</style>


     <div class="mb20">
<label class="title">client_name:</label><input name="client_name" type="text" value="ANDROID"/>
</div>
<div class="mb20">
<label class="title">client_version:</label><input name="client_version" type="text" value="4.0"/>
</div>
<div class="mb20">
<label class="title">api_debug:</label><input name="api_debug" type="text"  value=""/>
</div>
<div class="mb20">
<label class="title">url:</label><input name="client_url" type="text" value=""/>
</div>
<div class="mb20">
<label class="title"><input name="api_key" type="text"  value="" class="w100"/>:</label><input name="api_value" type="text"  value=""/>
</div>
<div class="mb20">
<label class="title"></label><input type="button" value="测试" id="submit" class="mr10"/><input type="button" value="添加参数" id="add"/>
</div>
<div id="message"></div>
  这里做了点简单的修改,高度,宽度等。可变参数那行只用了name属性,分别是api_key和api_value,方便等下的克隆操作。
  

三、JavaScript部分



<script type="text/javascript">
$("#add").click(function() {
var $parent = $(this).parent();
var $clone = $parent.prev().clone();
$clone.find(':text').val('');
$clone.insertBefore($parent);
});
$("#submit").click(function() {
var api_keys = {
api_debug:$('input[name=api_debug]').val(),
client_url:$('input[name=client_url]').val()
};
$('input[name=api_key]').map(function() {
var key = $.trim($(this).val());
var value = $.trim($(this).next().val());
var repeat = {};
if(key != '') {
repeat[key] = value;
api_keys = $.extend(api_keys, repeat);
}
});
//提交到test文件中
                $.post('test.php', api_keys, function(data) {
$("#message").html(data);
});
});
</script>
  1、绑定两个按钮的click事件
  2、$("#add")的click事件是在做克隆操作,克隆的同时将原先两个输入框中的内容清除
  3、$('input[name=api_key]').map在做过滤无效可变参数的操作;有效的可变参数是指参数名和参数值都存在,只有都存在的才会发送过去
  4、$("#submit")通过post给test.php,通过它来发送消息给接口
  

四、php部分



<?php
$root = 'http://api.1ddian.cn/';//可自定义域名
$url= $root . $_REQUEST['client_url'];
//用curl实现Post请求,可跨域
$ch = curl_init();
curl_setopt($ch, CURLOPT_POST, 1);  
curl_setopt($ch, CURLOPT_URL, $url);  
curl_setopt($ch, CURLOPT_POSTFIELDS, $_REQUEST);  //传送参数
ob_start();  
curl_exec($ch);  
$result = ob_get_contents() ;  
ob_end_clean();  
print_r(json_decode($result)); //中文返回的是unicode编码,decode后方便阅读
?>
  1、$root这个域名可以自定义
  2、用curl实现Post请求,可跨域
  3、中文返回的是unicode编码,decode后方便阅读
  
  demo下载:
  http://download.iyunv.com/download/loneleaf1/7966101
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-103674-1-1.html 上篇帖子: PHP header函数使用教程 下篇帖子: PHP设计模式之装饰者模式
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表