file file_get_contents HTTP request failed

 更新时间:2016年11月25日 15:54  点击:2168

/*
我有一个问题,要求从php教程代码的url。我需要调用一个服务,使用从我的php代码的查询字符串。如果我的浏览器中键入一个网址,它工作还算可以,但如果我使用文件获取,内容()来拨打电话,我得到:

 代码如下 复制代码
$query=file_get_contents('http://www.111cn.net');
echo($query);

可能出现问题有三种

一、php.ini 的allow_url_fopen选项是不是开着的?如果是off就不能访问了,把它变成on.
二、php.ini开启了安全模式
三、机器装了防火强

其它解决方法

*/

 

 代码如下 复制代码
$curl_handle=curl_init();
curl_setopt($curl_handle, curlopt_url,'http://www.111cn.net');
curl_setopt($curl_handle, curlopt_connecttimeout, 2);
curl_setopt($curl_handle, curlopt_returntransfer, 1);
curl_setopt($curl_handle, curlopt_useragent, 'your application name');
$query = curl_exec($curl_handle);
curl_close($curl_handle);

缓存技术:   
有些信息比方经常不变的,但是还是能变的信息放在缓存中以加快显示速度,这是很有价值的,所谓的缓存,通俗的理解就是一些保存在服务器端的共用信息.它是于服务器同生死的,我们在保存缓存的时候可以指定下次更新的时间的判断,比方要在5分钟更新一次,可以记录上次更新的时间,和当前时间比较,如果大于 5 分钟 ,读取数据库教程,更新换成,否则直接读取缓存数据,当然,缓存需要客户端用户激活的,只需一次.
ob_start()函数:打开输出缓冲区.
     函数格式 void ob_start(void)
     说明:当缓冲区激活时,所有来自php教程程序的非文件头信息均不会发送,而是保存在内部缓冲区。为了输出缓冲区的内容,可以使用ob_end_flush()或flush()输出缓冲区的内容。
flush:刷新缓冲区的内容,输出。
     函数格式:flush()
     说明:这个函数经常使用,效率很高。
ob_get_contents :返回内部缓冲区的内容。
     函数格式:string ob_get_contents(void)
     说明:这个函数会返回当前缓冲区中的内容,如果输出缓冲区没有激活,则返回 false.
ob_get_length:返回内部缓冲区的长度。
     函数格式:int ob_get_length(void)
     说明:这个函数会返回当前缓冲区中的长度;和ob_get_contents一样,如果输出缓冲区没有激活,则返回 false.
ob_end_clean:删除内部缓冲区的内容,并且关闭内部缓冲区
     函数格式:void ob_end_clean(void)
     说明:这个函数不会输出内部缓冲区的内容而是把它删除
ob_end_flush:发送内部缓冲区的内容到浏览器,并且关闭输出缓冲区
     函数格式:void ob_end_flush(void)
     说明:这个函数发送输出缓冲区的内容(如果有的话)
ob_implicit_flush:打开或关闭绝对刷新
     函数格式:void ob_implicit_flush ([int flag])
     说明:默认为关闭缓冲区,打开绝对输出后,每个脚本输出都直接发送到浏览器,不再需要调用 flush()   
二、文件写入:    

 

/*
setcookie()函数定义一个cookie被发送的http头的其余部分一起。像其他头,饼干之前,必须发送从你的脚本(这是一个协议限制输出)。这就需要你的地方调用这个函数之前,任何输出,包括<html>和<head>标签以及任何空格。

一旦饼干已经确定,他们可以访问下一页上加载了$ _cookie或$ http_cookie_vars数组。请注意,如超全局变量$ _cookie形式适用于php的4.1.0。 cookie的值也存在于$ _request数组。

 代码如下 复制代码
bool setcookie ( string $name [, string $value [, int $expire = 0 [, string $path [, string $domain [, bool $secure = false [, bool $httponly = false ]]]]]] )

*/

 代码如下 复制代码

