Springmvc controller获取不到jsp中的数据

今天在练习一个SSM例子中,在最后的数据修改提交的过程中出现了一个有意思的错误,记录下来。


首先是在数据列表中通过点击修改跳转到对应的controller后台函数中,其中传递的是数据对应的id。
如下图:

这里写图片描述

对应的接收方法如下,这里使用的无返回值类型的返回方式:

@RequestMapping(value="/editItems", method=RequestMethod.GET)
        public void editItems(HttpServletRequest request,HttpServletResponse response,Integer id) throws Exception{
            ItemsCustom itemsCustom = itemsService.findItemsById(id);
            request.setAttribute("itemsCustom", itemsCustom);

            request.getRequestDispatcher("/WEB-INF/jsp/editItem.jsp").forward(request, response);;
        }

负责修改数据的conntroller方法:

@RequestMapping("/editItemSubmit")
        public String editItemSubmit(Integer id,ItemsCustom itemsCustom) throws Exception
        {

            System.out.println("id="+id);
            System.out.println("itemsCustom:"+itemsCustom);
            itemsService.updateItems(id,itemsCustom);
            //请求转发
//          return "forward:queryItems.action";

            //重定向
           return "redirect:queryItems.action";
        }

跳转到修改页面后,本以为修改完数据后就好了,但是发现修改完数据后,数据库中的数据并没有发生变化,其中更新数据的函数是通过MyBatis Generator生成的,所以函数是没有问题,可定是在数据的传递过程中出现的问题。

通过syso发现id和itemsCustom中的id并没有传递到controller中

这里写图片描述

但是神奇的地方出现了,如果是id的数据没有传递过来还可以理解,但是itemsCustom对象中id也变成了空值,而对象中其他的数据没有丢失。

对象数据部分丢失我还是第一次遇到,这我就有点慌了 这里写图片描述


通过一步步的数据观察,最后找到问题所在,原来在修改页面的表单提交中

这里写图片描述

在隐藏input中定义的id属性时,用el表达式忘记使用param.XXX来获取传递参数中的id值了,但是具体为什么hidden中的id会替换掉对象中的id的值,这个我查了半天也没有查到,但是我想是因为id值为itemsCustom对象属性值的一部分,所以才会发生空的id值替换itemsCustom中id的数据,导致后面中获取不到id的值无法对数据进行更新。

