Я слежу за учебными курсами на сайте электронной коммерции, используя услуги 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.Спасибо за любую помощь.