PHP Curl Module Simulation Login After collection page Instance _php tutorial

Source: Internet
Author: User
Tags http cookie http post
In PHP, the Curl module is a multi-threaded module, he can easily implement the simulation login, such as Post,get can, below I take an example of using the Curl module to simulate login after the page program.

Today received the lesson is from a website to obtain merchandise inventory, but this site need to login, I use Fsockopen pass the whole header is useless, can only turn to curl.

Let's talk about the way the Curl module is opened:

(1) Copy from PHP directory: Libeay32.dll,ssleay32.dll to Windows directory.
(2) Open php.ini, look for "Extension_dir = xxxxx", confirm that there are php_curl.dll files in the following file directory.
(3) Also php.ini, look for "Extension=php_curl.dll", confirming that it is not annotated (";").
(4) Restart Apache, if you use Curl_init () and the statement appears with an error, the installation is not successful.

Cases

The code is as follows Copy Code

$curl = Curl_init ();
$cookie _jar = Tempnam ('./tmp ', ' Cookie ');
curl_setopt ($curl, Curlopt_url, ' http://www.bKjia.c0m/checkUser.jsp ');//Here write the interface for handling logins
curl_setopt ($curl, Curlopt_post, 1);
$request = ' user=xxx&password=xxx ';
curl_setopt ($curl, Curlopt_postfields, $request);//Pass Data
curl_setopt ($curl, Curlopt_cookiejar, $cookie _jar);//Save the returned cookie information in the $cookie_jar file
curl_setopt ($curl, Curlopt_returntransfer, 1);//Set whether the returned data is automatically displayed
curl_setopt ($curl, Curlopt_header, false);//Set whether to display header information
curl_setopt ($curl, Curlopt_nobody, false);//Set whether to output page content
Curl_exec ($curl);//return result
Curl_close ($curl); Shut down

$curl 2 = Curl_init ();
curl_setopt ($curl 2, Curlopt_url, ' http://www.bKjia.c0m/aaa.php ');//the page from which to get information after landing
curl_setopt ($curl 2, Curlopt_header, false);
curl_setopt ($curl 2, Curlopt_returntransfer, 1);
curl_setopt ($curl 2, Curlopt_cookiefile, $cookie _jar);
$content = Curl_exec ($curl 2);

The obtained data is passed as a string to the $content. The string is then processed and the unnecessary parts are deleted.
I only removed the unnecessary parts of the front page:

The code is as follows Copy Code

