php服务器开发之 app客户端首页接口开发(一) 概述及方案一:读取数据库方式开发首页接口
本篇博文主要内容:1.简述app客户端首页接口开发的三种方案
2.实例讲解 方案一:读取数据库方式开发首页接口
/**********************************************************************************************************************************/
方案一:读取数据库方式开发首页接口
1.从数据库获取消息
2.封装数据3.生成接口数据
适用场景:
数据时效性高的系统
1.从数据库获取消息
2.封装数据,并写入缓存(memcache方式)
3.生成接口数据
方案三:定时读取缓存方式开发首页接口
使用crontab定时任务
方案一详解:读取数据库方式开发首页接口
重点:1.如何获取数据2.如何生成通信数据
分析部分APP首页
慕课网:首页是列表页显示课程信息,不是一页全部显示,而是部分加载。通过访问数据库加载。
搜狐视频HD:模块很多,但是原理和慕课网类似。都是从数据库获取数据。
开发流程:
1.通过http请求服务器
2.服务器查询数据
3.服务器返回数据
实例:
list.php
<?php //这是app首页接口 //访问方式http://****.com/list.php?page=1&pagesize=12 require_once('./response.php');//引入数据封装类 $page=isset($_GET['page'])?$_GET['page']:1; //判断是否传入page的get值,如果传入对page赋值,否则赋值为1 $pageSize=isset($_GET['pageSizze'])?$_GET['pageSize']:1; //同理判断pageSize //判断传入数据合法性(是否为数字) if(!is_numeric($page)||!is_numeric($pageSize)) { //code设置为401,这是服务端工程师规定的,需要在接口文档说明 Response::show(401,'数据不合法'); echo 1213123123123; } //起始值从offset开始获取pagesize条数据 $offset=($page-1)*$pageSize; $sql="select * from video where status= 1 order by orderby desc limit".$offset."," .$pageSize; echo $sql;//打印sql
通信数据(xml,json)封装类 response.php
<?php class Response { const JSON = "json"; /** * 按综合方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * @param string $type 数据类型 * return string */ public static function show($code, $message = '', $data = array(), $type = self::JSON) { if(!is_numeric($code)) { return ''; } $type = isset($_GET['format']) ? $_GET['format'] : self::JSON; $result = array( 'code' => $code, 'message' => $message, 'data' => $data, ); if($type == 'json') { self::json($code, $message, $data); exit; } elseif($type == 'array') { var_dump($result); } elseif($type == 'xml') { self::xmlEncode($code, $message, $data); exit; } else { // TODO } } /** * 按json方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * return string */ public static function json($code, $message = '', $data = array()) { if(!is_numeric($code)) { return ''; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data ); echo json_encode($result); exit; } /** * 按xml方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * return string */ public static function xmlEncode($code, $message, $data = array()) { if(!is_numeric($code)) { return ''; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data, ); header("Content-Type:text/xml"); $xml = "<?xml version='1.0' encoding='UTF-8'?>\n"; $xml .= "<root>\n"; $xml .= self::xmlToEncode($result); $xml .= "</root>"; echo $xml; } public static function xmlToEncode($data) { $xml = $attr = ""; foreach($data as $key => $value) { if(is_numeric($key)) { $attr = " id='{$key}'"; $key = "item"; } $xml .= "<{$key}{$attr}>"; $xml .= is_array($value) ? self::xmlToEncode($value) : $value; $xml .= "</{$key}>\n"; } return $xml; } }
http请求list.php
网页显示结果
未完待续。。。。。。。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。