PHP API接口应用实例

时间:2016-12-29 17:51:38 类型:PHP
字号:    

PHP工作学习中, 经常会遇到API接口的应用, 因为没有接触过, 就会感觉到非常难以下手, 这里给大家一个简单的PHP实例, 希望对大家有所帮助!

实例功能:简单实现API接口实例操作 1, 新闻标题添加 2, 新闻标题查询

client.php: 客户端[调取信息的一端]          service.php: 服务端[返回信息的一端]

数据库大家自行导入,设置 fun.php中

$dsn = "mysql:host=localhost;dbname=myapi";
$db = new PDO($dsn, 'root', 'root');

为追求简单, 这里没有任何超级的逻辑, 都是简单的理解, 对于不认识的函数,大家可以百度下了解下什么意思, 下面就直接上代码了, 代码的最后可以直接下载源代码

service.php文件


header("Content-Type: text/html; charset=UTF-8");
require("fun.php");
$success = '';
$output = array();
$action = isset($_GET["action"])?$_GET["action"]:"";
if(empty($action)){
	$success = '0';
	$output = array('success'=>$success); //0表示参数错误
	exit(json_encode($output));  //将php数组转换为JSON格式返回
}

$title = isset($_GET["title"])?$_GET["title"]:"";
if(empty($title)){
	$success = '1';
	$output = array('success'=>$success); //1表示标题为空
	exit(json_encode($output));
}

$db = conndb(); //连接数据库

if($action=="add"){ //新闻标题查询s
	$sql = "insert into news set title = '$title'";
	$count = $db->exec($sql);
    if($count){
			$success = '2';
			$output = array('success'=>$success); //2 添加新闻成功
			exit(json_encode($output));
	}
}
else if($action=="select"){
	$sql = "select * from news where title like '%".$title."%'";
	$result = query($db,$sql);
	if($result){$success = '3';}//3 查询到新闻信息
	else{$success = '4';} //没有查询到新闻信息
	$output = array('success'=>$success,'result'=>$result);
	exit(json_encode($output));
}


client.php源代码


header("Content-Type: text/html; charset=UTF-8");
	$data = array(
			  'action' => 'select', //添加信息 'select' 查询信息
			  'title'  => '南昌雅腾'
	);
	$param = http_build_query($data); //用法 http://www.ncyteng.com/news/show/86;
	
    $requesturl= "http://localhost:88/php/api/service.php?".$param; 
	//完整的访问路径如http://www.ncyteng.com/service.php, 调用时修改为自己的域名接口完整网址sss

	//echo $requesturl;
	//通过curl方式获取json数据
    $curl = curl_init(); //初始化
    curl_setopt($curl, CURLOPT_URL, $requesturl);//设置抓取的url 为 $requesturl
    curl_setopt($curl, CURLOPT_HEADER, 0);//设置头文件的信息作为数据流输出
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//设置获取的信息以文件流的形式返回,而不是直接输出。
    $data = curl_exec($curl);//执行命令
    curl_close($curl);//关闭URL请求
	$obj=json_decode($data);
	
	$success = $obj->success;
	$status = "";
	switch($success){
		case '0': $status = "参数传递错误";break;
		case '1': $status = "添加新闻标题不能为空";break;
		case '2': $status = "添加新闻成功";break;
		case '3': $status = "查询到信息";break;
	}
	echo $status."<br/>";
	if($success=="3"){
		$result = $obj->result;
		foreach($result as $row){ //注意每个$row这里是一个对象, 而不是一个数组
			echo "标题:".$row->title."<br/>";
		}
	}

源码下载: /public/static/uploads/pic/201612/29/2016122955108320370351.zip