curl 模拟浏览器请求,比如获取远程浏览器内容,虽然可以用file_get-contents来代替,但curl还支持浏览器类型,cookie和来源ip等,功能相比强大
常用相关函数
curl_init() 初始化curl会话
curl_setopt() 设置curl传输选项
curl_exec 执行curl会话
curl_errno 返回最后一次的错误代码
curl_error 返回当前会话嘴周一次错误的字符串
curl_close 关闭curl会话
- function getCurl($url,$cookie = null,$post_data = null,$miao = null){
- $ch = curl_init();
- curl_setopt($ch, CURLOPT_URL, $url);
- curl_setopt($ch, CURLOPT_HEADER, false);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
- if($cookie)
- {
- if($cookie =='auto')
- {
- $cookie_string = '';
- $_COOKIE['user_id'] = 12;
- foreach($_COOKIE as $key=>$val)
- {
- $cookie_string .= $key.'='.$val.';';
- }
- curl_setopt($ch, CURLOPT_COOKIE,$cookie_string);
- }
- elseif(is_array($cookie) && $cookie['type']=='cookie_file')
- {
- //echo $cookie['value'];
- curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie['value']);
- curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie['value']);
- }
- else
- {
- curl_setopt($ch, CURLOPT_COOKIE,$cookie);
- }
- }
- if($post_data)
- {
- curl_setopt($ch, CURLOPT_POST, 1);
- // 把post的变量加上
- curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
- }
- //判断超时处理
- if(!empty($miao)){
- curl_setopt($ch, CURLOPT_NOSIGNAL, 1); //注意,毫秒超时一定要设置这个
- curl_setopt($ch, CURLOPT_TIMEOUT_MS, $miao); //超时毫秒,cURL 7.16.2中被加入。从PHP 5.2.3起可使用
- $head = curl_exec($ch);
- $curl_errno = curl_errno($ch);
- $curl_error = curl_error($ch);
- if($curl_errno>0){
- $head = '2';
- }else{
- $head = $head;
- }
- }else{
- $head = curl_exec($ch);
- }
- //$head = curl_exec($ch);
- //echo $url;echo 'bb';var_dump($head);exit;
- $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
- curl_close($ch);
- return $head;
- }
该方法相比于file_get_contents最大的不同,就是可以将远程的cookie信息也获得过来,这种情况适合于跨站的登录信息的同步。比如你在www.demo.com下登录,然后到music.demo.com下应该也会是登录状态,那怎样实现这种情况呢?
在www下登录成功之后,将cookie信息保留一份,然后在music下通过curl方式获得cookie信息,因为cookie相对来说不安全,所以在www下可以不把重要信息放到cookie中而只把标志用户登录的信息放入其中,比如用户id,到了music中,用户通过id在进行登录即可,仍然将用户信息取出进行登录的操作。
那么问题来了了,既然在www下登录了在music也是登录状态,那在music下登录了在www下也应该是登录状态的,在其他子站下应该也是登录状态的,所以,对于有多个子站的情况,我们应该讲用户登录信息的处理放在一个公共的站点下面。每次都通过这里来操作,而且,登录后的用户信息应该放到memcached等缓存中,因为很明显登录操作是一个操作频繁的动作,应该减少用户频繁读取数据库带来的压力。