HTTP-статус 405. Метод не разрешен. Метод запроса «GET» не поддерживается. - PullRequest
0 голосов
/ 20 декабря 2018

Я слежу за учебными курсами на сайте электронной коммерции, используя услуги Spring, Angular JS, Spring REST.Когда я пытаюсь использовать свои RESTful-сервисы из класса «MovieCartResources», я получаю сообщение об ошибке HTTP Status 405 - Method Not Allowed.Это мой самый первый пост, извините, если я сделал несколько ошибок.

Класс MovieCartResources

@Controller
@RequestMapping("/rest/cart")
public class MovieCartResources {


@Autowired
private MovieCartService movieCartService;

@Autowired
private CustomerService customerService;

@Autowired
private MovieService movieService;

@RequestMapping("/{cartId}")
public @ResponseBody
MovieCart getMovieCart(@PathVariable(value = "cartId") int cartId) {

    return movieCartService.getMovieCartById(cartId);
}

@RequestMapping(value = "/add/{movieId}", method = RequestMethod.PUT)
@ResponseStatus(value = HttpStatus.NO_CONTENT)
public void addItem(@PathVariable("movieId") int movieId, 
@AuthenticationPrincipal User activeUser) {
    Customer customer = 
customerService.getCustomerByUsername(activeUser.getUsername());
    MovieCart movieCart = customer.getMovieCart();
    Movie movie = movieService.getMovieById(movieId);

    List<MovieItem> movieItemList = movieCart.getMovieItem();

    for (int i = 0; i < movieItemList.size(); i++) {
        if (movieItemList.get(i).getMovie().getMovieId() == 
movie.getMovieId()) {
            MovieItem movieItem = movieItemList.get(i);
            movieItem.setQuantity(movieItem.getQuantity() + 1);
            movieCartService.addMovieCartItem(movieItem);
            return;
        }
    }
    MovieItem movieItem = new MovieItem();
    movieItem.setQuantity(1);
    movieItem.setMovie(movie);
    movieItem.setMovieCart(movieCart);
    movieCartService.addMovieCartItem(movieItem);
}

Файл угловой JS

var cartApp = angular.module("cartApp", []);

cartApp.controller("cartCtrl", function ($scope, $http) {

$scope.refreshCart = function () {
    $http.get('/eShop/rest/cart/' + $scope.movieCartId).success(function (data) {
        $scope.movieCart = data;
    });
};

$scope.clearCart = function () {
    $http.delete('/eShop/rest/cart/' + 
$scope.movieCartId).success($scope.refreshCart());
};

$scope.initCart = function (movieCartId) {
    $scope.movieCartId = movieCartId;
    $scope.refreshCart();
}

$scope.putToCart = function (movieId) {
    $http.put('/eShop/rest/cart/add/' + movieId).success(function () {
        alert("Movie successfully added to movie list!")
    });
};

$scope.removeFromCart = function(movieId){
    $http.put('/eShop/rest/cart/remove/' + movieId).success(function(){
        $scope.refreshCart();
    })
}
});

Файл MovieCart.jsp

<%@include file="/WEB-INF/views/template/header.jsp" %>

<div class="container-wrapper">
<div class="container">
    <div class="jumbotron">
        <h1>Movie list</h1>
        <p>Here is your movie list</p>
    </div>
    <br>
    <section class="container" ng-app="cartApp">
        <div ng-controller="cartCtrl">
            <div>
                <a class="btn btn-danger -pull-left" ng- 
click="clearCart()">
                    <span class="glyphicon glyphicon-remove-sign"></span>
                    Clear cart
                </a>
            </div>
            <table class="table table-striped">
                <thead>
                <tr>
                    <th>Name</th>
                    <th>Type</th>
                    <th>IMDB</th>
                    <th>Duration</th>
                </tr>
                </thead>
                <tbody>
                <tr ng-repeat="movieItem in movieCart.movieItem">
                    <td>{{movieItem.movie.movieName}}</td>
                    <td>{{movieItem.movie.movieType}}</td>
                    <td>{{movieItem.movie.movieIMDB}}</td>
                    <td>{{movieItem.movie.movieDuration}}</td>
                    <td><a href="#" class="label label-danger" ng- 
 click="removeFromCart(movieItem.movie.movieId)">
                        <span class="glyphicon glypicon-remove"></span>
                        remove
                    </a></td>
                </tr>
                </tbody>
            </table>
        </div>
    </section>
 </div>
 </div>

 <script src="<c:url value="/resources/vendor/bootstrap/js/controller.js" /> "></script>

 <%@include file="/WEB-INF/views/template/footer.jsp" %>

Когда я пытаюсь использовать PUT,DELETE, GET методы в классе controller.js, я получаю HTTP Status 500 - Внутренняя ошибка сервера или HTTP Status 405 - Метод не разрешен.Я новичок в Angular и не знаю, как исправить эту ошибку.В моем файле "header.jsp" у меня есть скрипты для Angular js и Jquery.Спасибо за любую помощь.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...