這是一個函數,還能夠在精煉,如下是代碼php
<?php //var_dump($_SERVER);exit; $cookie_file = tempnam('./temp','cookie'); //建立cookie文件保存的位置 //echo $cookie_file;exit; function curl($url,$data=array(),$method,$setcooke=false,$cookie_file=false){ $ch = curl_init(); //1.初始化 curl_setopt($ch, CURLOPT_URL, $url); //2.請求地址 curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);//3.請求方式 //4.參數以下 禁止服務器端的驗證 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); //假裝請求來源,繞過防盜 //curl_setopt($ch,CURLOPT_REFERER,"http://wthrcdn.etouch.cn/"); //配置curl解壓縮方式(默認的壓縮方式) curl_setopt($ch, CURLOPT_HTTPHEADER, array('Accept-Encoding:gzip')); curl_setopt($ch, CURLOPT_ENCODING, "gzip"); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0'); //指明以哪一種方式進行訪問 curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_AUTOREFERER, 1); if($method=="POST"){//5.post方式的時候添加數據 curl_setopt($ch, CURLOPT_POSTFIELDS, $data); } if($setcooke==true){ //若是設置要請求的cookie,那麼把cookie值保存在指定的文件中 curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file); }else{ //就從文件中讀取cookie的信息 curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file); } curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $tmpInfo = curl_exec($ch); if (curl_errno($ch)) { return curl_error($ch); } curl_close($ch); return $tmpInfo; } /* //模擬get請求 $url="https://www.taobao.com/"; $str=curl($url,array(),'GET'); //echo $str; //post請求 $url="http://www.study.com/seven7/1408phpB/20160311/1.php"; $data=array('username'=>'abc'); $str=curl($url,$data,'POST'); echo $str; */ //模擬登錄 //登錄保存用戶信息到cookie中 $url="http://www.ecshop.com/user.php"; $data=array('username'=>'ecshop','password'=>'ecshop','remember'=>'1','act'=>'act_login','back_act'=>'./index.php','submit'=>''); //post提交 curl($url,$data,'POST',true,$cookie_file); //get獲取 $url="http://www.ecshop.com/user.php?act=order_list"; $str=curl($url,array(),'GET',false,$cookie_file); echo $str;