Po wysłaniu request DELETE do express otrzymuję taki błąd:
Access to XMLHttpRequest at '(tutaj jest URL)' from origin 'http://localhost:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
Ten sam błąd otrzymuję podczas wysłania request z aplikacji na netlify. Nie ma znaczenia czy to localhost czy nie.
Request GET działa bez problemu.
A oto i fragment kodu:
Express:
const cors = require("cors");
const app = express();
app.use(cors({origin: '*'}));
app.use(express.json());
app.use(function (req, res, next) {
res.setHeader('Access-Control-Allow-Origin', 'http://localhost:3000');
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
res.setHeader('Access-Control-Allow-Credentials', true);
next();
});
app.get("/api/image/:image_id", getImage);
app.delete("/api/image/:image_id", delImage);
React:
import axios from "axios";
const beStructionApi = axios.create({
baseURL: "(tutaj URL)",
headers: {"Access-Control-Allow-Origin": "*"}
});
export const getImage = (image_id) => {
return beStructionApi.get(`/image/${image_id}`).then((result) => {
const data = result.data.image.data;
let TYPED_ARRAY = new Uint8Array(data);
const STRING_CHAR = TYPED_ARRAY.reduce((data, byte)=> {
return data + String.fromCharCode(byte);
}, '');
let base64String = window.btoa(STRING_CHAR);
return base64String
})
}
export const delImageS3 = (image_id) => {
return beStructionApi.delete(`/image/${image_id}`).then((result) => {
console.log(result)
})