<?php
ini_set(
'display_errors',
1);
//错误信息
ini_set(
'display_startup_errors',
1);
//php启动错误信息
ini_set(
'date.timezone',
'Asia/Shanghai');
error_reporting(-
1);
//打印出所有的 错误信息
ini_set(
'error_log',
dirname(
__FILE__) .
'/error_log----------------.txt');
//将出错信息输出到一个文本文件
/**
* 接受用户登陆时提交的验证码
* //1. 获取到用户提交的验证码
* //2. 将session中的验证码和用户提交的验证码进行核对,当成功时提示验证码正确,并销毁之前的session值,不成功则重新提交
* // strtolower() 转小写
*/
session_start();
$dataObj =
json_decode(
$HTTP_RAW_POST_DATA);
$code =
'';
$data =
$dataObj->
captcha;
$msg =
'';
if(
strtolower(
$_SESSION[
"captcha"]) !=
strtolower(
$dataObj->
captcha)){
$code =
'-2';
$msg =
'不正确- '.
strtolower(
$_SESSION[
"captcha"]);
}
else{
$code =
'2';
$msg =
'正确';
$jsonData =
json_encode(
array(
'custName' =>
$dataObj->
custName,
'contName' =>
$dataObj->
contName,
'mobile' =>
$dataObj->
mobile,
'mailAddress' =>
$dataObj->
mailAddress,
'web' =>
$dataObj->
web,
'fax' =>
$dataObj->
fax,
'tel' =>
$dataObj->
tel,
'addr' =>
$dataObj->
addr,
'remarks' =>
$dataObj->
remarks,
));
$url=
'https://aapi.baidu.com/v2/officialWebsite/enquiry';
$data =
post_curls(
$url,
$jsonData);
//返回json
}
$json =
array (
'code'=>
$code,
'data'=>
$data,
'msg'=>
$msg
);
echo
json_encode(
$json);
/**
* POST请求https接口返回内容
*
@param
string
$url [请求的URL地址]
*
@param
string
$post [请求的参数]
*
@return
string
*/
function
post_curls(
$url,
$data){
// 模拟提交数据函数
$curl =
curl_init();
// 启动一个CURL会话
curl_setopt(
$curl, CURLOPT_URL,
$url);
// 要访问的地址
curl_setopt(
$curl, CURLOPT_SSL_VERIFYPEER,
0);
// 对认证证书来源的检查
// curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在
curl_setopt(
$curl, CURLOPT_USERAGENT,
$_SERVER[
'HTTP_USER_AGENT']);
// 模拟用户使用的浏览器
curl_setopt(
$curl, CURLOPT_FOLLOWLOCATION,
1);
// 使用自动跳转
curl_setopt(
$curl, CURLOPT_AUTOREFERER,
1);
// 自动设置Referer
curl_setopt(
$curl, CURLOPT_POST,
1);
// 发送一个常规的Post请求
curl_setopt(
$curl, CURLOPT_POSTFIELDS,
$data);
// Post提交的数据包
curl_setopt(
$curl, CURLOPT_TIMEOUT,
30);
// 设置超时限制防止死循环
curl_setopt(
$curl, CURLOPT_HEADER,
0);
// 显示返回的Header区域内容
curl_setopt(
$curl, CURLOPT_RETURNTRANSFER,
1);
// 获取的信息以文件流的形式返回
$tmpInfo =
curl_exec(
$curl);
// 执行操作
if (
curl_errno(
$curl)) {
echo
'Errno'.
curl_error(
$curl);
//捕抓异常
}
curl_close(
$curl);
// 关闭CURL会话
return
$tmpInfo;
// 返回数据,json格式
}
?
>
// code example

