Online Certificate Status Protocol PHP Library

This repository contains a PHP library that helps you checking if HTTPS certificates are revoked, by using the Online Certificate Status Protocol (OCSP).

This library doesn't require exec calls to system utilities like OpenSSL: it's a pure PHP library.

This library doesn't include any network-related helpers: you have to use your own transport libraries (cURL, Zend HTTP, Guzzle or whatever).

Checking HTTPS certificates requires:

the certificate to be checked, in PEM format (that is, the text files that starts with `-----BEGIN CERTIFICATE-----), or in DER format (that is, binary files) the issuer certificate, that is the certificate of the Certification Authority that provided you the HTTPS certificate the URL, provided by the Certification Authority, to be used for OCSP calls (the so-called OCSR Responder URL)

Obtaining the certificate and the issuer certificate from an HTTPS URL

You can get the HTTPS certificate and the issuer certificate from an HTTPS URL by using some code like this:

$hCurl = curl_init($url); curl_setopt($hCurl, CURLOPT_RETURNTRANSFER, false); curl_setopt($hCurl, CURLOPT_CUSTOMREQUEST, 'HEAD'); curl_setopt($hCurl, CURLOPT_NOBODY, true); curl_setopt($hCurl, CURLOPT_CERTINFO, true); curl_exec($hCurl); $certInfo = curl_getinfo($hCurl, CURLINFO_CERTINFO); $certificate = $certInfo[0]['Cert']; $issuerCertificate = $certInfo[1]['Cert'];

Obtaining the issuer certificate from a certificate

HTTPS certificates usually contain an URL where you can find the certificate of the certificate issuer.

You can use this code to extract this URL, provided that '/path/to/certificate' is the path to a local file that contains your HTTPS certificate:

$certificateLoader = new OcspCertificateLoader(); $certificate = $certificateLoader->fromFile('/path/to/certificate'); $certificateInfo = new OcspCertificateInfo(); $urlOfIssuerCertificate = $certificateInfo->extractIssuerCertificateUrl($certificate);

At this point, $urlOfIssuerCertificate will contain the URL where the issuer certificate can be downloaded from (if it's an empty string, that means that the issuer certificate URL is not included in your certificate).

Obtaining the OCSP Responder URL

To check if a certificate is valid, we need to know an URL, provided by the authority that issued the certificate, that can be called to check if the certificate has been revoked.

This URL may be included in the HTTPS certificate itself.

To get it, you can use the following code (provided that '/path/to/certificate' is the path to a local file that contains your HTTPS certificate):

$certificateLoader = new OcspCertificateLoader(); $certificate = $certificateLoader->fromFile('/path/to/certificate'); $certificateInfo = new OcspCertificateInfo(); $ocspResponderUrl = $certificateInfo->extractOcspResponderUrl($certificate);

Checking if a certificate has been revoked

Once you have the HTTPS certificate, the issuer certificate, and the OCSP Responder URL, you can check if the HTTPS certificate has been revoked, or if it's still valid.

In order to do so, you have to write some code like this (here we use cURL, but you can use any other transport library):

$certificateLoader = new OcspCertificateLoader(); $certificateInfo = new OcspCertificateInfo(); $ocsp = new OcspOcsp(); // Load the HTTPS certificate and the issuer certificate $certificate = $certificateLoader->fromFile('/path/to/certificate'); $issuerCertificate = $certificateLoader->fromFile('/path/to/issuer/certificate'); // Extract the relevant data from the two certificates $requestInfo = $certificateInfo->extractRequestInfo($certificate, $issuerCertificate); // Build the raw body to be sent to the OCSP Responder URL $requestBody = $ocsp->buildOcspRequestBodySingle($requestInfo); // Actually call the OCSP Responder URL (here we use cURL, you can use any library you prefer) $hCurl = curl_init(); curl_setopt($hCurl, CURLOPT_URL, $ocspResponderUrl); curl_setopt($hCurl, CURLOPT_RETURNTRANSFER, true); curl_setopt($hCurl, CURLOPT_POST, true); curl_setopt($hCurl, CURLOPT_HTTPHEADER, ['Content-Type: ' . OcspOcsp::OCSP_REQUEST_MEDIATYPE]); curl_setopt($hCurl, CURLOPT_SAFE_UPLOAD, true); curl_setopt($hCurl, CURLOPT_POSTFIELDS, $requestBody); $result = curl_exec($hCurl); $info = curl_getinfo($hCurl); if ($info['http_code'] !== 200) { throw new RuntimeException("Whoops, here we'd expect a 200 HTTP code"); } if ($info['content_type'] !== OcspOcsp::OCSP_RESPONSE_MEDIATYPE) { throw new RuntimeException("Whoops, the Content-Type header of the response seems wrong!"); } // Decode the raw response from the OCSP Responder $response = $ocsp->decodeOcspResponseSingle($result);

At this point, $response contains an instance of the OcspResponse class:

the certificate is not revoked if $response->isRevoked() === false the certificate is revoked if $response->isRevoked() === true (you can get the devocation date/time by calling $response->getRevokedOn()) in case of unknown state, $response->isRevoked() will return null

Exceptions

Problems may arise while loading the certificates, creating the request body for the OCSP Responder, analyzing the response from the OCSP Responder. To catch these errors, you can enclose your code within try/catch statements:

try { // code } catch (OcspExceptionException $problem) { // handle the error cases }

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。
3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考学习用!
4、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。