2012-09-07 88 views
0

几乎整天我都在为这个问题而苦苦挣扎。解析curl_exec响应

我使用$result = curl_exec($ch);读取响应,我想获得set-cookie头看起来像:

Set-Cookie: JSESSIONID=05a0c785d8e2f4856a3f844e3694; Path=/qos; HttpOnly rememberMe=deleteMe; Path=/qos; Max-Age=0; Expires=Thu, 06-Sep-2012 10:50:20 GMT rememberMe=x+8X9hDZEUwM23osStzBmHs6FV/4VJAy18j4gjswG0H9wYKtOsSLu4p4XQ2KjLReNN4V2NokyjT66QkWzYetsde /Gbvmb9iJgV3VsuCvRgFpEFsduig5wHwu0YXjVgQWheiK87+5CNQE1X06z8mbPKu2GZUE/vwUUraR66ZAfxPdRKM24NKJ7HV4UIAPspudvCTJzFRqfkwb+pw cqnslyB6Rb/LB+pqHx2oshnINTwNd1E25+Zjs8qGQFQnHRvI4mRGF+BHC1JPGBV2GD9F7K29+szUlAGJhKr7FtOV1ELhN4JMqP4yuGDH0Dt9naLbRr6oFxxB 9t1+N5gHKVOE0vL5VM54Is5nAnWmhUrx9r3+R99We5phw7XuE1svlcOq2XrVeRJthMy3Xfp70cobUBdN/bOh5/ih9/wg3XwpagsGUKf1raP9mGO4ShDd+NFg8Z+eC+80Yt2wkS+7ZH/UGNh73LkdtCv6WlgFqiB/po20Lu+gCbDEceKt+lTNlU2c1; Path=/qos; Max-Age=15724800; Expires=Fri, 08-Mar-2013 10:50:20 GMT; HttpOnly 

我想他们分裂“;”焦炭。

编辑:

下面的解决方案没有按我的想象工作。也许是因为我有我的resoult其他标题:

Status Code: 200 OK 
Content-Length: 0 
Date: Fri, 07 Sep 2012 10:50:20 GMT 
Server: GlassFish Server Open Source Edition 3.1.1 
Set-Cookie: JSESSIONID=05a0c785d8e2f4856a3f844e3694; Path=/qos; HttpOnly rememberMe=deleteMe; Path=/qos; Max-Age=0; Expires=Thu, 06-Sep-2012 10:50:20 GMT rememberMe=x+8X9hDZEUwM23osStzBmHs6FV/4VJAy18j4gjswG0H9wYKtOsSLu4p4XQ2KjLReNN4V2NokyjT66QkWzYetsde /Gbvmb9iJgV3VsuCvRgFpEFsduig5wHwu0YXjVgQWheiK87+5CNQE1X06z8mbPKu2GZUE/vwUUraR66ZAfxPdRKM24NKJ7HV4UIAPspudvCTJzFRqfkwb+pw cqnslyB6Rb/LB+pqHx2oshnINTwNd1E25+Zjs8qGQFQnHRvI4mRGF+BHC1JPGBV2GD9F7K29+szUlAGJhKr7FtOV1ELhN4JMqP4yuGDH0Dt9naLbRr6oFxxB 9t1+N5gHKVOE0vL5VM54Is5nAnWmhUrx9r3+R99We5phw7XuE1svlcOq2XrVeRJthMy3Xfp70cobUBdN/bOh5/ih9/wg3XwpagsGUKf1raP9mGO4ShDd+NFg8Z+eC+80Yt2wkS+7ZH/UGNh73LkdtCv6WlgFqiB/po20Lu+gCbDEceKt+lTNlU2c1; Path=/qos; Max-Age=15724800; Expires=Fri, 08-Mar-2013 10:50:20 GMT; HttpOnly 

而我只需要设置Cookie

回答

0

最后我找到了灵魂。一个爆炸是不够的。

$parsedHeaders = http_parse_headers($result); 
$set_cookie_header = $parsedHeaders['Set-Cookie']; 
$cookie = $set_cookie_header[0]; 
$cookie = $cookie[0]; 
$cookie = explode('; ', $cookie); 
$cookie = $cookie[0]; 
$cookie = substr($cookie, 11); 

我从php.net例子接过http_parse_headers,它看起来像:

function http_parse_headers($header) 
{ 
     $retVal = array(); 
     $fields = explode("\r\n", preg_replace('/\x0D\x0A[\x09\x20]+/', ' ', $header)); 
     foreach($fields as $field) { 
      if(preg_match('/([^:]+): (.+)/m', $field, $match)) { 
       $match[1] = preg_replace('/(?<=^|[\x09\x20\x2D])./e', 'strtoupper("\0")', strtolower(trim($match[1]))); 
       if(isset($retVal[$match[1]])) { 
        $retVal[$match[1]] = array($retVal[$match[1]], $match[2]); 
       } else { 
        $retVal[$match[1]] = trim($match[2]); 
       } 
      } 
     } 
     return $retVal; 
} 

我希望它能够帮助别人的未来。

1

使用explode()分裂我们的字符串,像这样:

$dataArray = explode('; ', $result); 

,并导致$ dataArray中是所有部件的阵列。

1

使用此行得到curl_exec()结果的所有元素的数组:您可以分割curl_exec()结果与“

$parsedResult = explode('; ', $result); 

注意; ”。

然后,您可以这样做访问Set-Cookie值:

$setCookieValue = substr("Set-Cookie: ", "", $parsedResult[0]); 

从本质上说,你把$ parsedResult数组的第一个元素和“设置Cookie:”删除它。

+0

感谢您的帮助,我解决了它并发布了我的答案:) – dargod