madnh / request
cURL wrapper
Installs: 1 363
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=5.3.0
- ext-curl: *
This package is not auto-updated.
Last update: 2025-01-18 21:58:22 UTC
README
A cURL wrapper
Config
Request support 3 ways of config:
- Global config
- Instance's config
- Request's config
Inherit: Global config <- Instance's config <- Request's config
Default config
- url: request's URL
- request_type: request method, default is 'GET'
- data: request data, string or array, default is empty string
- use_cookie: use cookie? default is true
- cookie: custom cookie to request, default is empty array
- cookie_send: Path of cookie file, use when send request
- cookie_save: Path of cookie file, use to store cookie after every request
- fail_on_error: stop on error? default is true
- follow_location: follow any redirect? default is true
- return_transfer: return response instead of print it out, default is true
- header: request header, array, default is empty array
- return_header: return response's header
- verifying_ssl: default is false
- use_proxy: default is false
- proxy: proxy's info
- is_http_proxy: default is true
- referer: default is true
- timeout: request timout, default is 3600
- useragent: useragent info of request, default is 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/43.0.2357.130 Safari/537.36'
Global config
Request::globalConfig('cookie_send', __DIR__.'/cookie.txt'); Request::globalConfig('cookie_save', __DIR__.'/cookie.txt');
Response
-
request: request config, array
-
header: response's header, string
-
response: response, string
-
error: False or array of
- no: cURL's error number
- message: error message
-
start: UNIX timestamp when request start
-
end: UNIX timestamp when request complete
Constant
- AUTH_MODE_BASIC
- AUTH_MODE_DIGEST
- AUTH_MODE_GSSNEGOTIATE
- AUTH_MODE_NTLM
- AUTH_MODE_ANY
- AUTH_MODE_ANYSAFE
How to use
- Setup global config, if need
- Create new instance, which config if need
- Setup instance config
- Make request, requets may include config if need
Config methods
- globalConfig(config_name: string or array of configs, [value = null])
- getGlobalConfig()
- getConfig(): export config
Request Methods
- request(config)
- get(url, [data, [config])
- post(url, [data, [config])
- put(url, [data, [config])
- delete(url, [data, [config])
Other methods
- setHeader(headers), set request headers, return instance
- addHeader(name, value): add a request header, return instance
- setCookie(cookies), set request cookies, return instance
- addCookie(name, value), set a request cookie value, return instance
- setData(data): set request data, return instance
- addData(name, value): add a request data, return instance
- rawConfig(CURL Options instance, value), set config, return instance
- setBasicAuthentication(username, password), set basic auth info, return instance
- setHttpAuthMode(mode): set auth mode. Return instance. Support:
- AUTH_MODE_BASIC
- AUTH_MODE_DIGEST
- AUTH_MODE_GSSNEGOTIATE
- AUTH_MODE_NTLM
- AUTH_MODE_ANY
- AUTH_MODE_ANYSAFE
Examples
Create new instance
$obj = new Request(array( 'timeout' => 10 )); $result = $obj->request(array( 'url' => 'http://www.w3schools.com/' )); print_r($result);
Make another request
$result = Request::url($_SERVER['HTTP_HOST'] . '/test/target.php') ->addData('name', 'Tom') ->addData('old', 16) ->setCookie(array( 'is_admin' => true )) ->ajaxRequest() ->post();