SpringMvc--后续(参数问题)

参数问题

package com.hwq.controller;

import com.hwq.beans.User;
import org.springframework.beans.propertyeditors.CustomDateEditor;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

import javax.servlet.http.HttpServletRequest;
import java.sql.Array;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import java.util.logging.SimpleFormatter;

@Controller
public class ParamController {

    @InitBinder
    public void initData(WebDataBinder web){
        //将日期格式转化成yyyy-MM-dd
        web.registerCustomEditor(Date.class,new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),true));
    }
    /*
    方式一:传统request接收参数
    param1?id=1

    get中文乱码问题:
        调整Tomcat服务器server.xml配置

    post中文乱码(偏码过滤器)
        在web.xml中配置过滤器
        <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
        <param-name>forceEncoding</param-name>
        <param-value>true</param-value>
        </init-param>
        </init-param>
        </filter>
        <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
        </filter-mapping>

     */

    @RequestMapping("/param1")
    public String Param1(HttpServletRequest request){
        String name = request.getParameter("name");
        System.out.println("name="+name);
        return "index";
    }
    /*
    方式二:直接使用参数接收参数
    param2?id=12
     */
    @RequestMapping("/param2")
    public String Param1(String name){
        System.out.println("id="+name);
        return "index";
    }
    /*
    方式三:使用数组接收参数      int integer[]
    param3?hobby=睡觉&hobby=打豆豆
     */
    @RequestMapping("/param3")
    public String Param3(String[] hobby){
        System.out.println("likes="+ Arrays.toString(hobby));
        return "index";
    }
    /*
    方式四:使用集合接收参数
    param4?hobby=睡觉&hobby=打豆豆
     */
    @RequestMapping("/param4")
    public String Param4(@RequestParam("hobby") List<String> hobby){
        System.out.println("likes="+ hobby);
        return "index";
    }
    /*
    方式五:日期   接收参数
        方式一:字符串接收
        param5?data=2019-09-09
        方式二:形式参数直接接收,这种方式对日期格式有严格要求yyyy/MM/dd
        param51?data=2019/09/09
        方式三:使用日期初始化绑定
            @InitBinder
            public void initData(WebDataBinder web){
            //将日期格式转化成yyyy-MM-dd
                 web.registerCustomEditor(Date.class,new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),true));
            }
     */
    @RequestMapping("/param5")
    public String Param5(String data){
        System.out.println("data="+ data);
        //将字符串转化成日期
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
        try {
            Date parse = simpleDateFormat.parse(data);
            System.out.println("parse="+parse);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        return "index";
    }
    @RequestMapping("/param51")
    public String Param51(Date data){
        System.out.println("data="+ data);
        //将字符串转化成日期
        return "index";
    }
    @RequestMapping("/param52")
    public String Param52(Date data){
        System.out.println("data="+ data);
        //将字符串转化成日期
        return "index";
    }
    /*
    方式六:RestFull风格传参
     */
    @RequestMapping("/param6/{id}/{name}")
    public String Param6(@PathVariable("id") Integer id, @PathVariable("name") String name){
        System.out.println("id="+id+"name="+name);
        return "index";
    }
    /*
        方式七:对象传参
         */
    @RequestMapping("/param7")
    public String Param7(User user){
        System.out.println("user="+user);
        System.out.println(user.getGroup());
        return "index";
    }


}

方式一:传统request接收参数

方式二:直接使用参数接收参数

创建一个add.jsp

方式三:使用数组接收参数

方式四:使用集合接收参数

方式五:日期 接收参数

/*
方式五:日期   接收参数
    方式一:字符串接收
    param5?data=2019-09-09
    方式二:形式参数直接接收,这种方式对日期格式有严格要求yyyy/MM/dd
    param51?data=2019/09/09
    方式三:使用日期初始化绑定
        @InitBinder
        public void initData(WebDataBinder web){
        //将日期格式转化成yyyy-MM-dd
             web.registerCustomEditor(Date.class,new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),true));
        }
 */
@RequestMapping("/param5")
public String Param5(String data){
    System.out.println("data="+ data);
    //将字符串转化成日期
    SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
    try {
        Date parse = simpleDateFormat.parse(data);
        System.out.println("parse="+parse);
    } catch (ParseException e) {
        e.printStackTrace();
    }
    return "index";
}
@RequestMapping("/param51")
public String Param51(Date data){
    System.out.println("data="+ data);
    //将字符串转化成日期
    return "index";
}
@RequestMapping("/param52")
public String Param52(Date data){
    System.out.println("data="+ data);
    //将字符串转化成日期
    return "index";
}

方式六:RestFull风格传参

