# 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] 控制器基类之控制器基类常用方法
> https://www.kancloud.cn/mikkle/thinkphp5_study/378509
>[info] 模型基类之常用数据处理方法
> https://www.kancloud.cn/mikkle/thinkphp5_study/381920
>[danger] EditData快捷类库的使用方法
>https://www.kancloud.cn/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 图片处理增强类 支持缩略图在线显示
- 附件十三 微信推送消息接口类库源码
- 附件十三 微信推送消息接口类库源码 之 基类
- 附件十四 存储微信昵称的处理方法