文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringMVC 参数绑定(视图传参到控制器)

2023-08-23 07:08

关注

在这里插入图片描述

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。
🍎个人主页:Java Fans的博客
🍊个人信条:不迁怒,不贰过。小知识,大智慧。
💞当前专栏:SSM 框架从入门到精通
✨特色专栏:国学周更-心性养成之路
🥭本文内容:SpringMVC 参数绑定(视图传参到控制器)

在这里插入图片描述

1、基本数据类型

要求前台页面的表单输入框的name属性值与对应控制器方法中的形式参数名称与类型一致,控制器方法就能接收到来自前台表单传过来的参数,即请求参数与方法形参要完全相同,这些参数由系统在调用时直接赋值,程序员可在方法内直接使用。

项目案例: 输入学生姓名、年龄和分数,提交成功则跳转到提交成功的界面并展示数据。

关键步骤:

【1】在 Controller 层新建一个 TestController1 类,并添加一个方法,代码如下:

package cn.hh.test02.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.servlet.ModelAndView;@Controller@RequestMapping("testc1")public class TestController1 {    @RequestMapping("login")    public ModelAndView login(String sName,int sAge, double sScore ){        ModelAndView mv = new ModelAndView();        mv.setViewName("test1/show");        mv.addObject("currentShow",sName+"年龄:"+sAge+",分数:"+sScore);        return mv;    }}

【2】在 webapp 目录下,新建一个目录 test1,在 test1 中新建 test1.jsp 文件,代码如下:

<%--  Created by IntelliJ IDEA.  User: hhzb100  Date: 2023/2/28  Time: 10:23  To change this template use File | Settings | File Templates.--%><%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head>    <title>Titletitle>head><body><form action="../testc1/login">    姓名:<input type="text" name="sName">    年龄:<input type="text" name="sAge">    分数:<input type="text" name="sScore">    <input type="submit" value="提交数据">form>body>html>

【3】再在上面的目录里新建 show.jsp 文件,代码如下:

<%--  Created by IntelliJ IDEA.  User: hhzb100  Date: 2023/2/26  Time: 11:29  To change this template use File | Settings | File Templates.--%><%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head>    <title>Titletitle>head><body><h1>提交成功!${currentShow}h1>body>html>

【4】在浏览器中输入 http://localhost:8080/testspringmvc02/test1/test1.jsp,如下图:

在这里插入图片描述

添加数据并提交,展示效果如下:

在这里插入图片描述

1.1 表单 name 属性值与方法参数名称不一致解决方案

当表单的 name 属性值与方法参数的名称不同时,会出现如下图所示的500错误:

在这里插入图片描述

表单的 name 属性值内容修改如下:

<form action="../testc1/login">    姓名:<input type="text" name="stuName">    年龄:<input type="text" name="stuAge">    分数:<input type="text" name="stuScore">    <input type="submit" value="提交数据">form>

而 TestController1 处理器中的方法参数分别为:sName、sAge、sScore;

则在接受方法的形参前面加个 @RequestParam(“表单 name 属性值”), TestController1 类代码修改如下:

    //1、表单 name 属性值与方法参数名称不一致解决方案    @RequestMapping("login")    public ModelAndView login(@RequestParam("stuName") String sName, @RequestParam("stuAge")int sAge, @RequestParam("stuScore")double sScore ){        ModelAndView mv = new ModelAndView();        mv.setViewName("test1/show");        mv.addObject("currentShow",sName+"年龄:"+sAge+",分数:"+sScore);        return mv;    }

1.2 表单 name 属性值为空时解决方案

当表单某个 name 属性值为空时,运行效果如下:

在这里插入图片描述

解决办法: 设置基本参数类型的默认值 @RequestParam(defaultValue = “xx”);修改 TestController1 类代码如下:

