2016-08-01 47 views
0

我使用PHP开发了一个脚本,我使用命令php index.php与控制台一起使用。不要使用PHP命令和cURL显示日志

在此脚本中,我使用cURL查询服务器。

问题是我的脚本在控制台上显示日志,我只是想要echo的结果。

你有想法隐藏这些日志吗?在这个地址找到

// GET TOKEN 
// ///////////////////////////////////////////////////////////////////////////// 
$url = "some/url"; 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_URL, $url); 
curl_setopt($ch, CURLOPT_USERPWD, "$user:$pwd"); 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_VERBOSE, 1); 
curl_setopt($ch, CURLOPT_HEADER, 1); 
$data = curl_exec($ch); 
$location = ""; 
preg_match_all('/^Location:(.*)$/mi', $data, $location); 
$location = trim($location[1][0]); 
$location = parse_url($location); 
parse_str($location['query'], $attrs); 
$token = $attrs['code']; 

if(isset($token)) { 

    // GET CONNEXION 
    // ///////////////////////////////////////////////////////////////////////// 
    $url = "some/url"; 
    $post_data = ['code' => $token, 'grant_type' => 'authorization_code']; 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_POST, true); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_USERPWD, "$client_id:$client_secret"); 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    $data = json_decode(curl_exec($ch)); 
    $connexion = isset($data->access_token) ? $data->access_token : $data->error_description; 

    // GET LOGIN 
    // ///////////////////////////////////////////////////////////////////////// 
    $url = "some/url"; 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    $data = curl_exec($ch); 
    $data = json_decode($data); 
    // $login = json_encode(['public' => $data->api_keys[1]->public, 'secret' => $data->api_keys->secret]); 

    // REQUEST 
    // ///////////////////////////////////////////////////////////////////////// 
    $url = $request . "?externalId=".$external_id."&externalSource=".$external_source; 
    date_default_timezone_set("Europe/Paris"); 
    $nonce = generateRandomString(); 
    file_put_contents('php://stderr', print_r("Set random nonce to " . $nonce . "\n", TRUE)); 
    $created = date("Y-m-dTH:i:sP"); 
    $created = date("Y-m-dTH:i:sP"); 
    $username = $data->api->public; 
    $secret = $data->api->secret; 
    $pwd_digest = base64_encode(sha1($nonce.$created.$secret)); 
    $auth_header = "X-WSSE: UsernameToken Username=\"$username\", PasswordDigest=\"$pwd_digest\", Nonce=\"$nonce\", Created=\"$created\""; 
    $header = array($auth_header, 'Accept: something', 'Accept-Language: en'); 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_HTTPHEADER, $header); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
    $data = curl_exec($ch); 
    $data = json_decode($data); 
    echo $data->nbNqPoints; 

} else { 
    echo "0"; 
} 
+0

因为每个站点必须使用各种方式处理。所以你可以提供你的$ url和任何你可以提供的东西,所以我们可以帮助你! –

+0

我不知道它是否有关系,但是在你设置CURLOPT_RETURNTRANSFER的地方,尝试将它设置为'true'而不是1. –

+1

你可以使用一个小小的ob_start(); ob_get_clean();通过它破解 – hanshenrik

回答