我正在尝试从spring控制器中的angularjs进行http调用并发布json数据,但我在angularjs中收到此错误:
angular.js:10661 POST http://localhost:8080/shopng/product/add 404 (Not
Found)
(anonymous) @ angular.js:10661
sendReq @ angular.js:10480
serverRequest @ angular.js:10187
processQueue @ angular.js:14634
(anonymous) @ angular.js:14650
$eval @ angular.js:15916
$digest @ angular.js:15727
$apply @ angular.js:16024
(anonymous) @ angular.js:23416
eventHandler @ angular.js:3293
product_service.js:35 Error while adding product
product_controller.js:30 {productName: "ads", productPrice: 34, description: "ads", imageUrl: "asd"}
但是当我使用GET请求时,它没有给我任何错误,但是它说媒体类型不受支持,当我删除媒体类型然后执行' NULL'值被添加到数据库中。
这是我的RestController:
@RestController
@RequestMapping("/product")
public class ProductRestController {
@Autowired
ProductDao productDao;
//Add Product
@RequestMapping(value = "/add", method= RequestMethod.POST, consumes="application/json")
public ResponseEntity<Void> createProduct(@ModelAttribute("product") Product product) {
System.out.println("Creating Product " + product.getProductName());
if (productDao.isProductExit(product)) {
System.out.println("A Product with name " + product.getProductName() + " already exist");
return new ResponseEntity<Void>(HttpStatus.CONFLICT);
}
productDao.add(product);
return new ResponseEntity<Void>(HttpStatus.CREATED);
}
以下是我的角色服务请求:
function addProduct(product){
var deferred = $q.defer();
$http.post('http://localhost:8080/shopng/product/add', product)
.then(
function(response){
deferred.resolve(response.data);
},
function(errResponse){
console.log('Error while adding product');
deferred.reject(errResponse);
}
);
return deferred.promise;
}
这是该项目的github回购:https://github.com/Bk073/Shopping 任何帮助将不胜感激。
答案 0 :(得分:1)
我已经完成了你的securityconfig类。
请停用csrf,如下所示。
http.authorizeRequests().antMatchers("/admin/**")
.access("hasRole('ROLE_ADMIN')").and().formLogin()
.loginPage("/login").failureUrl("/login?error")
.usernameParameter("username")
.passwordParameter("password")
.and().logout().logoutSuccessUrl("/login?logout")
.and().csrf().disable();
//.and().exceptionHandling().accessDeniedPage("/403");
你得到404 - 因为csrf检查会抛出异常。要处理该异常,您尚未添加异常处理程序。所以404意味着 - 找不到异常处理程序,而不是发布请求本身。
如果您需要使用csrf保护,请记住发送带有请求的csrf令牌。
成功回复请参阅以下附件。
答案 1 :(得分:0)
控制器中的值属性不正确。它应该以 / 开头。请在控制器中更改为 / add
//Add Product
@RequestMapping(value = "/add", method= RequestMethod.POST, consumes="application/json")
public ResponseEntity<Void> createProduct(@ModelAttribute("product") Product product) {
System.out.println("Creating Product " + product.getProductName());
if (productDao.isProductExit(product)) {
System.out.println("A Product with name " + product.getProductName() + " already exist");
return new ResponseEntity<Void>(HttpStatus.CONFLICT);
}
productDao.add(product);
return new ResponseEntity<Void>(HttpStatus.CREATED);
}
答案 2 :(得分:0)
尝试这样的事情。添加RequestBody而不是ModelAttribute。
@RequestMapping(value = "/add", method= RequestMethod.POST, consumes="application/json")
public ResponseEntity<Void> createProduct(@RequestBody Product product) {
System.out.println("Creating Product " + product.getProductName());
if (productDao.isProductExit(product)) {
System.out.println("A Product with name " + product.getProductName() + " already exist");
return new ResponseEntity<Void>(HttpStatus.CONFLICT);
}
productDao.add(product);
return new ResponseEntity<Void>(HttpStatus.CREATED);
}