package cn.hh.test02.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.servlet.ModelAndView;@Controller@RequestMapping("testc1")public class TestController1 {    @RequestMapping("login")    public ModelAndView login(@RequestParam(defaultValue = "张三") String sName, @RequestParam(defaultValue = "20") int sAge,  @RequestParam(defaultValue = "88.8") double sScore ){        ModelAndView mv = new ModelAndView();        mv.setViewName("test1/show");        mv.addObject("currentShow",sName+"年龄:"+sAge+",分数:"+sScore);        return mv;    }}

修改后的运行效果如下:

在这里插入图片描述

2、包装数据类型(推荐使用)

使用基本类型的包装类,实现参数接收,避免使用基本类型接收参数时,将null值赋予基本类型变量抛出异常的问题。之前基本数据类型会报500错误,包装数据类型不会报错。

    @RequestMapping("login")    public ModelAndView login(String sName, Integer sAge, Double sScore ){        ModelAndView mv = new ModelAndView();        mv.setViewName("test1/show");        mv.addObject("currentShow",sName+"年龄:"+sAge+",分数:"+sScore);        return mv;    }

当不赋值时的运行效果如下,不会报500错误。

在这里插入图片描述

3、@RequestParam() 属性

@RequestParam()有三个属性:

接收数组参数的关键点有两个:

  1. 前台表单有多个表单域的name属性相同;
  2. 控制器方法用这个name值命名的数组作为参数。

项目案例: 页面有多个兴趣爱好供选择,选择好后,控制台能显示出来。

关键步骤:

【1】在 cn.hh.test02.controller 目录下添加 TestController2 类,代码如下:

package cn.hh.test02.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.servlet.ModelAndView;@Controller@RequestMapping("testc2")public class TestController2 {    @RequestMapping("interest")    public String interest(String[] myInterest){        System.out.println("我的兴趣爱好有:");        for (String s : myInterest) {            System.out.println("interest = " + s);        }        return "test1/interest";    }}

【2】在 src/main/webapp/test1 目录下新建 interest.jsp,代码如下:

<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head>    <title>Titletitle>head><body>我的兴趣爱好<br/><form action="../testc2/interest">    摄影:<input type="checkbox" name="myInterest" value="摄影"/><br/>    跳舞:<input type="checkbox" name="myInterest" value="跳舞"/><br/>    旅游:<input type="checkbox" name="myInterest" value="旅游"/><br/>    阅读:<input type="checkbox" name="myInterest" value="阅读"/><br/>    <input type="submit" value="确定"/>form><br/>观测控制台的输出body>html>

【3】运行测试:

在这里插入图片描述

确定兴趣爱好,观察控制台,控制台打印如下:

在这里插入图片描述

方法 Delete5(User user) 可只用一个实体类作形式参数,前提是这个实体类的各个属性要与前台表单穿过来的各个 name 属性值相同。

关键步骤:

【1】创建实体类 User 类,代码如下:

package cn.kgc.springmvc02.entity;import lombok.Data;@Datapublic class User {    private String uName;    private Integer uAge;}

【2】在 cn/kgc/springmvc02/controller 目录下,新建 ParamController 类,代码如下:

package cn.kgc.springmvc02.controller;import cn.kgc.springmvc02.entity.User;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RequestParam;@Controller@RequestMapping("param")public class ParamController {    @RequestMapping("delete")    public String Delete5(User user) {        System.out.println("user = " + user);        return "show";    }}

【3】在 src/main/webapp 目录下创建 show.jsp,代码如下:

<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head>    <title>Titletitle>head><body>    <h1>删除成功!h1>body>html>

【4】页面展示效果

在这里插入图片描述

【5】控制台打印效果

在这里插入图片描述

什么是REST风格:把请求参数变为请求路径的一种编程风格。 通过路径变量的使用,可以实现REST风格的编程。

传统的编程风格中,某项事物列表Web页面,要想一个个编辑,需要每一项中有类似这种超链接:
/restfuls?id=1
其中每一项的id不同。而采用RESTful风格后,超链接将变成:
/ restfuls/1 或者 1/restfuls 意义一样。