// html input 加验证码 <input type="text" name="captcha" id="captcha" placeholder="验证码" maxlength="10"> <img src="captcha.php" onclick="this.src='captcha.php?' + Math.random();" width="105" height="36"> // jquery ajax $('#btn_submit').click(function () { var url = 'api.php/?action=reg'; var dataObj = {"mobile": "", "addr": "", "remarks": "" } // console.log(dataObj) $.ajax({ type: "POST", url: url, contentType: "application/json; charset=utf-8", data: JSON.stringify(dataObj), dataType: "json", success: function (message) { console.log(message) if (message.code == '2') { $('#registerWrap .reg_success').show(); }else{ } }, error: function (message) { console.log(message) alert('注册失败'); } }); }) // api.php <?php ini_set('display_errors',1); //错误信息 ini_set('display_startup_errors',1); //php启动错误信息 ini_set('date.timezone','Asia/Shanghai'); error_reporting(-1); //打印出所有的 错误信息 ini_set('error_log', dirname(__FILE__) . '/error_log----------------.txt'); //将出错信息输出到一个文本文件 /** * 接受用户登陆时提交的验证码 * //1. 获取到用户提交的验证码 * //2. 将session中的验证码和用户提交的验证码进行核对,当成功时提示验证码正确,并销毁之前的session值,不成功则重新提交 * // strtolower() 转小写 */ session_start(); $dataObj = json_decode($HTTP_RAW_POST_DATA); $code = ''; $data = $dataObj->captcha; $msg = ''; if(strtolower($_SESSION["captcha"]) != strtolower($dataObj->captcha)){ $code = '-2'; $msg = '不正确- '.strtolower($_SESSION["captcha"]); }else{ $code = '2'; $msg = '正确'; $jsonData = json_encode(array( 'custName' => $dataObj->custName, 'contName' => $dataObj->contName, 'mobile' => $dataObj->mobile, 'mailAddress' => $dataObj->mailAddress, 'web' => $dataObj->web, 'fax' => $dataObj->fax, 'tel' => $dataObj->tel, 'addr' => $dataObj->addr, 'remarks' => $dataObj->remarks, )); $url='https://api.baidu.com/v2/officialWebsite/enquiry'; // 跨域第三方接口 $data = post_curls($url,$jsonData);//返回json } $json = array ( 'code'=>$code, 'data'=>$data, 'msg'=>$msg ); echo json_encode($json); /** * POST请求https接口返回内容 * @param string $url [请求的URL地址] * @param string $post [请求的参数] * @return string */ function post_curls($url,$data){ // 模拟提交数据函数 $curl = curl_init(); // 启动一个CURL会话 curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查 // curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在 curl_setopt($curl, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); // 模拟用户使用的浏览器 curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转 curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer curl_setopt($curl, CURLOPT_POST, 1); // 发送一个常规的Post请求 curl_setopt($curl, CURLOPT_POSTFIELDS, $data); // Post提交的数据包 curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环 curl_setopt($curl, CURLOPT_HEADER, 0); // 显示返回的Header区域内容 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回 $tmpInfo = curl_exec($curl); // 执行操作 if (curl_errno($curl)) { echo 'Errno'.curl_error($curl);//捕抓异常 } curl_close($curl); // 关闭CURL会话 return $tmpInfo; // 返回数据,json格式 } ?> // captcha.php <?php /** * 字母+数字的验证码生成 */ // 开启session session_start(); //1.创建黑色画布 $image = imagecreatetruecolor(100, 30); //2.为画布定义(背景)颜色 $bgcolor = imagecolorallocate($image, 255, 255, 255); //3.填充颜色 imagefill($image, 0, 0, $bgcolor); // 4.设置验证码内容 //4.1 定义验证码的内容 $content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"; //4.1 创建一个变量存储产生的验证码数据,便于用户提交核对 $captcha = ""; for ($i = 0; $i < 4; $i++) { // 字体大小 $fontsize = 10; // 字体颜色 $fontcolor = imagecolorallocate($image, mt_rand(0, 120), mt_rand(0, 120), mt_rand(0, 120)); // 设置字体内容 $fontcontent = substr($content, mt_rand(0, strlen($content)), 1); $captcha .= $fontcontent; // 显示的坐标 $x = ($i * 100 / 4) + mt_rand(5, 10); $y = mt_rand(5, 10); // 填充内容到画布中 imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor); } $_SESSION["captcha"] = $captcha; //4.3 设置背景干扰元素 for ($$i = 0; $i < 200; $i++) { $pointcolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imagesetpixel($image, mt_rand(1, 99), mt_rand(1, 29), $pointcolor); } //4.4 设置干扰线 for ($i = 0; $i < 3; $i++) { $linecolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200)); imageline($image, mt_rand(1, 99), mt_rand(1, 29), mt_rand(1, 99), mt_rand(1, 29), $linecolor); } //5.向浏览器输出图片头信息 header('content-type:image/png'); //6.输出图片到浏览器 imagepng($image); //7.销毁图片 imagedestroy($image); ?>