Problem description
Use a-upload to handle image uploading scene. According to the official document, only action, listtype and @change events need to be defined. Most other page effect components can be directly implemented, such as opening the local file system, clicking load picture and uploading it to the designated remote server. But what if the remote is denied access due to CORS
Those who want to solve the problem quickly can skip the problem analysis and refer directly to the solution process
Problem analysis
The cross-domain problem actually means that the front and back ends do not communicate well with each other. Open the network function of Google Debugging tool and check the packet preprocessed by the interface first (CORS preprocesses non-simple requests first), because the interface preprocessing part is configured in the project, that is, there will be no cross-domain problem. A-upload does not care about how to deal with cross-domain in your project, so it is easy to have problems due to the configuration of a-upload’s request header after pre-processing
To solve the process
- Check the access-Control-allow-headers header of the pre-processing request. This header indicates the configuration allowed in the cross-domain request returned by the server. If the server does not support the configuration, an error will be reported. If the server returns access-Control-allow-headers: content-type, But the a-upload component’s default image upload header contains x-requested-with :XMLHttpRequest, which is the culprit for cross-domain failure!
- Delete the X-requested-with in the request header, which is intended to represent an asynchronous Ajax request, but in order to successfully cross domains, use the HEADERS attribute of an A-upload and assign a null value
headers: {
X-Requested-With: null
}
Copy the code
- Note that if the page is accessed using HTTPS, the action value in the A-upload component needs to be HTTPS as well, otherwise an error will be reported.