This article will introduce you to the CURL application examples on the WeChat public platform. If you encounter such problems, please refer to it.
In the past few days, I have been using curl a lot in my work. Curl simulates a browser to transmit data. It supports many protocols such as HTTP, HTTPS, FTP, etc., when collecting and simulating users to perform some operations. Very useful.
There are four main steps to using CURL:
1. Initialization URL
2. Set some parameters of the request (COOKIE, HEAD...)
3. Execute request
4. Close resources
Let’s talk about a simple collection first. Generally, when obtaining the content of a web page, it is most convenient for us to use the file_get_contents() function to obtain it. Now we use CURL to capture the content of a web page
The code is as follows | Copy code | ||||
|
Note: The key point lies in the second parameter of the curl_setopt() function (there will be some commonly used information below)
In this way, we can get the content of this web page. If only CURL can do something, it will be overkill. CURL can actually be used to do more magical things.
I just recently joined a new entrepreneurial company (Nima, I’m really confused about choosing this company because I have several offers, but the salary here is very low, because it’s an entrepreneurial company. I don’t know. Why did I choose this company? Anyway, my friends were confused about why I chose this company. In fact, I don’t know why I chose this company. The salary of other companies is about twice that of this company. I hope I didn’t choose this company this time. Wrong, otherwise, you will feel like dying, after talking so much nonsense), what I am doing is the development of the WeChat public platform, which is relatively popular now, because WeChat currently has very few open interfaces, so there are very few things that can be obtained through the interfaces. (Nima, Brother Ma, when did you have an excuse to play more!), but there are many interfaces in the official operating platform that do not have data, so we need to find some data ourselves. Well, the protagonist comes on CURL.
First of all, you need to log in to access the public platform, so I will log in first (nonsense). First, I need to capture packets and analyze the normal submission data. I will not take screenshots here (the blog is on the bae platform, and the editor has not had time yet) Ignore him, it’s not easy to use). Through packet capture analysis, we found that WeChat’s public platform uses ajax to log in, and the password has been md5 encrypted before submission (it seems that the formal one should be called md5 hash, and it is standard The MD5 hash should be 128 bits, but for the convenience of storage and transmission, the most common ones now are 32 and 16 bits. I just learned about it, and I’m ashamed). Another very important point is that the WeChat public platform uses the https protocol for login. . The best part is that there is no verification code required, sogay. Otherwise, it would be a lot of trouble to analyze it at this point. Come on!!!
The code is as follows | Copy code | ||||
"; curl_close($ch); |
The above is the code to log in to the WeChat public platform. It has been tested and is very easy to use +_+.
In the past few days, I have been exposed to a lot of people on the WeChat public platform. This is just the first step in a long journey. Later I will share how to match WeChat’s fakeid and openid so that I can display the user’s complete information on my own platform (according to me Understand that there is currently no good solution on how to match fakeid and openid on the Internet. After several days of struggle, we can now match it. It is quite troublesome, and existing users cannot match it (in fact, this is theoretically possible) It's possible, but I haven't done it yet and don't talk nonsense. In fact, I don't have time to do this. If you have the opportunity, you can try it, but the implementation requires the support of the existing system, that is, your current system must record and use the chat history (I What did you say? I didn’t say anything!))).
Physical education teacher, you said that you didn’t take your physical education class well and didn’t come to teach us Chinese. I have encountered a lot of things that can be written these days, so I just thought of it and wrote it there. It’s a bit messy. In the past few days, The main one used is CURL, so today I will talk about some CURL examples, just to write down what I have on hand to log in to the WeChat public platform. CURL ends here, I may write more about the WeChat public platform later.
Attachment:
Options |
Optionalvaluevalue |
Remarks |
CURLOPT_AUTOREFERER |
Automatically sets header when redirecting based on Location: 🎜>Referer:information. |
|
CURLOPT_BINARYTRANSFER |
Returns native (Raw) output when CURLOPT_RETURNTRANSFER is enabled. |
|
CURLOPT_COOKIESESSION |
When enabledcurl will only pass one session cookie, ignoring other cookie, by default cURL will return all cookie to the server. session cookie refers to those cookies that exist to determine whether the server-side session is valid. . |
|
CURLOPT_CRLF |
When enabled, converts the line feed character of Unix into a carriage return and line feed character. |
|
CURLOPT_DNS_USE_GLOBAL_CACHE |
When enabled, a global DNS cache is enabled, which is thread-safe and enabled by default. |
|
CURLOPT_FAILONERROR |
displays the HTTP status code. The default behavior is to ignore whose number is less than or equal to 400 HTTPInformation. |
|
CURLOPT_FILETIME |
When enabled, an attempt will be made to modify information in the remote document. The result information will be returned through the CURLINFO_FILETIME option of the curl_getinfo() function. curl_getinfo(). |
|
CURLOPT_FOLLOWLOCATION |
When enabled, the "Location: " returned by the server will be placed recursively in the header is returned to the server, use CURLOPT_MAXREDIRS to limit the number of recursive returns. |
|
CURLOPT_FORBID_REUSE |
Forcibly disconnect after completing the interaction and cannot be reused. |
|
CURLOPT_FRESH_CONNECT |
Force a new connection to replace the one in the cache. |
|
CURLOPT_FTP_USE_EPRT |
When enabled, when FTP downloads, use EPRT ( or LPRT) command. Disables EPRT and LPRT when set to FALSE , use the PORT commandonly. |
|
CURLOPT_FTP_USE_EPSV |
When enabled, try first PASV mode during FTP transfer >EPSV command. Disables the EPSV command when set to FALSE. |
|
CURLOPT_FTPAPPEND |
When enabled append writes to the file instead of overwriting it. |
|
CURLOPT_FTPASCII |
Alias for
CURLOPT_TRANSFERTEXT. |
|
CURLOPT_FTPLISTONLY |
When enabled, only the names of the FTP directories are listed. |
|
CURLOPT_HEADER |
When enabled, the header file information will be output as a data stream. |
|
CURLINFO_HEADER_OUT |
The request string of the tracking handle when enabled. |
Available starting with PHP 5.1.3 . CURLINFO_ The prefix is intentional (intentional). |
CURLOPT_HTTPGET |
When enabled, the HTTP's method will be set to GET, because GET is the default, so it is only used when it is modified. |
|
CURLOPT_HTTPPROXYTUNNEL |
When enabled, it will be transmitted through the HTTP proxy. |
|
CURLOPT_MUTE |
When enabled, all modified parameters in the cURL function will be restored to their default values. |
|
CURLOPT_NETRC |
After the connection is established, access the ~/.netrc file to obtain the username and password information to connect to the remote site. |
|
CURLOPT_NOBODY |
When enabled, the BODY part in the HTML will not be output. |
|
CURLOPT_NOPROGRESS |
Close the progress bar of curl transfer when enabled. The default setting for this item is enabled. Note:PHP automatically sets this option to TRUE, this option should only be changed for debugging purposes.
|
|
CURLOPT_NOSIGNAL |
When enabled, ignores all curl signals passed to php. This is enabled by default during SAPI multi-thread transmission. |
Added in cURL 7.10. |
CURLOPT_POST |
When enabled will send a regular POST request of type: application/x-www-form -urlencoded, just like form submission. |
|
CURLOPT_PUT |
Allows HTTP to send files when enabled, must set both CURLOPT_INFILE and CURLOPT_INFILESIZE. |
|
CURLOPT_RETURNTRANSFER |
Return the information obtained by curl_exec() in the form of a file stream instead of outputting it directly. |
|
CURLOPT_SSL_VERIFYPEER |
After disabling cURL will terminate validation from the server. Use the CURLOPT_CAINFO option to set the certificate Use the CURLOPT_CAPATH option to set the certificate directory if CURLOPT_SSL_VERIFYPEER(default is 2) is enabled, CURLOPT_SSL_VERIFYHOST needs to be Set to TRUE otherwise set to FALSE. |
Defaults to TRUE since cURL 7.10. Default bundle installation starting with cURL 7.10. |
CURLOPT_TRANSFERTEXT |
When enabled uses ASCII mode for FTP transfers. For LDAP, it retrieves plain text information instead of HTML. On Windows systems, the system will not set STDOUT to binary mode. |
|
CURLOPT_UNRESTRICTED_AUTH |
Multiple locations in header generated using CURLOPT_FOLLOWLOCATION Continuously append username and password information in even if the domain name has changed. |
|
CURLOPT_UPLOAD |
Allow file uploads when enabled. |
|
CURLOPT_VERBOSE |