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"  οnclick="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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值