2016-08-02 3 views
1

봄 MVC, Hibernate 및 MYSQL 데이터베이스를 사용하여 학생을 추가, 편집 및 삭제하는 학생 관리 웹 응용 프로그램을 개발했습니다.봄 MVC HTTP 상태 400

추가 및 편집 옵션이 제대로 작동하지만 삭제 클릭 할 때하는 것은 HTTP 상태를 (400)

컨트롤러의 삭제 기능은 차이가 URL에 같은 같은 편집이며 최대 절전 모드에서 삭제 기능 호출을 보여줍니다.

컨트롤러

package com.akhil.controller; 

import java.util.Map; 

import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.stereotype.Controller; 
import org.springframework.ui.Model; 
import org.springframework.ui.ModelMap; 
import org.springframework.validation.BindingResult; 
import org.springframework.web.bind.annotation.ModelAttribute; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RequestMethod; 
import org.springframework.web.bind.annotation.RequestParam; 
import org.springframework.web.servlet.mvc.annotation.ModelAndViewResolver; 

import com.akhil.model.Student; 
import com.akhil.service.StudentService; 

@Controller 
public class StudentController { 
@Autowired 
private StudentService studentService; 

@RequestMapping("/") 
public String setupForm(ModelMap model){ 
    Student student = new Student(); 
    model.addAttribute("student", student); 
    model.addAttribute("studentList", studentService.getAllStudent()); 
    return "student"; 
} 
@RequestMapping(value="/student.do", method=RequestMethod.POST) 
public String doActions(@ModelAttribute Student student, BindingResult result, @RequestParam String action, Map<String, Object> map){ 
    Student studentResult = new Student(); 
    studentService.add(student); 
    map.put("student", studentResult); 
    map.put("studentList", studentService.getAllStudent()); 
    return "student"; 
} 
@RequestMapping(value="/editstudent", method=RequestMethod.GET) 
public String editstudent(@RequestParam("studentId") int studentID, Model model) { 

    Student student = studentService.getStudent(studentID); 
    model.addAttribute(student); 
    return "student1"; 
    } 
@RequestMapping(value="/updatestudent.do", method=RequestMethod.POST) 
public String updatestudent(@ModelAttribute Student student, BindingResult result, @RequestParam String action, Map<String, Object> map){ 
    Student studentResult = new Student(); 
    studentService.edit(student); 
    //map.put("student", studentResult); 
    map.put("studentList", studentService.getAllStudent()); 
    return "student"; 
} 
@RequestMapping(value="/deletestudent", method=RequestMethod.GET) 
public String deletestudent(@RequestParam("studentId") int studentID, Model model) { 
    Student studentResult = new Student(); 
    studentService.delete(studentID); 
    model.addAttribute("student", studentResult); 
    model.addAttribute("studentList", studentService.getAllStudent()); 
    return "student"; 
    } 

}

보기

<%@ page language="java" contentType="text/html; charset=ISO-8859-1" 
pageEncoding="ISO-8859-1"%> 
<%@ include file="/WEB-INF/jsp/includes.jsp"%> 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> 
<title>Student Management</title> 
</head> 
<body> 
<h1>Students Data</h1> 
<form:form action="student.do" method="POST" commandName="student"> 
<table> 
    <tr> 
     <td><form:label path="studentId">Student ID:</form:label></td> 
     <td><form:input path="studentId" value="${Student.studentID}" /> </td> 
    </tr> 
    <tr> 
     <td>First name</td> 
     <td><form:input path="firstname" value="${Student.firstname}"/></td> 
    </tr> 
    <tr> 
     <td>Last name</td> 
     <td><form:input path="lastname" value="${Student.lastname}" /></td> 
    </tr> 
    <tr> 
     <td>Year Level</td> 
     <td><form:input path="yearLevel" value="${Student.yearLevel}" /> </td> 
    </tr> 
    <tr> 
     <td colspan="2"> 
      <input type="submit" name="action" value="Add" /> 
      <input type="submit" name="action" value="Edit" /> 
      <input type="submit" name="action" value="Delete" /> 
      <input type="submit" name="action" value="Search" /> 
     </td> 
    </tr> 
</table> 
</form:form> 
<br> 
<table border="1"> 
<tr> 
<th>ID</th> 
<th>First name</th> 
<th>Last name</th> 
<th>Year level</th> 
</tr> 
<c:forEach items="${studentList}" var="student"> 
    <tr> 
     <td>${student.studentId}</td> 
     <td>${student.firstname}</td> 
     <td>${student.lastname}</td> 
     <td>${student.yearLevel}</td> 
     <td align="center"><a href="editstudent.html? studentId=${student.studentId}">Edit</a> | <a href="deletestudent.html?studentIds=${student.studentId}">Delete</a></td> 
    </tr> 
</c:forEach> 
</table> 
</body> 
</html> 

답변

0

'삭제'링크가 잘못된 이름 (오히려 'studentId'가 아닌 'studentIdsssss')와 매개 변수를 보냅니다. @RequestParam은 기본적으로 'required = true'이므로 오류가 발생합니다.

그런데 '부작용'(예 : 수정, 삭제) 작업을 POST로 노출하는 것이 더 일반적입니다. 그러나 그것은 요점 외에도 간단한 데모를위한 것이라면 괜찮을 것입니다.

+0

감사합니다. 그것은 효과가 있었다. 하지만 내가 POST에 삭제를 변경하면 오류가 표시됩니다. 어디서나 변경해야합니까? –

관련 문제