2

我的服务器上只有fsockopen可以使用。我的意思是我不能使用 cURL 或 file_get_contents。顺便说一句,我正在使用PHP

我想要一个 Skype 用户名验证,所以我从另一个主题中找到了这个链接:

https://login.skype.com/json/validator?new_username=anyUserName

此页面响应为有效或无效的用户名作为 JSON 输出: {"status":200,"status_text":"valid","data":{"markup":"","alternatives":false,"fieldDetails":" "}}

它说有效,所以这个用户名不存在。我可能会解析这些数据以查看它是否正确。

我的问题是,如何使用 fsockopen 获取此 https 页面内容,我可以打开尝试读取数据的套接字,但由于我从论坛获得的许多片段而失败了太多次。因为我不知道该怎么做,即使你不会写代码也请告诉我或告诉我一个方法吗?

基本上,如何在 PHP中使用 fsockopen 返回 skype id 状态,我很高兴收到评论,在此先感谢各位。

4

1 回答 1

0

如果您的 php 中有 openssl,您应该能够在主机名或 ip 前面加上'ssl://''tls://'使用正确的端口号,而 php 应该处理其余部分。所以就像这样:

fsockopen('ssl://78.141.177.180', 443, $errno, $errstr);

并像往常一样使用返回的资源。当没有可用的 curl 时,我自己使用下面的函数(代码从php.net 评论中抢救并稍作按摩)。称之为

not_curl_get('login.skype.com/json/validator?new_username=foo', 'ssl://', 443)

函数本身:

function not_curl_get($url, $protocol = '', $port = 80, $options = array()) {
    $options = array_merge(array(
        'follow_location'      => true,
        'return_response_part' => 'body',
        'referer'              => false,
        'user_agent'           => 'Mozilla/5.0 (Windows; U; Windows NT 5.1; hu; rv:1.9.1.2) Gecko/20090729 Firefox/3.5.2 (.NET CLR 3.5.30729)',
        'cookie_file'          => false,
        'request_type'         => 'get',
    ), $options);

    global $_NOT_CURL_GET_OLDHEADER;
    $url = str_replace("http://","",$url);
    if (preg_match("#/#","$url")){
        $page = $url;
        $url = @explode("/",$url);
        $url = $url[0];
        $page = str_replace($url,"",$page);
        if (!$page || $page == ""){
            $page = "/";
        }
        $ip = gethostbyname($url);
    }else{
        $ip = gethostbyname($url);
        $page = "/";
    }
    $open = fsockopen($protocol.$ip, $port, $errno, $errstr, 60);
    if ($options['request_type'] === 'post'){
        $send = "POST $page HTTP/1.0\r\n";
    }else{
        $send = "GET $page HTTP/1.0\r\n";
    }
    $send .= "Host: $url\r\n";
    if ($options['referer']){
        $send .= "Referer: ".$options['referer']."\r\n";
    }
    if ($options['cookie_file']){
        if (@file_exists($options['cookie_file'])){
            $cookie = urldecode(@file_get_contents($options['cookie_file']));
            if ($cookie){
                $send .= "Cookie: $cookie\r\n";
                $add = @fopen($options['cookie_file'],'w');
                fwrite($add,"");
                fclose($add);
            }
        }
    }
    $send .= "Accept-Language: en-us, en;q=0.50\r\n";
    if ($options['user_agent']){
        $send .= "User-Agent: ".$options['user_agent']."\r\n";
    }
    if ($options['request_type']){
        $send .= "Content-Type: application/x-www-form-urlencoded\r\n";
        $send .= "Content-Length: " .strlen($options['request_type']) ."\r\n\r\n";
        $send .= $options['request_type'];
    }else{
        $send .= "Connection: Close\r\n\r\n";
    }
    fputs($open, $send);
    $return = '';
    while (!feof($open)) {
        $return .= fgets($open, 4096);
    }
    fclose($open);
    $return = @explode("\r\n\r\n",$return,2);
    $header = $return[0];
    if ($options['cookie_file']){
        if (preg_match("/Set\-Cookie\: /i","$header")){
            $cookie = @explode("Set-Cookie: ",$header,2);
            $cookie = $cookie[1];
            $cookie = explode("\r",$cookie);
            $cookie = $cookie[0];
            $cookie = str_replace("path=/","",$cookie[0]);
            $add = @fopen($options['cookie_file'],'a');
            fwrite($add,$cookie,strlen($read));
            fclose($add);
        }
    }
    if ($_NOT_CURL_GET_OLDHEADER){
        $header = "$_NOT_CURL_GET_OLDHEADER<br /><br />\n$header";
    }
    if ($return[1]){
        $body = $return[1];
    }else{
        $body = "";
    }
    if ($options['return_response_part'] === 'body'){
        $return = $body;
    }
    if ($options['return_response_part'] === 'head'){
        $return = $header;
    }
    if ($options['return_response_part'] === 'all'){
        $return = "$header$body";
    }
    if ($options['follow_location']){
        if (preg_match("/Location\:/","$header")){
            $url = @explode("Location: ",$header);
            $url = $url[1];
            $url = @explode("\r",$url);
            $url = $url[0];
            $_NOT_CURL_GET_OLDHEADER = str_replace("\r\n\r\n","",$header);
            $l = "&#76&#111&#99&#97&#116&#105&#111&#110&#58";
            $_NOT_CURL_GET_OLDHEADER = str_replace("Location:",$l,$_NOT_CURL_GET_OLDHEADER);
            return not_curl_get($url, $protocol, $port, $options);
        }else{
            return $return;
        }
    }else{
        return $return;
    }
}
于 2013-08-16T07:30:51.200 回答