$content = Strstr ($orders, ');//Find First occurrence

The Place and delete

The curl parameter is detailed:

BOOL curl_setopt (int ch, string option, mixed value)

The curl_setopt () function sets options for a curl session. The option parameter is the setting that you want, and value is the one given by this choice.

The values of the following options are used as long shapes (specified in the option parameter):

*curlopt_infilesize: When you upload a file to a remote site, this option tells PHP the size of your upload file.
*curlopt_verbose: If you want curl to report every unexpected thing, set this option to a value other than 0.
*curlopt_header: If you want to include a header in the output, set this option to a value other than 0.
*curlopt_noprogress: If you do not have PHP display a process bar for the Curl transfer, set this option to a value other than 0.

Note: PHP automatically sets this option to a value other than 0, you should only change this option for debugging purposes.

*curlopt_nobody: If you do not want to include the body part in the output, set this option to a value other than 0.
*curlopt_failonerror: If you want PHP to not display when an error occurs (HTTP code returns greater than or equal to 300), set this option to one person other than 0 value. The default behavior is to return a normal page, ignoring the code.
*curlopt_upload: If you want PHP to prepare for uploading, set this option to a value other than 0.
*curlopt_post: If you want PHP to do a regular HTTP POST, set this option to a value other than 0. This post is an ordinary application/x-www-from-urlencoded type, most of which is used by HTML forms.
*curlopt_ftplistonly: Set this option to a value other than 0, PHP lists the list of directory names for FTP.
*curlopt_ftpappend: Set this option to a value other than 0, PHP will apply the remote file instead of overwriting it.
*CURLOPT_NETRC: Set this option to a value other than 0, PHP will look in your ~./netrc file for the user name and password of the remote site you want to connect to.
*curlopt_followlocation: Set this option to a non-0 value (like "Location:") header, the server will send it as part of the HTTP header (note that this is recursive, PHP will be sent as "location:" the head).
*curlopt_put: Set this option to use HTTP to upload a file for a value other than 0. To upload this file you must set the Curlopt_infile and Curlopt_infilesize options.
*curlopt_mute: Set this option to a value other than 0, PHP will be completely silent for the curl function.
*curlopt_timeout: Sets a long shape number, as the maximum continuation of how many seconds.
*curlopt_low_speed_limit: Sets a long shaping number to control how many bytes are transferred.
*curlopt_low_speed_time: Sets a long shape number that controls how many seconds to transmit curlopt_low_speed_limit the specified number of bytes.
*curlopt_resume_from: Pass a long shaping parameter that contains the byte offset address (the start form you want to transfer to).
*curlopt_sslversion: Pass a long parameter that contains the SSL version. The default PHP will be determined by its own efforts, and in more security you must set it up manually.
*curlopt_timecondition: Passes a long parameter that specifies how the Curlopt_timevalue parameter is handled. You can set this parameter to Timecond_ifmodsince or timecond_isunmodsince. This is used only for HTTP.
*curlopt_timevalue: Passes a number of seconds from 1970-1-1 onwards to the present. This time will be used by the Curlopt_timevalue option as the specified value, or by default timecond_ifmodsince.

The values of the following options will be used as strings:

*curlopt_url: This is the URL address you want to retrieve with PHP. You can also set this option when initializing with the Curl_init () function.
*curlopt_userpwd: Pass a shape like [Username]:[password] style string, function PHP to connect.
*curlopt_proxyuserpwd: Pass a string that is formatted as [Username]:[password] to connect to the HTTP proxy.
*curlopt_range: Pass a range that you want to specify. It should be in the "X-y" format, except for X. or Y. HTTP delivery also supports several intervals, separated by a phrase (x-y,n-m).
*curlopt_postfields: A string that passes all data as an HTTP "POST" operation.
*curlopt_referer: A string that contains a "REFERER" header in an HTTP request.
*curlopt_useragent: A string that contains a "user-agent" header in an HTTP request.
*curlopt_ftpport: Pass an IP address that contains the FTP "POST" instruction used. This post command tells the remote server to connect to the IP address we specified. This string can be an IP address, a host name, a network interface name (under Unix), or '-' (using the system default IP address).
*curlopt_cookie: Passes a header connection that contains an HTTP COOKIE.
*curlopt_sslcert: Pass a string containing a certificate in PEM format.
*CURLOPT_SSLCERTPASSWD: Pass a password that contains required to use the Curlopt_sslcert certificate.
*curlopt_cookiefile: A string that passes the name of a file that contains cookie data. This cookie file can be a Netscape format, or an HTTP-style header that is stockpiled in a file.
*curlopt_customrequest: When an HTTP request is made, passing a character is used by get or head. For a delete or other operation is beneficial, more pass a string to is used instead of GET or HEAD when doing an HTTP request. This was useful for doing or another, and more obscure, HTTP request.

Note: Do not do this before confirming your server support commands.

The following options require a file description (obtained by using the fopen () function):
 
*curlopt_file: This file will be the output file you put in the transfer, the default is stdout.
*curlopt_infile: This file is the input file you sent over.
*curlopt_writeheader: This file is written with the head part of your output.
*curlopt_stderr: This file is written with errors rather than STDERR.

http://www.bkjia.com/PHPjc/633158.html www.bkjia.com true http://www.bkjia.com/PHPjc/633158.html techarticle in PHP, the Curl module is a multi-threaded module, he can easily implement the simulation login, such as post,get can be, below I give an example of using the Curl module to simulate the acquisition of the page after the login ...

  • Related Article

    Contact Us

    The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

    If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.