java.lang.IllegalStateException:bean 名称 'userData' 的 BindingResult 和普通目标对象都不能用作请求属性

java.lang.IllegalStateException: Neither BindingResult nor plain target object for bean name 'userData' available as request attribute

我是 spring mvc 的新手。我正在尝试使用 MySQL jdbc 在 spring 中制作简单的 crud。对于数据映射,我使用了 spring 形式。每当我尝试使用 spring 表单时,它都会显示错误

Error is here

每当我删除 spring 表格并使用普通表格时,它看起来没问题,但在使用 spring 表格时显示错误。错误显示 java.lang.IllegalStateException:Bean 名称 'userData' 的 BindingResult 和普通目标对象都不能用作请求属性

header.jsp

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@taglib prefix="form" uri="http://www.springframework.org/tags/form" %>

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>JSP Page</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

    </head>
    <body>
        <nav class="navbar navbar-inverse">
            <div class="container-fluid">
                <div class="navbar-header">
                    <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#myNavbar">
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span> 
                    </button>
                    <a class="navbar-brand" href="#">SpringCRUDDemo</a>
                </div>
                <div class="collapse navbar-collapse" id="myNavbar">
                    <ul class="nav navbar-nav">
                        <li><a href="<c:url value='/'/>">Home</a></li>
                        <li><a href="<c:url value='/view/'/>">View</a></li>
                        <li><a href="#">Update</a></li> 
                        <li><a href="#">Delete</a></li> 
                    </ul>
                    <ul class="nav navbar-nav navbar-right">
                        <li><a href="#"><span class="glyphicon glyphicon-user"></span> Sign Up</a></li>
                        <li><a href="#"><span class="glyphicon glyphicon-log-in"></span> Login</a></li>
                    </ul>
                </div>
            </div>
        </nav>

index.jsp

<%@include file="./shared/header.jsp" %>

<div class="container">
    <form:form commandName="userData" action="#" method="post" enctype="multipart/form-data">
        <label for="firstname" class="label">Enter your first name</label> 
        <form:input path="firstName"/>
    </form:form>
</div>

servlet class

package com.nishan.springcruddemo.servlet;

import com.nishan.springcruddemo.daoimp.CustomerDaoImp;
import com.nishan.springcruddemo.entity.Customer;
import java.sql.SQLException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

/**
 *
 * @author Dell
 */
@Controller

public class DefaultController {

    @Autowired
    CustomerDaoImp customerDaoImp;

    @RequestMapping(value = "/", method = RequestMethod.GET)
    public String index() {
        return "index";
    }

    @RequestMapping(value = "/insert", method = RequestMethod.POST)
    public String save(@ModelAttribute("userData") Customer customer) {
        try {
            customerDaoImp.insert(customer);
        } catch (ClassNotFoundException | SQLException ex) {
            System.out.println(ex.getMessage());
        }

        return "redirect:/index";
    }

    @RequestMapping(value = "/view", method = RequestMethod.GET)
    public String viewCustomer() {
        return "view-customer";
    }
}

您必须使用@RequestParam 来获取单个值。

要将表单数据与模型绑定 class 您需要将模型 (POJO) 创建为 userData commandName="userData"。CommandName 和 ModelClass 名称相同。

class 的字段 firstName 并且两者相同。然后你的表单数据与 Pojo 绑定它将到达你的控制器 Class.

希望对您有所帮助。