I'm using Guzzle v3.9.2 with both php 5.3 and php 5.5.
I have the following working curl code that uses an ssl client certificate:
$url = "https://example.com/";
$cert_file = '/path/to/certificate.pem';
$ch = curl_init();
$options = array(
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_FOLLOWLOCATION => true,
  CURLOPT_URL => $url ,
  CURLOPT_SSLCERT => $cert_file ,
);
curl_setopt_array($ch , $options);
$output = curl_exec($ch);
if (!$output) {
  echo "Curl Error : " . curl_error($ch);
}
else {
  echo htmlentities($output);
}
I have tried to move it to Guzzle:
require '/var/www/vendor/autoload.php';
use Guzzle\Http\Client;
$client = new Client();
$request = $client->get($url, array('cert' => $cert_file));
$response = $client->send($request);
echo $response . PHP_EOL;
print 'HI' . PHP_EOL;
When I run it using curl I get a 200 response. When I use Guzzle I get a 403.
If you are using private key then you have to use ssl_key option it will not 
work with cert.You can use **cert** options only with client certificate.
This error occurs because of three reason.
How Guzzle set ssl curl path:
vendor/Http/Resources/cacert.pem. ssl.certificate_authority parameter to set the curl ssl certification. It supports values as false,true or file pathYou can set the file path while class initialization as below-
$cert_file = '/var/www/stack/25924147/cert/example.pem'; #Use absolute path as relative path will not work
$client = new Client();
$client->setDefaultOption('verify',true); #pass it for self-signed certificate
$client->setSslVerification($cert_file,true,2);  #Last Verify Option states default value is 2. When the verify value is 0, the connection succeeds regardless of the names in the certificate. Use that ability with caution!. When the verify value is 1, curl_easy_setopt will return an error
try{
    $request = $client->get($url);
    $options = $request->getCurlOptions(); #used to check curl options is set properly.
    var_dump($options); 
    $response = $client->send($request);
    echo $response . PHP_EOL;
    print 'HI' . PHP_EOL;
}catch( Guzzle\Http\Exception\CurlException $e){
    print_r($e->getResponse());
    echo "\n Curl Error \n";
}catch(Guzzle\Http\Exception\ClientErrorResponseException $e){
   print_r($e->getResponse());
   echo "\n Response Error \n";
}catch( Guzzle\Http\Exception\RequestException $e){
  print_r($e->getResponse());
  echo "\n REquest Error \n";
}
OR If you wants to pass certificate on every request try below code
   $cert_file = '/var/www/stack/25924147/cert/example.pem'; #Use absolute path as relative path will not work
   $client = new Client();
   $request = $client->get('https://www.example.com', array(), array(
      'ssl_key' => array('/etc/pki/private_key.pem')
  )
With Passoword - 
 $request = $client->get('https://www.example.com', array(), array(
     'ssl_key' => array('/etc/pki/private_key.pem', 's3cr3tp455w0rd')
 )
For Guzzle Http client Doc check - The Guzzle HTTP client
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With