Search code examples
reactjsspring-bootproxyhttp-proxy-middlewarehttp-status-code-415

http-proxy-middleware proxy is not working in React js and Spring Boot project. GET API is return 415 status error


I'm using the http-proxy-middleware middle ware. Content-Type: application/json is must be add in API's headers while execute with postman. I added my API's header configuration in React.

I think the error is caused by I dont send headers corrently. Actually I dont know. Please help me.

Thanks

Spring Boot

MovieController.java

@RestController
@RequestMapping("/movie")
public class MovieController {

    @Autowired
    private IMovieService movieService;

    @GetMapping(value = "/fetchAllMovieList", produces = MediaType.APPLICATION_JSON_VALUE, consumes = MediaType.APPLICATION_JSON_VALUE)
    public ResponseEntity<List<Movie>> fetchAllMovieList() {
        return new ResponseEntity<>(movieService.fetchAllMovieList(), HttpStatus.OK);
    }
}

React

movieAction.js

import {API_BASE} from "../config/env";
import axios from 'axios';

const headers = {
    'Content-Type': 'application/json;charset=UTF-8',
    "Access-Control-Allow-Origin": "*",
    "Accept": "application/json"
}

export function fetchMovies() {
    return dispatch => {
        dispatch({
            type: "FETCH_MOVIES",
            payload: axios.get(`${API_BASE}/movie/fetchAllMovieList`, {
                headers: headers
            }).then(response => console.log("Action/moviesAction.js -> response -> ", response))
        })
    }
}

setupProxy.js

import {API_BASE} from "./env";
const createProxyMiddleware = require("http-proxy-middleware");

module.exports = function (app) {
    app.use(
        createProxyMiddleware("/movie/fetchAllMovieList",{
            target: `${API_BASE}`,
            changeOrigin: true
        })
    );
};

env.js

export const API_BASE = "http://localhost:8080";

Results in Console

GET http://localhost:8080/movie/fetchAllMovieList 415
Uncaught (in promise) Error: Request failed with status code 415
    at createError (createError.js:16)
    at settle (settle.js:17)
    at XMLHttpRequest.handleLoad (xhr.js:62)

Results in Network

{
  "timestamp": "2021-01-04T07:24:51.116+00:00",
  "status": 415,
  "error": "Unsupported Media Type",
  "message": "",
  "path": "/movie/fetchAllMovieList"
}

Solution

  • I and Mahdi solved that problem. We missed data:{} part. I added under the headers: headers, and mixed him and mine codes. I'm going to share solition.

    moviesAction.js

    import axios from 'axios';
    
    const headers = {
        'Content-Type': 'application/json;charset=UTF-8',
        "Access-Control-Allow-Origin": "*",
        Accept: "application/json"
    }
    
    export function fetchMovies() {
        return async dispatch => {
            const response = await axios.get(`/movie/fetchAllMovieList`, {
                headers: headers,
                data: {}
            });
    
            console.log("Action/moviesAction.js -> response -> ", response);
    
            dispatch({
                type: "FETCH_MOVIES",
                payload: response.data,
            });
        }
    }
    

    setupProxy.js

    import {API_BASE} from "./env";
    const {createProxyMiddleware} = require("http-proxy-middleware");
    
    module.exports = function (app) {
        app.use("/movie/fetchAllMovieList",
            createProxyMiddleware({
                target: `${API_BASE}`,
                changeOrigin: true
            })
        );
    };
    

    env.js

    export const API_BASE = "http://localhost:8080";
    

    Add proxy in package.json

      "name": "movie-frontend",
      "version": "0.1.0",
      "private": true,
      **"proxy":"http://localhost:8080",**
      "dependencies": {