diff --git a/app/controllers/SmsController.php b/app/controllers/SmsController.php index 9b9c434..847a666 100644 --- a/app/controllers/SmsController.php +++ b/app/controllers/SmsController.php @@ -20,7 +20,9 @@ class SmsController extends ControllerBase{ //$url = "http://wxapp.wemediacn.com/smsoauth2_qa/api/sms/send"; //$url = "http://127.0.0.1/tiffany/api/sms/send?qaz=wsx"; //$url = "http://wxapp.wemediacn.com/smsoauth2_qa/api/sms/authcode"; - $url = "http://127.0.0.1/tiffany/api/sms/authcode?qaz=wsx"; + //$url = "http://127.0.0.1/tiffany/api/sms/authcode?qaz=wsx"; + $url = "http://wxapp.wemediacn.com/smsoauth2_qa/api/sms/query_reports"; + //$url = "http://127.0.0.1/tiffany/api/sms/query_reports?qaz=wsx"; $post_arr = array(); $post_arr['appid'] = ""; $post_arr['mobile'] = ""; @@ -30,6 +32,7 @@ class SmsController extends ControllerBase{ $post_arr['len'] = ""; $post_arr['type'] = ""; $post_arr['is_resend'] = ""; + $post_arr['min_id'] = ""; $post_json = json_encode($post_arr); $result = $this->__http_post_request($url, $post_json, true); print_r($result); die; @@ -433,7 +436,7 @@ class SmsController extends ControllerBase{ $type = in_array($type, array(1, 2))?$type:1; //获取是否重发旧验证码 $is_resend = isset($request_arr['is_resend'])?$request_arr['is_resend']:false; - $is_resend = in_array($is_resend, array(true, false)?$is_resend:false; + $is_resend = in_array($is_resend, array(true, false))?$is_resend:false; } } } @@ -451,7 +454,172 @@ class SmsController extends ControllerBase{ * http://127.0.0.1/tiffany/api/sms/query_reports?qaz=wsx */ function queryReportsAction(){ - + //如果是GET请求 + if($this->request->isGet()){ + //告知请求的资源不支持 http 方法“GET”。 + $rs['Message'] = "请求的资源不支持 http 方法“GET”。"; + } + //如果未获取到请求数据 + elseif(empty(file_get_contents("php://input"))){ + //告知用户系统繁忙,请稍候再试 + $rs['errcode'] = -1; + $rs['errmsg'] = "系统繁忙,请稍候再试"; + $rs['data'] = null; + } + //如果有获取到请求数据 + else{ + //准备判断请求数据整体是否为空 + $request_arr = json_decode(file_get_contents("php://input"), true); + //如果请求数据整体为空 + if(empty($request_arr)){ + //告知用户系统繁忙,请稍候再试 + $rs['errmsg'] = "系统繁忙,请稍候再试"; + $rs['errcode'] = -1; + $rs['data'] = null; + } + //如果请求数据整体不为空 + else{ + //准备获取appid和access_token + $rs['errmsg'] = ""; + //如果未获取到appid + if(empty($request_arr['appid'])){ + //告知用户appid is empty; + $rs['errmsg'].= "appid is empty;"; + } + //如果未获取到access_token + if(empty($request_arr['access_token'])){ + //告知用户access_token is empty; + $rs['errmsg'].= "access_token is empty;"; + } + //如果以上判断未通过 + if(!empty($rs['errmsg'])){ + //告知用户参数错误 error detail: + $rs['errmsg'] = "参数错误 error detail:".$rs['errmsg']; + $rs['errcode'] = 61451; + $rs['data'] = null; + } + //如果以上判断都通过 + else{ + //准备判断appid是否有效 + $appid = $request_arr['appid']; + //查询接口信息 + $AppInfo = AppInfo::findFirst("AppId = '$appid' AND Enable = 0"); + //如果未查询到接口信息 + if(empty($AppInfo)){ + //告知用户找不到app配置信息,appid无效,err detail:找不到app配置信息 + $rs['errmsg'] = "找不到app配置信息,appid无效,err detail:找不到app配置信息"; + $rs['errcode'] = 40036; + $rs['data'] = null; + } + //如果有查询到接口信息 + else{ + //获取上次请求日期 + $last_req_time = $AppInfo->LastReqTime; + $last_req_date = date("Y-m-d", strtotime($last_req_time)); + //获取当前时间及当天日期 + $current_time = time(); + $current_datetime = date("Y-m-d H:i:s", $current_time); + $current_date = date("Y-m-d", $current_time); + //获取上次请求日期所在日的请求次数 + $today_req_times = $AppInfo->TodayReqTimes; + //获取接口请求次数限制 + $day_max_req_times = $AppInfo->DayMaxReqTimes; + //如果上次请求日期是当天日期 + if($last_req_date==$current_date){ + //如果当天请求次数已达到接口请求次数限制 + if($today_req_times>=$day_max_req_times){ + //告知用户request today reached the request limit,err detail:超过请求上限限制 + $rs['errmsg'] = "request today reached the request limit,err detail:超过请求上限限制"; + $rs['errcode'] = 80102; + $rs['data'] = null; + } + //如果当天请求次数尚未达到接口请求次数限制 + else{ + //当天请求次数加一 + $today_req_times = $today_req_times+1; + } + } + //如果上次请求日期不是当天日期 + else{ + //如果接口请求次数限制不大于0 + if($day_max_req_times<=0){ + //告知用户request today reached the request limit,err detail:超过请求上限限制 + $rs['errmsg'] = "request today reached the request limit,err detail:超过请求上限限制"; + $rs['errcode'] = 80102; + $rs['data'] = null; + } + //如果接口请求次数限制大于0 + else{ + //初始当天请求次数 + $today_req_times = 1; + } + } + //如果以上判断都通过 + if(empty($rs['errcode'])){ + //准备更新当天请求次数 + $AppInfo->LastModifiedTime = $current_datetime; + //其他字段 + $AppInfo->TodayReqTimes = $today_req_times; + $AppInfo->LastReqTime = $current_date; + //如果更新失败 + if(!($AppInfo->save())){ + //告知用户系统繁忙,请稍候再试 + $rs['errmsg'] = "系统繁忙,请稍候再试"; + $rs['errcode'] = -1; + $rs['data'] = null; + } + //如果更新成功 + else{ + //准备判断access_token是否有效 + $access_token = $request_arr['access_token']; + //查询接口信息 + $AccessToken = AccessToken::findFirst("AppId = '$appid' AND (AccessToken = '$access_token' OR PrevAccessToken = '$access_token')"); + //如果未查询到接口信息 + if(empty($AccessToken)){ + //告知用户accesstoken 不正确,err detail:找不到accesstoken信息 + $rs['errmsg'] = "accesstoken 不正确,err detail:找不到accesstoken信息"; + $rs['errcode'] = 40039; + $rs['data'] = null; + } + //如果有查询到接口信息 + else{ + //获取现access_token到期时间 + $ExpireTime = $AccessToken->ExpireTime; + //获取前access_token到期时间 + $PrevExpireTime = date("Y-m-d H:i:s", strtotime($AccessToken->ExpireTime)-14400+600); + //如果access_token匹配前access_token + if($access_token==$AccessToken->PrevAccessToken){ + //如果前access_token已过期 + if($current_datetime>$PrevExpireTime){ + //告知用户access_token is expired,err detail:accesstoken 已过期 + $rs['errmsg'] = "access_token is expired,err detail:accesstoken 已过期"; + $rs['errcode'] = 80105; + $rs['data'] = null; + } + } + //如果access_token匹配现access_token + else{ + //如果现access_token已过期 + if($current_datetime>$ExpireTime){ + //告知用户access_token is expired,err detail:accesstoken 已过期 + $rs['errmsg'] = "access_token is expired,err detail:accesstoken 已过期"; + $rs['errcode'] = 80105; + $rs['data'] = null; + } + } + //如果以上判断都通过 + if(empty($rs['errcode'])){ + + } + } + } + } + } + } + } + } + //输出结果 + echo json_encode($rs, JSON_UNESCAPED_UNICODE); } }