当前位置:首页 > CMS教程 > Thinkphp > 列表

使用Thinkphp框架开发移动端接口

发布:smiling 来源: PHP粉丝网  添加日期:2021-06-15 19:24:48 浏览: 评论:0 

本文给大家分享的是使用thinkphp框架开发移动端接口的2种方法,一种是开发API,另外一种是实现移动端访问自动切换移动主题模板,从而实现伪app访问,下面我们就来详细看下如何实现吧。

方案一:给原生APP提供api接口

使用TP框架时 放在common文件夹下文件名就叫function.php

  1. <?php 
  2. /** 
  3.  * Created by zhangkx 
  4.  * Email: zkx520tnhb@163.com 
  5.  * Date: 2015/8/1 
  6.  * Time: 23:15 
  7.  */ 
  8.    
  9. /*************************** api开发辅助函数 **********************/ 
  10.    
  11. /** 
  12.  * @param null $msg  返回正确的提示信息 
  13.  * @param flag success CURD 操作成功 
  14.  * @param array $data 具体返回信息 
  15.  * Function descript: 返回带参数,标志信息,提示信息的json 数组 
  16.  * 
  17.  */ 
  18. function returnApiSuccess($msg = null,$data = array()){ 
  19.   $result = array
  20.     'flag' => 'Success'
  21.     'msg' => $msg
  22.     'data' =>$data 
  23.   ); 
  24.   print json_encode($result); 
  25.    
  26. /** 
  27.  * @param null $msg  返回具体错误的提示信息 
  28.  * @param flag success CURD 操作失败 
  29.  * Function descript:返回标志信息 ‘Error',和提示信息的json 数组 
  30.  */ 
  31. function returnApiError($msg = null){ 
  32.   $result = array
  33.     'flag' => 'Error'
  34.     'msg' => $msg
  35.   ); 
  36.   print json_encode($result); 
  37.    
  38. /** 
  39.  * @param null $msg  返回具体错误的提示信息 
  40.  * @param flag success CURD 操作失败 
  41.  * Function descript:返回标志信息 ‘Error',和提示信息,当前系统繁忙,请稍后重试; 
  42.  */ 
  43. function returnApiErrorExample(){ 
  44.   $result = array
  45.     'flag' => 'Error'
  46.     'msg' => '当前系统繁忙,请稍后重试!'
  47.   ); 
  48.   print json_encode($result); 
  49.    
  50. /** 
  51.  * @param null $data 
  52.  * @return array|mixed|null 
  53.  * Function descript: 过滤post提交的参数; 
  54.  * 
  55.  */ 
  56.    
  57.  function checkDataPost($data = null){ 
  58.   if(!emptyempty($data)){ 
  59.     $data = explode(',',$data); 
  60.     foreach($data as $k=>$v){ 
  61.       if((!isset($_POST[$k]))||(emptyempty($_POST[$k]))){ 
  62.         if($_POST[$k]!==0 && $_POST[$k]!=='0'){ 
  63.           returnApiError($k.'值为空!'); 
  64.         } 
  65.       } 
  66.     } 
  67.     unset($data); 
  68.     $data = I('post.'); 
  69.     unset($data['_URL_'],$data['token']); 
  70.     return $data
  71.   } 
  72.    
  73. /** 
  74.  * @param null $data 
  75.  * @return array|mixed|null 
  76.  * Function descript: 过滤get提交的参数; 
  77.  * 
  78.  */ 
  79. function checkDataGet($data = null){ 
  80.   if(!emptyempty($data)){ 
  81.     $data = explode(',',$data); 
  82.     foreach($data as $k=>$v){ 
  83.       if((!isset($_GET[$k]))||(emptyempty($_GET[$k]))){ 
  84.         if($_GET[$k]!==0 && $_GET[$k]!=='0'){ 
  85.           returnApiError($k.'值为空!'); 
  86.         } 
  87.       } 
  88.     } 
  89.     unset($data); 
  90.     $data = I('get.'); 
  91.     unset($data['_URL_'],$data['token']); 
  92.     return $data
  93.   } 

查询单个果品详细信息

  1. /** 
  2.   * 发布模块 
  3.   *  
  4.   * 获取信息单个果品详细信息 
  5.   * 
  6.   */ 
  7.   public function getMyReleaseInfo(){ 
  8.     //检查是否通过post方法得到数据 
  9.     checkdataPost('id'); 
  10.     $where['id'] = $_POST['id']; 
  11.     $field[] = 'id,fruit_name,high_price,low_price,address,size,weight,fruit_pic,remark'
  12.     $releaseInfo = $this->release_obj->findRelease($where,$field); 
  13.     $releaseInfo['remark'] = mb_substr($releaseInfo['remark'],0,49,'utf-8').'...'
  14.     //多张图地址按逗号截取字符串,截取后如果存在空数组则需要过滤掉 
  15.     $releaseInfo['fruit_pic'] = array_filter(explode(','$releaseInfo['fruit_pic'])); 
  16.     $fruit_pic = $releaseInfo['fruit_pic'];unset($releaseInfo['fruit_pic']); 
  17.     //为图片添加存储路径 
  18.     foreach($fruit_pic as $k=>$v ){ 
  19.       $releaseInfo['fruit_pic'][] = 'http://'.$_SERVER['HTTP_HOST'].'/Uploads/Release/'.$v
  20.     } 
  21.     if($releaseInfo){ 
  22.       returnApiSuccess('',$releaseInfo); 
  23.     }else
  24.       returnApiError( '什么也没查到(+_+)!'); 
  25.     } 
  26.   } 

findRelease() 方法的model

  1. /** 
  2.   * 查询一条数据 
  3.   */ 
  4.   public function findRelease($where,$field){ 
  5.     if($where['status'] == '' || emptyempty($where['status'])){ 
  6.       $where['status'] = array('neq','9'); 
  7.     } 
  8.     $result = $this->where($where)->field($field)->find(); 
  9.     return $result
  10.   } 

app端接收到的数据(解码json之后)

  1.   "flag""success"
  2.   "message"""
  3.   "responseList": { 
  4.     "id""2"
  5.     "fruit_name""苹果"
  6.     "high_price""8.0"
  7.     "low_price""5.0"
  8.     "address""天津小白楼水果市场"
  9.     "size""2.0"
  10.     "weight""2.0"
  11.     "remark""急需..."
  12.     "fruit_pic": [ 
  13.       "http://fruit.txunda.com/Uploads/Release/201508/55599e7514815.png"
  14.       "http://fruit.txunda.com/Uploads/Release/201508/554f2dc45b526.jpg" 
  15.     ] 
  16.   } 

app端接收到的数据(原生json串),代码如下:

  1. {"flag":"success","message":"","responseList":{"id":"2","fruit_name":"\u82f9\u679c","high_price":"8.0","low_price":"5.0","address":"\u5929\u6d25\u5c0f\u767d\u697c\u6c34\u679c\u5e02\u573a","size":"2.0","weight":"2.0","remark":"\u6025\u9700...","fruit_pic":["http:\/\/fruit.txunda.com\/Uploads\/Release\/201508\/55599e7514815.png","http:\/\/fruit.txunda.com\/Uploads\/Release\/201508\/554f2dc45b526.jpg"]}} 

方案二:另外我们还可以通过ThinkPHP实现移动端访问自动切换主题模板,这样也可以做到移动端访问

ThinkPHP的模板主题机制,如果只是在PC,只要需修改 DEFAULT_THEME (新版模板主题默认是空,表示不启用模板主题功能)配置项就可以方便的实现多模板主题切换。

但对于移动端和PC端,也许你会设计完全不同的主题风格,且针对不同的来路提供不同的渲染方式,其中一种比较流行的方法是“响应式设计”,但就本人经历而言,要实现完全的“响应式设计”并不是那么容易,且解决兼容问题也是个难题,假设是大型站点,比如:淘宝、百度、拍拍这些,响应式设计肯定是满足不了需求的,而是需要针对手机访问用户提供单独的手机网站。

ThinkPHP 完全可以实现,而且相当简单。和TPM的智能模版切换引擎一样,只要对来路进行判断处理即可。

一、将 ismobile() 加入到{项目/Common/common.php}

  1. function ismobile() { 
  2.   // 如果有HTTP_X_WAP_PROFILE则一定是移动设备 
  3.   if (isset ($_SERVER['HTTP_X_WAP_PROFILE'])) 
  4.     return true; 
  5.     
  6.   //此条摘自TPM智能切换模板引擎,适合TPM开发 
  7.   if(isset ($_SERVER['HTTP_CLIENT']) &&'PhoneClient'==$_SERVER['HTTP_CLIENT']) 
  8.     return true; 
  9.   //如果via信息含有wap则一定是移动设备,部分服务商会屏蔽该信息 
  10.   if (isset ($_SERVER['HTTP_VIA'])) 
  11.     //找不到为flase,否则为true 
  12.     return stristr($_SERVER['HTTP_VIA'], 'wap') ? true : false; 
  13.   //判断手机发送的客户端标志,兼容性有待提高 
  14.   if (isset ($_SERVER['HTTP_USER_AGENT'])) { 
  15.     $clientkeywords = array
  16.       'nokia','sony','ericsson','mot','samsung','htc','sgh','lg','sharp','sie-','philips','panasonic','alcatel','lenovo','iphone','ipod','blackberry','meizu','android','netfront','symbian','ucweb','windowsce','palm','operamini','operamobi','openwave','nexusone','cldc','midp','wap','mobile' 
  17.     ); 
  18.     //从HTTP_USER_AGENT中查找手机浏览器的关键字 
  19.     if (preg_match("/(" . implode('|'$clientkeywords) . ")/i"strtolower($_SERVER['HTTP_USER_AGENT']))) { 
  20.       return true; 
  21.     } 
  22.   } 
  23.   //协议法,因为有可能不准确,放到最后判断 
  24.   if (isset ($_SERVER['HTTP_ACCEPT'])) { 
  25.     // 如果只支持wml并且不支持html那一定是移动设备 
  26.     // 如果支持wml和html但是wml在html之前则是移动设备 
  27.     if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) && (strpos($_SERVER['HTTP_ACCEPT'], 'text/html') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') < strpos($_SERVER['HTTP_ACCEPT'], 'text/html')))) { 
  28.       return true; 
  29.     } 
  30.   } 
  31.   return false; 
  32.  } 

二、在{项目/Lib/}创建一个 CommonAction.php,如果你的项目已公共控制器,则无需创建,直接加在里面即可。

  1. Class CommonAction extends Action{ 
  2.   Public function _initialize(){ 
  3.     //移动设备浏览,则切换模板 
  4.     if (ismobile()) { 
  5.       //设置默认默认主题为 Mobile 
  6.       C('DEFAULT_THEME','Mobile'); 
  7.     } 
  8.     //............你的更多代码....... 
  9.   } 
  10.  } 

通过以上2种方式均可实现移动端访问,一种是原生,一种是伪原生,小伙伴们根据自己的项目需求来选择吧。

Tags: Thinkphp开发移动端接口

分享到: