Usage examples of php's curl encapsulation class
The examples in this article describe two usage examples of the php curl encapsulation class. These two functions allow us to use php curl related functions very conveniently. Share it with everyone for your reference. The details are as follows:
Before using the function, we need to open the php curl module (libeay32.dll, ssleay32.dll, php5ts.dll, php_curl.dll)
Steps to open the php curl function library
1). Remove windows/ In the php.ini file; in front of extension=php_curl.dll; /*Use echo phpinfo(); to view the path of php.ini*/
2). Copy php5/libeay32.dll and ssleay32.dll to the system directory windows/ Next
3). Restart apache
The code is as follows:
<?php include_once('curl.class.php'); $aa =new Curl(''); $curlOptions = array( CURLOPT_URL => "http://www.xx.com/addTicket.jsp", //访问URL CURLOPT_RETURNTRANSFER => true, //获取结果作为字符串返回 CURLOPT_REFERER => "ww.ww.ww/zw2", CURLOPT_HTTPHEADER => array('X-FORWARDED-FOR:139.197.14.19', 'CLIENT-IP:127.0.0.1','Proxy-Client-IP:139.197.14.19','WL-Proxy-Client-IP:139.197.14.19' ), CURLOPT_HEADER => 1, //获取返回头信息 //CURLOPT_SSL_VERIFYPEER => false, //支持SSL加密 CURLOPT_POST => true, //发送时带有POST参数 CURLOPT_POSTFIELDS => 'ids=897&Submit=%E6%8A%95%E7%A5%A8', //请求的POST参数字符串 CURLOPT_TIMEOUT => $aa->timeout //等待响应的时间 ); echo $aa->getResponseText($curlOptions);
cul processing class:
<?php class Curl { public $cookieFile; public $timeout = 160; Public function __construct($dir){ $this->cookieFile = $this->getTemporaryCookieFileName($dir); } /** * 设置CURL参数并发送请求,获取响应内容 * @access private * @param $curlOptions array curl设置参数数组 * @return string|false 访问成功,按字符串形式返回获取的信息;否则返回false */ public function getResponseText($curlOptions) { /* 设置CURLOPT_RETURNTRANSFER为true */ if(!isset($curlOptions[CURLOPT_RETURNTRANSFER]) || $curlOptions[CURLOPT_RETURNTRANSFER] == false) { $curlOptions[CURLOPT_RETURNTRANSFER] = true; } /* 初始化curl模块 */ $curl = curl_init(); /* 设置curl选项 */ curl_setopt_array($curl, $curlOptions); /* 发送请求并获取响应信息 */ $responseText = ''; try { $responseText = curl_exec($curl); if(($errno = curl_errno($curl)) != CURLM_OK) { $errmsg = curl_error($curl); throw new Exception($errmsg, $errno); } } catch (Exception $e) { //exceptionDisposeFunction($e); //print_r($e); $responseText = false; } /* 关闭curl模块 */ curl_close($curl); /* 返回结果 */ return $responseText; } /** * 将Unicode字符串(u0000)转化为utf-8字符串,工具函数 * @access private * @static * @param $string string Unicode字符串 * @return string utf-8字符串 */ public function unicodeToUtf8($string) { $string = str_replace('u', '', strtolower($string)); $length = strlen($string) / 4; $stringResult = ''; for($i = 0; $i < $length; $i++) { $charUnicodeHex = substr($string, $i * 4, 4); $unicodeCode = hexdec($charUnicodeHex); $utf8Code = ''; if($unicodeCode < 128) { $utf8Code = chr($unicodeCode); } else if($unicodeCode < 2048) { $utf8Code .= chr(192 + (($unicodeCode - ($unicodeCode % 64)) / 64)); $utf8Code .= chr(128 + ($unicodeCode % 64)); } else { $utf8Code .= chr(224 + (($unicodeCode - ($unicodeCode % 4096)) / 4096)); $utf8Code .= chr(128 + ((($unicodeCode % 4096) - ($unicodeCode % 64)) / 64)); $utf8Code .= chr(128 + ($unicodeCode % 64)); } $stringResult .= $utf8Code; } return $stringResult; } private function getTemporaryCookieFileName($dir='.') { return (str_replace("", '/', tempnam($dir, 'tmp'))); } }
Example 2
<?php //curl类 class Curl { function Curl(){ return true; } function execute($method, $url, $fields='', $userAgent='', $httpHeaders='', $username='', $password=''){ $ch = Curl::create(); if(false === $ch){ return false; } if(is_string($url) && strlen($url)){ $ret = curl_setopt($ch, CURLOPT_URL, $url); }else{ return false; } //是否显示头部信息 curl_setopt($ch, CURLOPT_HEADER, false); // curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); if($username != ''){ curl_setopt($ch, CURLOPT_USERPWD, $username . ':' . $password); } $method = strtolower($method); if('post' == $method){ curl_setopt($ch, CURLOPT_POST, true); if(is_array($fields)){ $sets = array(); foreach ($fields AS $key => $val){ $sets[] = $key . '=' . urlencode($val); } $fields = implode('&',$sets); } curl_setopt($ch, CURLOPT_POSTFIELDS, $fields); }else if('put' == $method){ curl_setopt($ch, CURLOPT_PUT, true); } //curl_setopt($ch, CURLOPT_PROGRESS, true); //curl_setopt($ch, CURLOPT_VERBOSE, true); //curl_setopt($ch, CURLOPT_MUTE, false); curl_setopt($ch, CURLOPT_TIMEOUT, 10);//设置curl超时秒数 if(strlen($userAgent)){ curl_setopt($ch, CURLOPT_USERAGENT, $userAgent); } if(is_array($httpHeaders)){ curl_setopt($ch, CURLOPT_HTTPHEADER, $httpHeaders); } $ret = curl_exec($ch); if(curl_errno($ch)){ curl_close($ch); return array(curl_error($ch), curl_errno($ch)); }else{ curl_close($ch); if(!is_string($ret) || !strlen($ret)){ return false; } return $ret; } } function post($url, $fields, $userAgent = '', $httpHeaders = '', $username = '', $password = ''){ $ret = Curl::execute('POST', $url, $fields, $userAgent, $httpHeaders, $username, $password); if(false === $ret){ return false; } if(is_array($ret)){ return false; } return $ret; } function get($url, $userAgent = '', $httpHeaders = '', $username = '', $password = ''){ $ret = Curl::execute('GET', $url, '', $userAgent, $httpHeaders, $username, $password); if(false === $ret){ return false; } if(is_array($ret)){ return false; } return $ret; } function create(){ $ch = null; if(!function_exists('curl_init')){ return false; } $ch = curl_init(); if(!is_resource($ch)){ return false; } return $ch; } } ?>
usage
GET usage:
$curl = new Curl(); $curl->get('http://www.php.cn/');
POST usage:
$curl = new Curl(); $curl->get('http://www.php.cn/', 'p=1&time=0′);
I hope this article The above will be helpful for everyone's PHP programming.
For more articles related to PHP’s curl encapsulation class usage examples, please pay attention to 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



Alipay PHP...

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,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

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.

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...