function makecookie($var, $value, $life = 0, $prefix = 0) //设置cookie
{
 global $cookiepre, $cookiedomain, $cookiepath, $timestamp, $_server;
 setcookie(($prefix ? $cookiepre : '').$var, $value,
 $life ? $timestamp + $life : 0, $cookiepath,
 $cookiedomain, $_server['server_port'] == 443 ? 1 : 0);
}

function clearcookies() //清除cookie
{
 global $uid, $username, $pw, $adminid;
 makecookie('auth', '', -86400 * 365);
 $uid = $adminid = 0;
 $username = $pw = '';
}

//实例

 代码如下 复制代码

makecookie('111','www.111cn.net');
//清除cookie
clearcookies();

//下面兴一个支持二级域名cookie函数吧。

function setcookielive($name, $value='', $expire=0, $path='', $domain='', $secure=false, $httponly=false) {
    //set a cookie as usual, but also add it to $_cookie so the current page load has access
    $_cookie[$name] = $value;
    return setcookie($name,$value,$expire,$path,$domain,$secure,$httponly);
}

//调用方法

 代码如下 复制代码

setcookielive('webab','111cn',time()+86000,'/','111cn.net');

//一入门级cookie设置方法

setcookie("cookie[three]", "cookiethree");
setcookie("cookie[two]", "cookietwo");
setcookie("cookie[one]", "cookieone");

// after the page reloads, print them out
if (isset($_cookie['cookie'])) {
    foreach ($_cookie['cookie'] as $name => $value) {
        echo "$name : $value <br /> ";
    }

 代码如下 复制代码
function ihtmlspecialchars($string)
{
 if(is_array($string))
 {
  foreach($string as $key => $val)
  {
   $string[$key] = ihtmlspecialchars($val);
  }
 } else
 {
  $string = preg_replace('/&amp;((#(d{3,5}|x[a-fa-f0-9]{4})|[a-za-z][a-z0-9]{2,5});)/', '&\1',
  str_replace(array('&', '"', '<', '>'), array('&amp;', '&quot;', '&lt;', '&gt;'), $string));
 }
 return $string;
}

//实例

 代码如下 复制代码

$str = '<a href="www.111cn.net">dfdfd</a>';
echo ihtmlspecialchars( $str );
echo '<br >';

//echo &lt;a href=&quot;www.111cn.net&quot;&gt;dfdfd&lt;/a&gt; 这样就可防止一些不安全因素了。

echo htmlspecialchars ($str );

//print &lt;a href=&quot;www.111cn.net&quot;&gt;dfdfd&lt;/a&gt;

/*
两个结果完全相同,所以个人觉得自php自带的函数高效于用户自定义函数
*/
?>

/*

 代码如下 复制代码
int preg_match_all ( string $pattern , string $subject , array &$matches [, int $flags [, int $offset ]] );

搜索所有匹配正则表达式的模式并提出给予他们在比赛中受的标志指定的顺序。第一场比赛后发现,随后的搜查是继续从最后一场比赛结束。

实例

 代码如下 复制代码
preg_match_all("|<[^>]+>(.*)</[^>]+>|u",
    "<b>example: </b><div align=left>this is a test</div>",
    $out, preg_pattern_order);
echo $out[0][0] . ", " . $out[0][1] . " ";
echo $out[1][0] . ", " . $out[1][1] . " ";

出输

 代码如下 复制代码

<b>example: </b>, <div align=left>this is a test</div>
example: , this is a test


preg_match_all("|<[^>]+>(.*)</[^>]+>|u",
    "<b>example: </b><div align="left">this is a test</div>",
    $out, preg_set_order);
echo $out[0][0] . ", " . $out[0][1] . " ";
echo $out[1][0] . ", " . $out[1][1] . " ";

 

int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags [, int $offset ]]] )
搜索主题的经常表达的方式给予配合


$subject = "abcdefwww.111cn.net";
$pattern = '/^def/';
preg_match($pattern, substr($subject,3), $matches, preg_offset_capture);
print_r($matches);


array
(
    [0] => array
        (
            [0] => def
            [1] => 0
        )

)


*/

[!--infotagslink--]

相关文章