Curl https skips ssl authentication in PHP and reports error
This article mainly shares with you the analysis and solutions to the error reporting problem of Curl https skipping ssl authentication in PHP. I hope it can help everyone.
function get($url = '', $cookie = ''){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //将curl_exec()获取的信息以文件流的形式返回,而不是直接输出。 curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); // 从证书中检查SSL加密算法是否存在 curl_setopt($ch, CURLOPT_SSLVERSION, 2);//设置SSL协议版本号 if($cookie){ curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); curl_setopt ($ch, CURLOPT_REFERER,'https://wx.qq.com'); } curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); $output = curl_exec($ch); if ( curl_errno($ch) ) return curl_error($ch); curl_close($ch); return $output; }
The above method is the function for user curl to initiate https request. The CURLOPT_SSLVERSION item specifies the SSL protocol version. Many codes on the Internet say that it can be set to 1/2/3, but the results of my test are as follows:
-
When set to 1, the following error will be reported in PHP 5.2.11 version:
“error:14077458:SSL routines:SSL23_GET_SERVER_HELLO:reason(1112)”
Error reported here The reason is that the version of openssl in your php is too low. The solution is to upgrade your php to 5.3.60 (I haven’t tested which version is higher, it should be ok as long as the openssl version is greater than 0.9.8) When set to 2, the following error will be reported:
Linux environment error: "SSL version range is not valid."
Windows environment error: "OpenSSL was built without SSLv2 support"
This should be easier to understand because the version number of the SSL protocol is invalid.When set to 3, the following error will be reported:
Linux environment error: "Encountered end of file".
Error reported in Windows environment: “Unknown SSL protocol error in connection to login.wx.qq.com:443 ”
After checking the information online, I think the reason for this error is due to security vulnerabilities in SSLV2 and SSLV3, so WeChat has The SSLV2 and SSLV3 protocol versions are no longer used, so an error will occur when we set it to 3.
function get($url = '', $cookie = ''){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //将curl_exec()获取的信息以文件流的形式返回,而不是直接输出。 curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); // 从证书中检查SSL加密算法是否存在 curl_setopt($ch, CURLOPT_SSLVERSION, 2);//设置SSL协议版本号 if($cookie){ curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); curl_setopt ($ch, CURLOPT_REFERER,'https://wx.qq.com'); } curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); $output = curl_exec($ch); if ( curl_errno($ch) ) return curl_error($ch); curl_close($ch); return $output; }
The above method is the function for user curl to initiate https request. The CURLOPT_SSLVERSION item specifies the SSL protocol version. Many codes on the Internet say that it can be set to 1/2/3, but I tested it. The result is as follows:
When set to 1, the following error will be reported in PHP 5.2.11 version:
“error:14077458:SSL routines:SSL23_GET_SERVER_HELLO:reason(1112)”
The reason for the error reported here is that the version of openssl in your php is too low. The solution is to upgrade your php to 5.3.60 (I have not tested which version is higher than it. It should be as long as the openssl version is greater than 0.9.8. Yes)When set to 2, the following error will be reported:
Linux environment error: "SSL version range is not valid."
Windows environment error: "OpenSSL was built without SSLv2 support”
This should be easier to understand, that is, the version number of the SSL protocol is invalid.When set to 3, the following error will be reported:
Linux environment error:” Encountered end of file”.
Error reported in Windows environment: “Unknown SSL protocol error in connection to login.wx.qq.com:443 ”
After checking the information online, I think the reason for this error is due to SSLV2 and SSLV3 There are security holes, so WeChat no longer uses SSLV2 and SSLV3 protocol versions, so an error will occur when we set it to 3.
Related recommendations:
Configuring SSL authentication (https) used by PHP in Nginx environment
The above is the detailed content of Curl https skips ssl authentication in PHP and reports error. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
