thinkPHP5.0框架API优化后的友好性分析
作者:chinalorin
本文实例讲述了thinkPHP5.0框架API优化后的友好性。分享给大家供大家参考,具体如下:
新版ThinkPHP针对API开发做了很多的优化,并且不依赖原来的API模式扩展。
数据输出
新版的控制器输出采用Response
类统一处理,而不是直接在控制器中进行输出,通过设置default_return_type
或者动态设置不同类型的Response
输出就可以自动进行数据转换处理,一般来说,你只需要在控制器中返回字符串或者数组即可,例如如果我们配置:
'default_return_type'=>'json'
那么下面的控制器方法返回值会自动转换为json格式并返回。
namespace app\index\controller; class Index { public function index() { $data = ['name'=>'thinkphp','url'=>'thinkphp.cn']; return ['data'=>$data,'code'=>1,'message'=>'操作完成']; } }
访问该请求URL地址后,最终可以在浏览器中看到输出结果如下:
如果你需要返回其他的数据格式的话,控制器本身的代码无需做任何改变。
支持明确指定输出类型的方式输出,例如下面指定JSON数据输出:
namespace app\index\controller; class Index { public function index() { $data = ['name'=>'thinkphp','url'=>'thinkphp.cn']; // 指定json数据输出 return json(['data'=>$data,'code'=>1,'message'=>'操作完成']); } }
或者指定输出XML类型数据:
namespace app\index\controller; class Index { public function index() { $data = ['name'=>'thinkphp','url'=>'thinkphp.cn']; // 指定xml数据输出 return xml(['data'=>$data,'code'=>1,'message'=>'操作完成']); } }
核心支持的数据类型包括view、xml、json和jsonp,其他类型的需要自己扩展。
错误调试
由于API开发不方便在客户端进行开发调试,但ThinkPHP5的Trace调试功能支持Socket在内的方式,可以实现远程的开发调试。
设置方式:
'app_trace' => true, 'trace' => [ 'type' => 'socket', // socket服务器 'host' => 'slog.thinkphp.cn', ],
然后安装chrome浏览器插件后即可进行远程调试,详细参考调试部分。
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》、《smarty模板入门基础教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
您可能感兴趣的文章:
- Thinkphp 在api开发中异常返回依然是html的解决方式
- thinkphp5框架API token身份验证功能示例
- ThinkPHP框架整合微信支付之JSAPI模式图文详解
- ThinkPHP实现微信支付(jsapi支付)流程教程详解
- Thinkphp5框架ajax接口实现方法分析
- thinkPHP5框架接口写法简单示例
- ThinkPHP框架实现的微信支付接口开发完整示例
- thinkPHP框架实现的短信接口验证码功能示例
- thinkPHP微信分享接口JSSDK用法实例
- thinkPHP框架对接支付宝即时到账接口回调操作示例
- ThinkPHP和UCenter接口冲突的解决方法
- thinkphp使用url请求调用ThinkApi天气教程【图文详解】