geetest_id = $geetest_id; $this->geetest_key = $geetest_key; } //验证初始化 public function pre_process($params) { if(!empty($this->geetest_id) && !empty($this->geetest_key)){ return $this->pre_process_api($params); }else{ return $this->pre_process_demo($params); } } private function pre_process_api($params) { $public_params = [ 'digestmod' => 'md5', 'gt' => $this->geetest_id, 'sdk' => self::SDK_VERSION, 'json_format' => self::JSON_FORMAT ]; $params = array_merge($params, $public_params); $url = 'https://api.geevisit.com/register.php?' . http_build_query($params); $res = get_curl($url); $arr = json_decode($res, true); if($arr && isset($arr['challenge'])){ return $this->success_process($arr['challenge']); }else{ return $this->failback_process(); } } private function success_process($challenge) { $challenge = md5($challenge . $this->geetest_key); $result = array( 'success' => 1, 'gt' => $this->geetest_id, 'challenge' => $challenge, 'new_captcha'=>true ); return $result; } private function failback_process() { $challenge = md5(uniqid(mt_rand(), true) . microtime()); $result = array( 'success' => 0, 'gt' => !empty($this->geetest_id) ? $this->geetest_id : 'e10adc3949ba59abbe56e057f20f883e', 'challenge' => $challenge, 'new_captcha'=>true ); return $result; } private function pre_process_demo($params) { $url = 'https://www.geetest.com/demo/gt/register-fullpage?t=' . time() . "123"; $referer = 'https://www.geetest.com/demo/slide-popup.html'; $data = get_curl($url, 0, $referer); $arr = json_decode($data, true); if($arr && isset($arr['challenge'])){ return $arr; }else{ return $this->failback_process(); } } //正常流程下(即验证初始化成功),二次验证 public function success_validate($challenge, $validate, $seccode, $params) { if(!empty($this->geetest_id) && !empty($this->geetest_key)){ return $this->success_validate_api($challenge, $validate, $seccode, $params); }else{ return $this->success_validate_demo($challenge, $validate, $seccode); } } private function success_validate_api($challenge, $validate, $seccode, $params) { if (!$this->check_validate($challenge, $validate)) { return false; } $public_params = [ 'seccode' => $seccode, 'challenge' => $challenge, 'captchaid' => $this->geetest_id, 'sdk' => self::SDK_VERSION, 'json_format' => self::JSON_FORMAT ]; $params = array_merge($params, $public_params); $url = 'https://api.geevisit.com/validate.php'; $res = get_curl($url, http_build_query($params)); $arr = json_decode($res, true); if($arr && isset($arr['seccode'])){ if($arr['seccode'] == md5($seccode)){ return true; } } return false; } private function check_validate($challenge, $validate) { if (strlen($validate) != 32) { return false; } if (md5($this->geetest_key . 'geetest' . $challenge) != $validate) { return false; } return true; } private function success_validate_demo($challenge, $validate, $seccode) { $params = [ 'geetest_challenge' => $challenge, 'geetest_validate' => $validate, 'geetest_seccode' => $seccode ]; $url = 'https://www.geetest.com/demo/gt/validate-fullpage'; $referer = 'https://www.geetest.com/demo/slide-popup.html'; $data = get_curl($url, http_build_query($params), $referer); $arr = json_decode($data, true); if($arr && $arr['status'] == 'success'){ return true; } return false; } //异常流程下(即验证初始化失败,宕机模式),二次验证 public function fail_validate($challenge, $validate, $seccode) { if(md5($challenge) == $validate){ return true; }else{ return false; } } public function gt4_validate($captcha_id, $lot_number, $pass_token, $gen_time, $captcha_output) { if(!empty($this->geetest_id) && !empty($this->geetest_key)){ return $this->gt4_validate_api($captcha_id, $lot_number, $pass_token, $gen_time, $captcha_output); }else{ return $this->gt4_validate_demo($captcha_id, $lot_number, $pass_token, $gen_time, $captcha_output); } } private function gt4_validate_api($captcha_id, $lot_number, $pass_token, $gen_time, $captcha_output){ $url = 'http://gcaptcha4.geetest.com/validate?captcha_id='.$captcha_id; $param = [ 'lot_number' => $lot_number, 'pass_token' => $pass_token, 'gen_time' => $gen_time, 'captcha_output' => $captcha_output ]; $param['sign_token'] = hash_hmac('sha256', $param['lot_number'], $this->geetest_key); $data = get_curl($url, http_build_query($param)); $arr = json_decode($data, true); if(isset($arr['status']) && $arr['status']=='success'){ if(isset($arr['result']) && $arr['result'] == 'success'){ return true; } } return false; } private function gt4_validate_demo($captcha_id, $lot_number, $pass_token, $gen_time, $captcha_output){ global $clientip; $url = 'http://gt4.geetest.com/demov4/demo/login'; $param = [ 'captcha_id' => $captcha_id, 'lot_number' => $lot_number, 'pass_token' => $pass_token, 'gen_time' => $gen_time, 'captcha_output' => $captcha_output ]; $referer = 'http://gt4.geetest.com/demov4/invisible-bind-zh.html'; $httpheader[] = "X-Real-IP: ".$clientip; $httpheader[] = "X-Forwarded-For: ".$clientip; $data = get_curl($url.'?'.http_build_query($param),0,$referer,0,0,0,0,$httpheader); $arr = json_decode($data, true); if(isset($arr['result']) && $arr['result'] == 'success'){ return true; } return false; } }