基于Yii2.0框架的Restful Api的对接以及跨域解决;
2.新建api模块,专门用来存放api相关,并配置响应格式为json而不是xml;
3.改造请求错误提示为Json格式,而非html;
4.测试调试请求;
5.前端进行接收,这部分我们说下前端ajax如何跨域做出请求;
准备:
1.新建news表用来展示(也可以用命令行migration去建表):
2.api的请求工具:chrome中建议安装postman、firefox中安装HttpRequest,其他浏览器自行解决;
3.Json的查看工具:chrome中建议安装JSONView,会显示格式化的json,firefox中安装jsonformater,其他浏览器自行解决;
3.开启伪静态rewrite、并且配置api的二级域名为api.news.com格式,绑定在api/web下面;
1.copy一份frontend或backend目录下的文件重命名为api放置在同级下作为api的内容,在common>bootstrap.php文件中依赖注入声明api模块:
Yii::setAlias('@api',dirname(dirname(__DIR__)).'/api');
2.在api下新建v1、v2作为我们不同版本的内容、并在里面新建controllers、models、views部分,并分别在v1、v2下新建Module.php声明命名空间;
在yii2.0框架中集成了restful api的部分,封装在yii\rest下,我们要做的工作有:
1.apache或nginx中开启rewrite伪静态模式(可自行搜索)
2.新建api模块,专门用来存放api相关,并配置响应格式为json而不是xml;
3.改造请求错误提示为Json格式,而非html;
4.测试调试请求;
5.前端进行接收,这部分我们说下前端ajax如何跨域做出请求;
准备:
1.新建news表用来展示(也可以用命令行migration去建表):
DROP TABLE IF EXISTS `news`;
CREATE TABLE IF NOT EXISTS `news` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`time` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `title` (`title`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
2.api的请求工具:chrome中建议安装postman、firefox中安装HttpRequest,其他浏览器自行解决;
3.Json的查看工具:chrome中建议安装JSONView,会显示格式化的json,firefox中安装jsonformater,其他浏览器自行解决;
3.开启伪静态rewrite、并且配置api的二级域名为api.news.com格式,绑定在api/web下面;
一、Api模块的建立:
1.copy一份frontend或backend目录下的文件重命名为api放置在同级下作为api的内容,在common>bootstrap.php文件中依赖注入声明api模块:
Yii::setAlias('@api',dirname(dirname(__DIR__)).'/api');
2.在api下新建v1、v2作为我们不同版本的内容、并在里面新建controllers、models、views部分,并分别在v1、v2下新建Module.php声明命名空间;
<?php
/**
* @see https://github.com/craftsmann.
* @author craftsmann <m13993334619@163.com>
*/
namespace api\modules\v1;
class Module extends \yii\base\Module
{
public $controllerNamespace = 'api\modules\v1\controllers';
public function init()
{
parent::init(); // T