# Api開發---接口數據的添加和修改
> 注:由于這是入門級課程 在本章的api數據操作課程中 將忽略 權限驗證 簽名驗證等
>
[TOC]
### 我拿一段源碼講解一下
~~~
public function applyEdit(){
header("Access-Control-Allow-Origin: *");
if($this->request->isPost()){
try{
$param_list =[
"company"=>"company/s",
"address"=>"address/s",
"contacts"=>"contacts/s",
"jobs"=>"jobs/s",
"mobile"=>"mobile/s",
"tencent_code"=>"tencent_code/s",
"desc"=>"desc/s",
"event_key"=>"event_key/n",
];
$save_data = $this->buildParam($param_list);
$save_data["originate"] = preg_replace('/http(s)?:\/\//',"",$this->request->server("HTTP_ORIGIN"));
$save_data["open_id"] = $this->open_id;
$validate_name = "base/system/SystemApply";
$model_name='base/system/SystemApply';
$result = $this->editData(false,$validate_name,$model_name,$save_data);
if(isset($result["code"])){
if($result["code"]==1001){
$this->sendMessageToAdmin($save_data);
}
}
return json($result);
}catch (Exception $e){
Log::error($e->getMessage());
return self::showJsonReturnCodeWithOutData(1008,$e->getMessage());
}
}else{
return self::showJsonReturnCodeWithOutData(1002);
}
}
~~~
### 首先 我在代碼的前段增加允許跨域的代碼
~~~
header("Access-Control-Allow-Origin: *");
~~~
>[danger] 你可以修改"*"為允許跨域的域名
### 我這里增加了只允許post方式提交數據
~~~
f($this->request->isPost()){
//post提交 處理數據主代碼
}else{
//get方式 渲染提交頁面
return self::showJsonReturnCodeWithOutData(1002);
}
~~~
### 在主程序中try catch獲取異常 保證接口穩定性及記錄錯誤日志
~~~
try{
// 處理數據主代碼
}catch (Exception $e){
Log::error($e->getMessage());
return self::showJsonReturnCodeWithOutData(1008,$e->getMessage());
}
~~~
PS:如果單單是接口 完全可以省略上一步的post判斷,只需要判斷非post提交拋出異常即可
### 使用基類方法buildParam接收數據
~~~
$param_list =[
"company"=>"company/s",
"address"=>"address/s",
"contacts"=>"contacts/s",
"jobs"=>"jobs/s",
"mobile"=>"mobile/s",
"tencent_code"=>"tencent_code/s",
"desc"=>"desc/s",
"event_key"=>"event_key/d",
];
$save_data = $this->buildParam($param_list);
~~~
buildParam方法源碼參見前面課程
>[danger] 在$param_list數組中 數組的鍵值為你數據庫字段 數組的value值為接口接收時的字段
大家會發現 在值中 會有一個斜杠加上字符 如 /s /d
這個是強制轉換 這個就是第一層的數據驗證保護 不能忽略
常用的一般為 /s /d
ThinkPHP5.0版本默認的變量修飾符是/s,如果需要傳入字符串之外的變量可以使用下面的修飾符,包括:
| 修飾符號 | 轉換結果 |
| --- | --- |
| /s | 強制轉換為字符串類型 |
| /d | 強制轉換為整型類型 |
| /b | 強制轉換為布爾類型 |
| /a | 強制轉換為數組類型 |
| /f | 強制轉換為浮點類型 |
>[danger] 如果你要獲取的數據為數組,請一定注意要加上 /a 修飾符才能正確獲取到。否則報錯.
### 附加要保存的數據 (根據程序需要 可選部分)
~~~
$save_data["originate"] = preg_replace('/http(s)?:\/\//',"",$this->request->server("HTTP_ORIGIN"));
$save_data["open_id"] = $this->open_id;
~~~
這里 originate 是用戶的來源網址 open_id 為基類中獲取到的用戶身份信息
### 定義驗證類和模型類 使用editData方法保存數據
~~~
$validate_name = "base/system/SystemApply";
$model_name='base/system/SystemApply';
$result = $this->editData(false,$validate_name,$model_name,$save_data);
~~~
>[danger] 注意 我這里使用了模型分層和驗證器的分層 其中驗證器的分層 要git最新的TP5源碼才不會報錯,其中版本5.0.11及以下都會報錯的
> 另:editData源碼參見前面課程
### 判斷返回值 進行特殊處理 (根據程序需要 可選部分)
~~~
if(isset($result["code"])){
if($result["code"]==1001){
$this->sendMessageToAdmin($save_data);
}
}
return json($result);
~~~
如果 不需要額外處理什么 直接返回 editData結果即可
~~~
return $this->editData(false,$validate_name,$model_name,$save_data);
~~~
其實這樣就可以了
### 另外 該方法同樣適用數據修改
$param_list 數組中 只要添加了主鍵字段 editData方法就會執行修改操作
> 附錄:
> 模型和控制器的建立
> 參加TP5實戰開發前篇
>[info] 控制器基類之控制器基類常用方法
> http://www.hmoore.net/mikkle/thinkphp5_study/378509
>[info] 模型基類之常用數據處理方法
> http://www.hmoore.net/mikkle/thinkphp5_study/381920
>[danger] EditData快捷類庫的使用方法
>http://www.hmoore.net/mikkle/thinkphp5_study/462693
使用獨立的修改類庫 推薦使用
~~~
$paramList = [
"company" => "company/s",
"address" => "address/s",
"contacts" => "contacts/s",
"jobs" => "jobs/s",
"mobile" => "mobile/s",
"tencent_code" => "tencent_code/s",
"desc" => "desc/s",
"event_key" => "event_key/n",
];
$validate_name = "base/system/SystemApply";
$model_name = 'base/system/SystemApply';
$re = EditData::instance()
->setParameter($paramList)
->setAppend(["append" => "this is append"])
->setValidate($validate_name)
->setModel($model_name)
->save();;
return $re ? ReturnCode::jsonCode(1001) : ReturnCode::jsonCode(1003);
~~~
- 序言及更新日志
- 前言一 開發PHP必備的環境(你可以不看)
- LinUX系統ThinkPHP5鏈接MsSQL數據庫的pdo_dblib擴展
- centos7.2掛載硬盤攻略
- Centos系統Redis安裝及Redis的PHP擴展安裝
- Centos系統增加Swap(系統交換區)的方法
- 前言二 開發PHP軟件配置和介紹(你依然可以不看)
- 數據庫SQL文件
- 本地Git(版本控制)的搭建
- GIT遠程倉庫的克隆和推送
- Git常用命令
- PHP面向對象思想實戰經驗領悟
- PHP面向對象實戰----命名空間
- PHP面向對象實戰----繼承
- 基類實戰--底層方法封裝
- 基類實戰--構造函數實戰
- 基類實戰--析構函數的使用
- TP5實戰開發前篇---控制器(controller)
- 控制器中Request類的使用
- 控制器中基類的使用
- TP5實戰開發前篇---模型篇(model)
- TP5實戰開發前篇---驗證器篇(Validate)
- TP5實戰課程入門篇---花拳繡腿
- 模塊以及類的文件的建立
- Api開發------單條信息顯示
- Api開發---單條信息復雜關聯顯示
- Api開發---查詢信息緩存Cache的應用
- TP5實戰技巧---開發思路 引路造橋
- TP5實戰技巧---整合基類 化繁為簡
- TP5實戰課程入門篇---數據操作
- Api開發---數據的添加和修改
- API開發---快速開發API通用接口
- TP5專用微信sdk使用教程
- THINKPHP5微信SDK更新記錄及升級指導
- TP5專用SDK 微信參數配置方法
- 微信公眾號推送接口對接教程
- 微信推送接口對接示例含掃描登錄微信端部分
- TP5專用微信支付SDK使用簡介
- TP5專用支付寶支付SDK使用說明
- 使用NW將開發的網站打包成桌面應用
- TP5高階實戰課程 進階篇概述
- 進階篇一 實戰開發之習慣及要求
- 進階篇二 實戰開發之控制器
- 控制器基類之控制器基類使用方法
- 控制器基類之控制器基類常用方法分享
- 控制器基類之構造函數的使用方法
- 進階篇三 實戰開發之權限控制
- TP5實戰源碼 --- 全局用戶信息驗證類Auth
- TP5實戰源碼 --- 微信Auth實戰開發源碼
- 進階篇四 實戰開發之模型
- 模型基類之模型基類的用途
- 模型基類之常用數據處理方法
- 模型邏輯層之實戰代碼(含事務)
- 模型實戰開發之模型常用方法
- 模型實戰源碼 --- 樂觀鎖的應用
- 模型實戰技巧---Model事件功能的使用
- 模型事件實戰應用---數據庫操作日志
- 進階篇五 實戰開發之緩存(Cache)
- TP5實戰源碼---應用緩存獲取城市信息
- TP5實戰源碼---應用緩存獲取分類詳情
- 進階篇六 TP5類庫的封裝和使用
- DataEdit快捷操作類庫
- ShowCode快捷使用類庫
- 阿里大于 短信API接口 TP5專用類庫
- DatabaseUpgrade數據庫對比及更新類庫
- AuthWeb權限類使用說明
- 進階篇七 服務層的應用
- 服務層源碼示例
- 服務層基類源碼
- 進階篇八 應用層Redis數據處理基類
- Redis服務層基類源碼
- 進階篇九 使用Redis類庫處理一般的搶購(秒殺)活動示例
- 進階篇十 某大型項目應用本Redis類源碼示例(含事務 樂觀鎖)
- 進階篇十一 邏輯層的應用
- 邏輯層基類源碼
- 進階篇 服務層代碼示例
- 高階實戰課程 進階篇持續新增中
- 高階篇一 TP5命令行之守護任務源碼
- TP5實戰源碼 --- 命令行
- TP5實戰源碼 --- 通過shell建立PHP守護程序
- 高階篇二 使用Redis隊列發送微信模版消息
- 高階篇二 之 Worker隊列基類源碼
- 高階篇三 TP5實戰之Redis緩存應用
- Redis實戰源碼之Hash專用類庫源碼
- Redis實戰源碼之Model類結合
- Redis實戰源碼之模型Hash基類源碼
- Redis實戰源碼之Hash查詢使用技巧
- Redis實戰源碼之 shell腳本中redis賦值和取值
- 高階篇四 Swoole的實戰應用
- swoole基類代碼
- Swoole擴展WebsocketServer專用類
- 基于Swoole的多Room聊天室的程序
- Swoole守護服務shell源碼
- 高階篇五 命令行異步多進程隊列類的應用
- tp_worker類源碼
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis類
- CycleWorkBase
- WorkerHookBase異步鉤子
- 隊列日志SQL
- 高階篇六 定時執行隊列類庫以及使用方法
- 定時隊列類庫源碼
- 高階篇七 異步執行循環隊列類庫以及使用教程
- CycleWorkBase源碼
- 高階實戰課程 進階篇持續新增中
- Extend便捷類庫源碼庫
- 阿里相關類庫
- SendSms--驗證碼API接口文件
- 權限相關類庫目錄
- AuthWeb 權限驗證類庫
- Redis便捷操作類庫(20171224更新)
- Redis
- Tools工具類庫集
- Curl類庫
- DataEdit
- Rand類庫
- ShowCode類庫
- Upload類庫
- 附件集合
- 附件一:微信支付 實戰開發源碼
- 微信支付類庫源代碼
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回調頁面源碼
- 附件二 順豐快遞BSP接口實戰開發源碼
- 順豐快遞BSP接口實戰開發源碼
- 順豐BSP基類
- 順豐BSP基礎代碼
- 順豐BSP下單接口
- 順豐BSP查單接口
- 順豐BSP確認/取消接口
- 附件三 APP注冊登陸接口源碼(含融云平臺接口)
- 附件四 TP5訂單Model(含事務 獲取器 修改器等方法)
- 附錄五 RSA加密解密
- Rsa文件源碼
- 附件六 阿里大于短信接口
- 附件七 AES加解密類
- AES加解密類源碼
- 附件八 TP5路由設置源碼
- 附件九 TP5 Excel導入導出下載便捷類庫
- Excel類庫TP5源碼
- 附件十 TP5便捷操作Redis類庫源碼
- TP5源碼 Redis操作便捷類庫
- 附件十一 TP5源碼 上傳文件入庫類源碼
- 上傳類Upload源碼
- Upload類上傳配置文件
- 存儲圖像文件的數據庫SQL文件
- 存儲文件的數據庫SQL文件
- 附件十二 TP5 圖片處理增強類 支持縮略圖在線顯示
- 附件十三 微信推送消息接口類庫源碼
- 附件十三 微信推送消息接口類庫源碼 之 基類
- 附件十四 存儲微信昵稱的處理方法