restful风格请求方式说明
/usersget查询全部列表数据
/users/1get根据 id 查询一条数据
/users/1delete根据 id 删除一条数据
/userspost添加数据,参数以json格式进行传递
/usersput修改数据

@PathVariable 映射 URL 绑定的占位符:

通过 @PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中:URL 中的 {xxx} 占位符可以通过

@PathVariable(“xxx”) 绑定到操作方法的入参中。

一般与 @RequestMapping(“xxx”) 一起使用

项目代码:

package cn.kgc.springmvc02.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.*;@Controller@RequestMapping("restfuls")public class RestfulController {    //1、列表查询    @GetMapping    public String getList(){        System.out.println("列表数据展示");        return "show";    }    //2、查询一个    @GetMapping("{id}")    public String getDataById(@PathVariable Integer id){        System.out.println("查询id = " + id);        return "show";    }    //3、根据 id 删除一条数据    @DeleteMapping("{id}")    public String deleteById(@PathVariable Integer id){        System.out.println("删除id = " + id);        return "show";    }    //4、添加数据    @PostMapping    public String addData(){        return "show";    }    //5、修改数据    @PutMapping("{id}")    public String updateData(@PathVariable Integer id){        System.out.println("修改id = " + id);        return "show";    }}

运行测试:

【1】列表查询(请求地址:/restfuls;请求方式:GET)

在这里插入图片描述

控制台打印:

在这里插入图片描述

【2】查询一个(请求地址:/restfuls/1;请求方式:GET)

在这里插入图片描述

控制台打印:

在这里插入图片描述

【3】根据 id 删除一条数据(请求地址:/restfuls/1;请求方式:DELETE)

在这里插入图片描述

控制台打印:

在这里插入图片描述

【4】添加数据(请求地址:/restfuls;请求方式:POST)

在这里插入图片描述

控制台打印:

在这里插入图片描述

【5】修改数据(请求地址:/restfuls/1;请求方式:PUT)

在这里插入图片描述

控制台打印:

在这里插入图片描述

1、中文乱码问题

对于上面案例所请求的参数,若含有中文,可能会出现中文乱码问题,SpringMVC 对于请求参数中的中文乱码问题,提供了专门的字符集过滤器,只需要在web.xml配置文件中注册字符串过滤器即可解决中文乱码问题。上面项目若要解决乱码问题,只需在 web.xml 中添加如下配置即即可:

<filter>        <filter-name>characterEncodingFilterfilter-name>        <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class>        <init-param>            <param-name>encodingparam-name>            <param-value>UTF-8param-value>        init-param>        <init-param>            <param-name>forceEncodingparam-name>            <param-value>trueparam-value>        init-param>    filter>    <filter-mapping>        <filter-name>characterEncodingFilterfilter-name>        <url-pattern>/*url-pattern>    filter-mapping>

2、使用 ModelAndView,页面却获取不到值

有时候我们使用 ModelAndView 添加模型数据的时候,页面用${ } 获取不到相应的值,也面效果如下:

在这里插入图片描述

造成这个问题的原因是项目中的 web.xml 文件内容有问题,先看看未修改前的头部内容:

<web-app>  <display-name>Archetype Created Web Applicationdisplay-name>

修改后的web.xml内容:

<web-app version="2.5"         xmlns="http://java.sun.com/xml/ns/javaee"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee        http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  <display-name>Archetype Created Web Applicationdisplay-name>

修改之后,便可以解决这个问题!


  码文不易,本篇文章就介绍到这里,如果想要学习更多Java系列知识点击关注博主,博主带你零基础学习Java知识。与此同时,对于日常生活有困扰的朋友,欢迎阅读我的第四栏目《国学周更—心性养成之路》,学习技术的同时,我们也注重了心性的养成。

在这里插入图片描述

来源地址:https://blog.csdn.net/hh867308122/article/details/129255336

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