创建一个User类

package com.hwq.beans;

import java.util.Date;
import java.util.List;

public class User {
    private int id;
    private String username;
    private String password;
    private int age;
    private List<String> hobby;
    private Date data;
    private Group group;

    public Group getGroup() {
        return group;
    }

    public void setGroup(Group group) {
        this.group = group;
    }

    public User() {
    }

    public User(int id, String username, String password, int age, List<String> hobby, Date data) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.age = age;
        this.hobby = hobby;
        this.data = data;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public List<String> getHobby() {
        return hobby;
    }

    public void setHobby(List<String> hobby) {
        this.hobby = hobby;
    }

    public Date getData() {
        return data;
    }

    public void setData(Date data) {
        this.data = data;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                ", hobby=" + hobby +
                ", data=" + data +
                '}';
    }
}

Group类

方式七:对象传参

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SpringMVC获取请求参数的方式有多种,最常用的是通过注解@RequestParam获取请求参数。例如,@RequestParam("username") String username表示获取名为username的请求参数,并将其赋值给String类型的变量username。另外,还可以通过HttpServletRequest对象获取请求参数,例如HttpServletRequest.getParameter("username")。此外,还可以使用@PathVariable注解获取URL路径中的参数,例如@RequestMapping("/user/{id}"),其中{id}表示获取路径中的id参数。 ### 回答2: SpringMVC是一种基于Java的web框架,用于开发web应用程序。通过SpringMVC框架,可以很方便地获取请求参数。 在SpringMVC中,获取请求参数有多种方式。其中,最常用的方式是通过方法的参数来获取请求参数。在控制器方法中定义参数参数名与请求参数名一致,SpringMVC会自动将请求参数的值绑定到对应的参数上。例如,如果请求中有一个参数名为"username"的参数,可以在控制器方法中定义一个同名的String类型的参数来接收该参数的值。 除了通过方法参数获取请求参数,还可以使用@RequestParam注解。该注解可以用于方法参数上,指定请求参数的名称,以及是否为必需的参数。例如,@RequestParam("id") int userId,表示要获取名为"id"的请求参数,并将其转换为int类型的userId参数。可以通过设置required属性来指定该参数是否必需,默认为true,如果请求中没有该参数,会抛出异常。 另外,还可以使用@PathVariable注解来获取路径参数。路径参数是在URL中定义的参数,可以通过在控制器方法的路径中使用占位符来表示。例如,@RequestMapping("/user/{id}"),可以通过@PathVariable("id")来获取路径中的参数值。 除了以上方式,还可以通过HttpServletRequest对象来获取请求参数。在控制器方法中,可以将HttpServletRequest对象作为方法参数传入,然后通过该对象的getParameter方法来获取请求参数的值。 总之,SpringMVC提供了多种简便的方式来获取请求参数。无论是通过方法参数、@RequestParam注解、@PathVariable注解,还是使用HttpServletRequest对象,都可以方便地获取请求参数的值,便于进行后续的业务逻辑处理。 ### 回答3: SpringMVC是基于Java的一种MVC(Model-View-Controller)框架,用于构建Web应用程序。在SpringMVC中,获取请求参数是非常常见的任务并且非常容易。 首先,要使用SpringMVC获取请求参数,你需要定义一个处理请求的控制器类,并在类的方法上添加@RequestMapping注解来指定请求的URL映射。 在控制器方法中,你可以使用@RequestParam注解来获取请求参数。该注解有几个属性可以使用,最常用的是value属性,用于指定请求参数的名称。例如,你可以使用@RequestParam("name")来获取名为name的请求参数。如果请求参数的名称与方法参数的名称相同,你也可以省略value属性,只使用@RequestParam注解。 @RequestParam注解也支持一些其他属性,例如required属性用于指示请求参数是否是必需的,默认为true,即必须提供该参数。你还可以使用defaultValue属性来指定请求参数的默认值。 除了@RequestParam注解,你还可以使用@PathVariable注解来获取URL路径中的参数。该注解将URL中的占位符与方法参数进行映射。例如,如果URL中有一部分为"/users/{id}",你可以在方法参数中使用@PathVariable("id")来获取该路径中的id参数。 另外,SpringMVC还支持通过@RequestParamMap注解来获取所有的请求参数,并以Map的形式进行处理。这对于处理不确定数量的请求参数非常有用。 总而言之,SpringMVC提供了多种方法来获取请求参数。你可以使用@RequestParam注解来获取单个请求参数,使用@PathVariable注解来获取URL路径中的参数,或者使用@RequestParamMap注解来获取所有的请求参数。这些功能使得处理请求参数变得非常方便和灵活。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值