还是在看EL表达式的时候没有细心看,其中通过EL获取对象值可以看下这篇博客 http://xvshell.iteye.com/blog/762026

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
poi解析excel功能参数说明 此项目是基于springMVC实现的,基本流程为从前台jsp页面使用Ajax文件上传导入excel文件(.xls(97-03)/.xlsx(07以后)),传到后台controller调用相应工具类解析后返回指定参数做后续处理. 1. POIUtil.java工具类 解析通过MutilpartFile导入的Excel并解析里面数据,先判断文件的类型(excel处理有两种此处为两种通用)是.xls/.xlsx,通过workbook.getNumberOfSheets()获取工作簿数量,遍历工作簿,sheet.getLastRowNum()获取最大行数,将每行数据放入List list = new Array List(),并根据excel数据类型将器转换为字符串、数字、Boolean、公式、空值类型防止出现错误,最后返回一个list. 2. ExcelUtil.java工具类 解析通过MutilpartFile导入的Excel并解析里面数据,先判断文件的类型(excel处理有两种此处为两种通用)是.xls/.xlsx,采用Apache的POI的API来操作Excel,读取内容后保存到List,再将List转Json(使用Linked,增删快,与Excel表顺序保持一致),Sheet表1————>List1<Map> 步骤1:根据Excel版本类型创建对于的Workbook以及CellSytle 步骤2:遍历每一个表的每一行的每一列,这里做了些小改动,因为后续可能解析过后可能会保存入数据库,这里为第一行数据添加一个自定义表头 String[] p = new String[]{"name","age","sex","tel","address","e-mail","phone"}; 遍历的列数量以p的length为准 步骤3:一个sheet表就是一个Json,多表就多Json,对应一个 List 一个sheet表的一行数据就是一个 Map 一行的一列,就把当前列头为key,列值为value存到该列的Map Map 一个线性Hash Map,以Excel的sheet表顺序,并以sheet表明作为key,sheet表转换Json后的字符串作为value 最后返回一个LinkedHashMap 3. ExcelToJsonPoi.java工具类 这个与上面工具类类似,不过这个是解析本地excel文件不是使用的流,使用迭代遍历sheet工作簿与每行每列的值,将所有类型作为String类型处理返回一个json对象输出控制台
本项目是用的spring springMVC myBatis框架,前段没用框架,只写了简单的页面效果,做增删查改 这是我系统学习所得,希望能对你有所帮助 项目部署: 1;导包,就是web-inf下lib,让后把这些选,单击右键build path -->add library 2;web.xml配置文件,这里几乎不需要改,以后要用只需要复制就行 3;具体框架配置文件,都集在了sourceConfig文件夹下,这个自己琢磨,以后再用这个框架也是几乎不需要改的,之所以说几乎,是因为只需要改包名就可以了 4;写bean,写dao,写service,写controller,这是重点 5;bean下写要操作的数据表,记住这个类药与数据的表一致,最好一模一样,避免麻烦 6;dao下写数据库操作内容,那下面有两个文件名一样的,一个是java文件,一个是xml文件,java文件是定义方法名,xml文件是让你写具体的数据操作方法的,格式就是这样,你看看就能懂,你只需要这样写,这个框架就可以识别,吧你在xml写的数据库操作方法匹配到java文件的方法,这是mybatis做的事 7;service包放你的业务逻辑层,具体来说就是,dao只放数据操作,service引用数据操作,还可以有其他操作 8;controller类的格式你要用心点了,这个是控制器,控制请求的跳转,他和servlet的功能类似, 功能引导: 为了让你更方便了解这个项目,说一下流程 1.把项目部署到tomcat,启动服务, 2.在浏览器输入http://localhost:8080/AscentSys/user/in.do 3.这个命令的意思是,访问这个项目地址user/in.do,然后这个请求就会发送到controller,在controller首先匹配到user,在匹配到in.do就调到具体的方法去处理这个情求了,这里会跳转到users文件夹下的login.jsp页面,解释一下,在spring-servlet.xml配置文件有一句路径解析的,“前缀后缀”那个bean,意思是在返回的东西加前缀后缀,这里写的是啥你琢磨琢磨可以明白的 4.在login.jsp页面,有个提交地址,是login.do,按上面说的,在controller首先匹配到user,在匹配到login.do就调到具体的方法去处理这个情求了,后面的流程我就不说了,自己看 5。再说一点,return的好多字符串,有的是redirect:/user/userlist.do这样的格式,意思是转发,就是转到另一个请求去,同理,具体意思是,在controller首先匹配到user,在匹配到userlist.do就调到下面的方法去处理这个情求了, 6,关于传参数的问题,在表单写的属性,在controller自动接收,也可以接受user对象,如果是对象,那个表单的格式你要看仔细了和一般表单的不同之处。琢磨琢磨你会明白的, 希望能对你有所帮助
### 回答1: 如果在使用Spring MVC访问controller时遇到404错误,通常是因为controller没有正确映射到请求路径。确保使用了@RequestMapping或@GetMapping注解来映射请求路径,并且路径是正确的。还要检查是否在Spring配置文件正确配置了路径映射。 ### 回答2: Spring MVC框架是一种基于MVC设计模式的Java Web应用框架,可以快速开发Web应用程序。在使用Spring MVC框架开发Web应用过程,有时候会发现在访问Controller的时候会出现404的错误。 出现这种问题的原因一般有以下几个方面: 1. URL映射错误:在Spring MVC框架Controller的URL映射是根据@RequestMapping注解来完成的。如果URL映射设置错误或者Controller没有正确的映射,就会出现404错误。 2. Controller没有在Spring MVC配置文件进行配置:当我们创建一个Controller类的时候,需要将该类注册到Spring MVC框架。如果没有在Spring MVC配置文件进行配置,就会出现404错误。 3. 没有编写视图页面:当Controller找到了相应的处理方法并经过处理之后,需要将结果返回给浏览器。这个结果一般是一个视图页面。如果没有编写相应的视图页面,就会出现404错误。 解决上述问题的方法如下: 1. 检查URL映射是否正确:需要检查Controller的@RequestMapping注解设置是否正确,并且需要注意大小写。如果发现设置有误,需要进行修改。 2. 将Controller注册到Spring MVC框架:需要在Spring MVC配置文件Controller进行配置,例如可以使用@ComponentScan注解进行扫描并注册。 3. 编写相应的视图页面:需要对于每一个Controller的处理方法都编写相应的视图页面,并且可以根据业务逻辑进行模板化编写,提高代码的复用性。 总之,出现Spring MVC访问Controller 404错误的原因一般有很多种,需要根据具体情况进行排查,找到问题的根源,并采取相应的解决措施。只有理解了错误的原因,才能够顺利地解决问题。 ### 回答3: Spring MVC框架是一种开源的、基于MVC(Model-View-Controller)模型的Web框架,它在Java EE平台上提供了一种优雅而灵活的方式,帮助我们构建Web应用程序。在使用Spring MVC框架时,我们希望访问的处理器(Controller)可以被正确的映射,并正确的处理请求。但有时候会遇到Spring MVC访问Controller出现404错误的情况,接下来我们来分析一下Spring MVC访问Controller404的解决办法。 1.配置错误:我们在Spring MVC的配置文件,可能会出现一些配置错误,如Controller类路径或方法名错误、请求路径配置错误等导致404错误。这时候我们需要仔细查看配置文件,确认配置是否正确,如在RequestMapping注解路径拼写错误等。 2.包名与访问路径不匹配:在Spring MVC,只有请求地址正确与Controller类的包名匹配时,才能访问到正确的Controller。如果Controller类的包名与请求地址不匹配,就会出现404错误。解决方法可以在Controller类上使用RequestMapping注解,指定正确的请求路径。 3.缺少必要的组件:当我们在执行Spring MVC项目时,需要一些必要的组件来支持此框架的运行,如JSP/HTML,Tomcat等,如果这些组件缺失或者配置错误,就会出现404错误。 4.访问路径有误:我们在访问Controller时,可能会出现访问路径出错的情况,要检查访问的URL地址是否正确,是否携带了必要的参数等。 总之,在解决Spring MVC访问Controller 404错误时,需要先仔细检查代码、配置等问题,逐一排查,找到具体原因,然后进行针对性的修复。同时也需要对错误有一个良好的分析能力,找到根源。只有这样,才能顺利的运行一个Spring MVC框架项目。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值