Home >Backend Development >PHP Tutorial >PHP uses ajax data to submit post and summary of common methods of post, ajaxpost_PHP tutorial
The example in this article describes the common methods of PHP using ajax data to submit posts and posts. Share it with everyone for your reference. The specific method is as follows:
In many cases, there will be no problem when we use ajax, but sometimes we encounter the problem of incomplete ajax data submission post. Here is an example for everyone to analyze.
The following is a standard ajax request code. Under normal circumstances, there will be no problems. However, problems may occur under certain circumstances, such as username=fdas&321, or the & symbol appears in the parameter value. After N times of testing, we found that all the data was transmitted, but the printed data was half-cut. Finally, we carefully observed the header information and found that the transmitted header was wrong. The problem was located in js, and we found that the method of string splicing would cause this problem username =fdas&321&password=password This is wrong. So we need to change the transmitted data into the json format of {username:username,passsword:password} to avoid problems!
The sample code is as follows:
① application/x-www-form-urlencoded
This should be the most common way to submit data via POST. For the browser's native form, if the enctype attribute is not set, data will eventually be submitted in application/x-www-form-urlencoded mode. The request is similar to the following (irrelevant request headers are omitted in this article):
Many times, we also use this method when submitting data using Ajax. For example, the Ajax of JQuery and QWrap, the default value of Content-Type is "application/x-www-form-urlencoded;charset=utf-8".
② multipart/form-data
This is another common way to submit POST data. When we use a form to upload files, the enctyped of the form must be equal to this value. Let’s look directly at an example request:
This example is a little more complicated. First, a boundary is generated to separate different fields. In order to avoid duplication with the text content, the boundary is very long and complicated. Then Content-Type specifies that the data is encoded with mutipart/form-data, and what is the boundary content of this request. The message body is divided into multiple parts with similar structure according to the number of fields. Each part starts with --boundary, followed by content description information, followed by carriage return, and finally the specific content of the field (text or binary). If a file is being transferred, the file name and file type information must also be included. The message body ends with the --boundary-- flag. For a detailed definition of mutipart/form-data, please go to rfc1867.
This method is generally used to upload files, and major server languages also have good support for it.
The two methods of POST data mentioned above are natively supported by browsers, and at this stage, native forms only support these two methods. But as more and more Web sites, especially WebApps, all use Ajax for data interaction, we can completely define new data submission methods to bring more convenience to development.
③ application/json
The Content-Type of application/json is certainly familiar to everyone as a response header. In fact, more and more people now use it as a request header to tell the server that the message body is a serialized JSON string. Due to the popularity of the JSON specification, all major browsers except lower versions of IE natively support JSON.stringify. Server-side languages also have functions for processing JSON, so you will not encounter any trouble when using JSON.
It’s also useful that the JSON format supports much more complex structured data than just key-value pairs. I remember that when I was working on a project a few years ago, the data that needed to be submitted had a very deep level. I serialized the data into JSON and submitted it. But at that time, I used the JSON string as val, still placed it in the key-value pair, and submitted it in x-www-form-urlencoded mode.
The Ajax function in Google's AngularJS submits a JSON string by default. For example, the following code:
Of course AngularJS can also be configured to use x-www-form-urlencoded to submit data.
④ text/xml
XML-RPC (XML Remote Procedure Call) was mentioned before. It is a remote call specification that uses HTTP as the transport protocol and XML as the encoding method. A typical XML-RPC request looks like this:
I hope this article will be helpful to everyone’s PHP programming design.