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://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);
?>
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM