json和xml封装数据、数据缓存到文件中
一、APP的通信格式之xml
xml:扩展标记语言,可以用来标记数据,定义数据类型,是一种允许用户对自己标记语言进行定义的源语言。XML格式统一,扩平台语言,非常适合数据传输和通信,业界公认的标准。
支持操作系统:windows、linux
支持语言:python、php、java
二、APP的通信格式之json
JSON是一种轻量级的数据交换语言,以文字为基础,且易于让人阅读,同时也方便了机器进行解析和生成。
JSON简单的说是javascript中的对象和数组,所以这两种结构就是对象和数组两种结构,通过这两种结构可以表示各种复杂的结构,其可以将Javascript对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松的传递这个字符串,或者在异步应用程序中将字符串从Web客户机传递给服务器端程序。
JSON采用完全独立于程序语言的文本格式。JSON是理想的数据交换语言。
三、APP的通信格式之区别
1、可读性方面:xml比较好
2、生成数据方面:json较优(一个函数即可)
3、传输速度方面:json胜出
四、APP接口的作用
1、获取数据
从数据或者缓存中获取数据,然后通过接口数据返回给客户端
2、提交数据
通过接口提交给服务器,然后服务器对数据进行入库处理,并返回执行结果。
五、APP开发之APP接口
1、json方式封装接口数据的方法
通信数据的标准格式:
code 状态码(200,400等)
message 提示信息(提示用户的操作成功与失败)
data 返回的数据
2、json方式封装:php生成JSON数据
方法:json_encode($value);
注意:该函数只能接受UTF-8编码的数据,如果传递其他格式的数据的话会返回NULL
六、使用json和xml封装数据,代码如下:
<?php
class Response{
static public function datas($code,$message,$data,$type='json'){
switch($type){
case 'json':
return self::json($code,$message,$data);
break;
case 'xml':
return self::xml($code,$message,$data);
break;
case 'array':
$arr = array(
"code"=>$code,
"message" =>$message,
"data" =>$data,
);
var_dump($arr);
break;
default:
break;
}
}
//xml为了安全性在前面加static
static public function xml($code,$message,$data){
if(!is_numeric($code)){
return false;
}
if($message && $data){
$str = '<?xml version="1.0" encoding="UTF-8">
<item>
<code>'.$code.'</code>
<message>'.$message.'</message>
<data>';
$str.=self::item($data);
$str.='</data>
</item>';
return $str;
}else{
return false;
}
}
static public function item($data){
$str = "";
//打印var_dump($data);
foreach($data as $key =>$value){
if(is_array($value)){
$str .="<data$key>".self::item($value)."</data$key>\n";
}else{
$str .="<$key>{$value}</$key>\n";
}
}
return $str;
}
//json
static public function json($code,$message,$data){
if(!is_numeric($code)){
return false
}
if($message && $data){
$arr = array(
"code"=>$code,
"message" =>$message,
"data" =>$data,
);
return json_encode($arr);
}else{
return false;
}
}
}
$data = array(
array("name"=>"张三","age"=>"10"),
array("name"=>"李煜","age"=>"20"),
array("name"=>"李涛","age"=>"18"),
array("name"=>"马华","age"=>"20"),
array("name"=>"王子涵","age"=>"20"),
array("name"=>"李丽","age"=>"22"),
);
$type = isset($_GET['type'])?$_GET['type']:'json';
echo Response::datas("200","成功",$data,$type)
?>
七、数据缓存到文件中,代码如下:
<?php
class Files{
public $dir;
public $ext = '.txt';
public $path;
public function __construct(){
$this->dir=dirname(__FILE__).'/data/';
}
//缓存数据
public function CacheData($data,$paths,$time,$filename){
//设置缓存文件
$this->path=$this->dir.$paths.$filename.$this->ext;
if(!file_exists(dirname($this->path))){
mkdir(dirname($this->path));
}
if($data){
// 设置数据,不足10位用0补全
$str = sprintf('010%d',$time).$data.time();
//数据存在的话,对数据进行缓存
file_put_contents($this->path,$str);
}else{
//判断文件是否存在
if(!file_exists($this->path)){
return false;
}
//如果数据为空,删除缓存
if(is_null($data)){
//删除文件
unlink($this->path);
}
//定时更新
$datas=file_get_contents($this->path);
$cacheTime=substr($datas,0,10);
$oldTime =substr($datas,-10);
if($oldTime+$cacheTime >time()){
return substr($datas,10,-10);
}else{
return false;
}
}
}
}
include "Response.php";
header('content-type:text/html;charset=utf-8');
$model=new Files();
//删除缓存
$model->CacheData(null,'user','','file1');
//$model->CacheData('数据',缓存到哪个文件中,缓存时间,'文件名file1')
//把数据缓存到data文件下的user文件夹的stem.txt中
//读取缓存
if($data=$model->CacheData('123','/user/',100,'file1')){
$data=json_decode($data,true);
var_dump($data);
echo "从文件获取数据";
}else{
//设置缓存
echo "设置数据";
$data = array(
array("name"=>"张三","age"=>"10"),
array("name"=>"李煜","age"=>"20"),
array("name"=>"李涛","age"=>"18"),
array("name"=>"马华","age"=>"20"),
array("name"=>"王子涵","age"=>"20"),
array("name"=>"李丽","age"=>"22"),
);
var_dump($data);
$str= Response::datas("200","成功",$data);
$model->CacheData($str,'/user/',100,'file1');
}
?>
json和xml封装数据、数据缓存到文件中的更多相关文章
- jQuery form插件的使用--处理server返回的JSON, XML,HTML数据
详细代码: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> & ...
- Python3操作MySQL,查询数据并保存到文件中
我们在测试过程中,可能需要到数据库中拉去一些数据,为从测试准备.比如最近在做接口性能测试的时候,就需要很多数据来支撑,所以就需要的数据库去查询数据,下面就是python3 查询 mysql 并且保存到 ...
- Java JSON、XML文件/字符串与Bean对象互转解析
前言 在做web或者其他项目中,JSON与XML格式的数据是大家经常会碰见的2种.在与各种平台做数据对接的时候,JSON与XML格式也是基本的数据传递格式,本文主要简单的介绍JSON/XML ...
- iOS-数据持久化基础-JSON与XML数据解析
解析的基本概念 所谓“解析”:从事先规定好的格式串中提取数据 解析的前提:提前约定好格式.数据提供方按照格式提供数据.数据获取方按照格式获取数据 iOS开发常见的解析:XML解析.JSON解析 一.X ...
- 玩转iOS开发 - JSON 和 Xml 数据解析
前言 Json 和xml是网络开发中经常使用的数据格式,JSON轻量级.xml相对较复杂.所以如今用JSON的比例很大.基本上从server获取的返回数据都是JSON格式的,作为iOS开发人员,解析J ...
- 数据交换格式Json与XML
什么是数据交换格式: 主流的有Json.XML.HTML. 数据交换格式的应用场景: 移动端(安卓,IOS)通讯方式采用http协议+Json格式的restful风格. 很多互联网公司都是用Http协 ...
- python数据处理(一)之供机器读取的数据 csv,json,xml
代码与资料 https://github.com/jackiekazil/data-wrangling 1 csv 1.1导入csv数据 1.2将代码保存到文件中并在命令行中运行 2.json 2 导 ...
- PHP如何自动识别第三方Restful API的内容,自动渲染成 json、xml、html、serialize、csv、php等数据
如题,PHP如何自动识别第三方Restful API的内容,自动渲染成 json.xml.html.serialize.csv.php等数据? 其实这也不难,因为Rest API也是基于http协议的 ...
- php生成json或者xml数据
, ,'数据返回成功',$arr);echo $xml;?>
随机推荐
- YII缓存依赖的应用
YII缓存依赖的应用 缓存 缓存依赖 Yii 缓存是提升Web应用性能的简便有效的方式.当我们在加载网页需要过多的时间,比如说查询时间过久,抑或是调用接口占用过多I/O,建立缓存是一个行之有效的方法, ...
- VR全景智慧城市-提前进入商家观景,涵盖实体行业
互联网发展的迅猛势头,让很多的实体商家翻了个大跟头,更有言说,未来的大街小巷根本见不到逛街的人,可是线上商城相继曝出的假货谁来买单?相比之下眼见为实更让消费者心里觉得踏实.所以,全景智慧城市更能满足大 ...
- Java阶段性测试--第二三大题参考代码
第二大题: 1.打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于它本身 package Test1; //1.打印出所有的 ...
- 聊聊AngularJs
大家好! 今天我们要说的就是我们的AngularJs 当然呢!我们Angular呢! 1.是一个MVC框架,如果我们说他是一个mvc的框架呢!就是有些不太具体了,其实他是我们的MVC的扩展版 当然他具 ...
- v9 调用模型中新增的字段
在模型中新增字段的时候,可以选择“是否为主表”. 若选是,则前台调用可直接通过字段名调用. 若选否,在前台调用是应在{pc:content}中添加 moreinfo="1",表示允 ...
- Strom序列化机制
Storm 中的 tuple可以包含任何类型的对象.由于Storm 是一个分布式系统,所以在不同的任务之间传递消息时Storm必须知道怎样序列化.反序列化消息对象. Storm 使用 Kryo库对对象 ...
- WindowManager.LayoutParams的探究
上次在子线程更新UI时用了一下WindowManager.LayoutParams,当时觉得不太顺手.以前都是用空参构造器,这次用了type和flag属性,出现了意想不到的效果.也看看源码吧,多锻炼锻 ...
- Swift 求余运算
求余运算 求余运算(a % b)是计算b的多少倍刚刚好可以容入a,返回多出来的那部分(余数). 注意:求余运算(%)在其他语言也叫取模运算.然而严格说来,我们看该运算符对负数的操作结果,"求 ...
- golang中defer的使用规则
转自个人博客chinazt.cc 在golang当中,defer代码块会在函数调用链表中增加一个函数调用.这个函数调用不是普通的函数调用,而是会在函数正常返回,也就是return之后添加一个函数调用. ...
- JS中关于clientWidth offsetWidth scrollWidth 的区别及意义
网页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight;网页可见区域宽: document.body.offset ...