jsonp数据类型,重要性,以及为什么用它,我就不详细解释了,如果想知道可以看我写的《php中 如何生成jsonp数据接口及如何调用?》
里面有详细说明;
那么进入正题,
案例要求:
两个网站A,和B,其中B通过jsonp接口向外提供职位查询功能,A网站通过该jsonp接口向B发起职位查询数据。
案例效果如下图:
首先创建一个查询表单页面,即search.html
代码及注释如下:
职位查询
然后,创建一个接口,我的接口是在yii2架构中做的,当然用原生的也可以,怎么方便怎么来,
代码,我只用到一个方法,想用的可根据详情改变,
代码如下:
//jsonp 接口 查询职位
public function actionJsonp()
{
header("Access-Control-Allow-Origin: *");//同源策略 跨域请求 头设置
header('content-type:text/html;charset=utf8 ');
//获取回调函数名
$jsoncallback = htmlspecialchars($_REQUEST['callback']);//把预定义的字符转换为 HTML 实体。
$zhi = htmlspecialchars($_REQUEST['zhi']);
$arr=yii::$app->db->createCommand("select * from position where p_name like :name",array(':name'=>"%$zhi%"))->queryAll();//用的like进行模糊查询
$json_data=json_encode($arr);//转换为json数据
//输出jsonp格式的数据
echo $jsoncallback . "(" . $json_data . ")";
}
那么这样就完成了,是不是很简单呢