<?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); ?>