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