-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathindex-curl-version.php
137 lines (113 loc) · 3.69 KB
/
index-curl-version.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<?php
$target_host="https://www.google.com/";
//处理代理的主机得到协议和主机名称
$protocal_host=parse_url($target_host);
//以.分割域名字符串
$rootdomain=explode(".",$_SERVER["SERVER_NAME"]);
//获取数组的长度
$lenth=count($rootdomain);
//获取顶级域名
$top=".".$rootdomain[$lenth-1];
//获取主域名
$root=".".$rootdomain[$lenth-2];
$aAccess = curl_init() ;
// --------------------
// set URL and other appropriate options
$new_request_uri = "";
$path_script = pathinfo($_SERVER["PHP_SELF"]);
//
if ($path_script['dirname']!="/") {
$new_request_uri = substr_replace($_SERVER["REQUEST_URI"],"",strpos($_SERVER["REQUEST_URI"],$path_script['dirname']),strlen($path_script['dirname']));
} else {
$new_request_uri = $_SERVER["REQUEST_URI"];
}
curl_setopt($aAccess, CURLOPT_URL,$protocal_host['scheme']."://".$protocal_host['host'].$new_request_uri);
curl_setopt($aAccess, CURLOPT_HEADER, true);
curl_setopt($aAccess, CURLOPT_RETURNTRANSFER, true);
curl_setopt($aAccess, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($aAccess, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($aAccess, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($aAccess, CURLOPT_TIMEOUT, 60);
curl_setopt($aAccess, CURLOPT_BINARYTRANSFER, true);
//if(!empty($_SERVER['HTTP_REFERER']))
//curl_setopt($aAccess,CURLOPT_REFERER,$_SERVER['HTTP_REFERER']) ;
//关系数组转换成字符串,每个键值对中间用=连接,以; 分割
function array_to_str ($array)
{
$string="";
if (is_array($array))
{
foreach ($array as $key => $value)
{
if(!empty($string))
$string.="; ".$key."=".$value;
else
$string.=$key."=".$value;
}
} else
{
$string = $array;
}
return $string;
}
//$headers=get_client_header();
$headers = array();
$headers[]="Accept-language: zh-CN,zh";//$_SERVER['HTTP_ACCEPT_LANGUAGE'];
$headers[]="Cookie: ".array_to_str($_COOKIE);
$headers[]="user-agent: ".$_SERVER['HTTP_USER_AGENT'];
if( $_SERVER['REQUEST_METHOD']=='POST' )
{
$headers[]="Content-Type: ".$_SERVER['CONTENT_TYPE'];
curl_setopt($aAccess, CURLOPT_POST, 1);
curl_setopt($aAccess, CURLOPT_POSTFIELDS, http_build_query($_POST));
}
curl_setopt($aAccess,CURLOPT_HTTPHEADER,$headers) ;
// grab URL and pass it to the browser
$sResponse = curl_exec($aAccess);
list($headerstr,$sResponse)=parse_header($sResponse);
$headarr= explode("\r\n", $headerstr);
foreach($headarr as $h){
if(strlen($h)>0){
if(strpos($h,'Content-Length')!==false) continue;
if(strpos($h,'Transfer-Encoding')!==false) continue;
if(strpos($h,'Connection')!==false) continue;
if(strpos($h,'HTTP/1.1 100 Continue')!==false) continue;
if(strpos($h,'Set-Cookie')!==false)
{
$targetcookie=$h.";";
$res_cookie=preg_replace("/domain=.*?;/","domain=".$root.$top.";",$targetcookie);
$h=substr($res_cookie,0,strlen($res_cookie)-1);
}
header($h);
}
}
function get_client_header(){
$headers=array();
foreach($_SERVER as $k=>$v){
if(strpos($k,'HTTP_')===0){
$k=strtolower(preg_replace('/^HTTP/', '', $k));
$k=preg_replace_callback('/_\w/','header_callback',$k);
$k=preg_replace('/^_/','',$k);
$k=str_replace('_','-',$k);
if($k=='Host') continue;
$headers[]="$k: $v";
}
}
return $headers;
}
function header_callback($str){
return strtoupper($str[0]);
}
function parse_header($sResponse){
list($headerstr,$sResponse)=explode("\r\n\r\n",$sResponse, 2);
$ret=array($headerstr,$sResponse);
if(preg_match('/^HTTP\/1\.1 \d{3}/', $sResponse)){
$ret=parse_header($sResponse);
}
return $ret;
}
// close cURL resource, and free up system resources
$sResponse=str_replace($protocal_host['host'],$_SERVER["SERVER_NAME"],$sResponse);
curl_close($aAccess);
echo $sResponse ;
?>