二、@RequestMapping注解和参数的获取

1、@RequestMapping

@RequestMapping(value="/testRequestMapping", 
				method={RequestMethod.POST},
				params = {"username=jack"}, 
				headers = {"Accept"})

valuepath的作用都是指定请求路径,当有注解后面只有一个参数的时候可以直接写路径
params指定请求参数中必须包含username的属性,且值必须为jack
headers用于指定请求的信息中必须包含的请求头信息
其他文章总结:https://www.oschina.net/translate/using-the-spring-requestmapping-annotation

2、请求参数的获取

(1)获取路径中的参数
<a href="param/testParam?username=hehe&password=123"></a>

	//请求参数绑定
   @RequestMapping("/testParam")
   public String testParam(String username,String password){
       System.out.println("执行了...");
       System.out.println("用户名:"+username);
       System.out.println("密码:"+password);
       return "success";
   }
   执行了...
   用户名:hehe
   密码:123

(2)请求参数绑定把数据封装到JavaBean的类中

public class Account implements Serializable{
    private String username;
    private String password;
    private Double money;

    private User user;
    private List<User> list;
    private Map<String,User> map;
    
    @Override
    public String toString() {
        return "Account{" +
                "username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", money=" + money +
                ", user=" + user +
                ", list=" + list +
                ", map=" + map +
                '}';
    }
}
public class User implements Serializable{
    private String uname;
    private Integer age;
    private Date date;
    @Override
    public String toString() {
        return "User{" +
                "uname='" + uname + '\'' +
                ", age=" + age +
                ", date=" + date +
                '}';
    }
}

	<form action="param/saveAccount" method="post">
        姓名:<input type="text" name="username" /><br/>
        密码:<input type="text" name="password" /><br/>
        金额:<input type="text" name="money" /><br/>
        用户姓名:<input type="text" name="user.uname" /><br/>
        用户年龄:<input type="text" name="user.age" /><br/>
        <input type="submit" value="提交" />
    </form>

当post请求中有中文的时候,可以配置一个过滤器来解决

<!--配置解决中文乱码的过滤器-->
    <filter>
        <filter-name>characterEncodingFilter</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>
    </filter>
    <!--指定要过滤的请求路径为所有路径-->
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
@RequestMapping("/saveAccount")
public String saveAccount(Account account){
    System.out.println("执行了...");
    System.out.println(account);
    return "success";
}
执行了...
Account{username='张三', password='123', money=100.0, user=User{uname='李四', age=23, date=null}, list=null, map=null}
	<%--把数据封装Account类中,类中存在list和map的集合--%>
    <form action="param/saveAccount" method="post">
        姓名:<input type="text" name="username" /><br/>
        密码:<input type="text" name="password" /><br/>
        金额:<input type="text" name="money" /><br/>

        用户姓名:<input type="text" name="list[0].uname" /><br/>
        用户年龄:<input type="text" name="list[0].age" /><br/>

        用户姓名:<input type="text" name="map['one'].uname" /><br/>
        用户年龄:<input type="text" name="map['one'].age" /><br/>
        <input type="submit" value="提交" />
    </form>
@RequestMapping("/saveAccount")
public String saveAccount(Account account){
    System.out.println("执行了...");
    System.out.println(account);
    return "success";
}
执行了...
Account{username='张三', password='123', money=100.0, user=null, 
list=[User{uname='李四', age=25, date=null}], 
map={one=User{uname='王五', age=28, date=null}}}

(3)对请求参数进行转换

	<form action="param/saveUser" method="post">
        用户姓名:<input type="text" name="uname" /><br/>
        用户年龄:<input type="text" name="age" /><br/>
        用户生日:<input type="text" name="date" /><br/>
        <input type="submit" value="提交" />
    </form>
/**
 * 把字符串转换日期
 */
public class StringToDateConverter implements Converter<String,Date>{

    /**
     * String source    传入进来字符串
     * @param source
     * @return
     */
    public Date convert(String source) {
        // 判断
        if(source == null){
            throw new RuntimeException("请您传入数据");
        }
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
        try {
            // 把字符串转换日期
            return df.parse(source);
        } catch (Exception e) {
            throw new RuntimeException("数据类型转换出现错误");
        }
    }
}

在springmvc.xml中配置:

	<!--配置自定义类型转换器-->
    <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean">
        <property name="converters">
            <set>
                <bean class="com.liaoxiang.utils.StringToDateConverter"/>
            </set>
        </property>
    </bean>
@RequestMapping("/saveUser")
public String saveUser(User user){
    System.out.println("执行了...");
    System.out.println(user);
    return "success";
}
执行了...
User{uname='张三', age=12, date=Mon Dec 12 00:00:00 CST 1994}

(3)获取原生的API
<a href="param/testServlet">Servlet原生的API</a>

@RequestMapping("/testServlet")
    public String testServlet(HttpServletRequest request, HttpServletResponse response){
        System.out.println("执行了...");
        System.out.println(request);

        HttpSession session = request.getSession();
        System.out.println(session);

        ServletContext servletContext = session.getServletContext();
        System.out.println(servletContext);

        System.out.println(response);
        return "success";
    }
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@RequestMapping注解是Spring框架中的一个注解,用于将HTTP请求映射到特定的处理方法上。它可以用于类级别和方法级别,用于定义URL路径和HTTP请求方法,以及其他属性来处理请求。 在类级别上,@RequestMapping注解用于定义控制器类的根路径。例如,如果一个控制器类被注解为@RequestMapping("/api"),那么该类中的所有处理方法的路径都将以"/api"开头。 在方法级别上,@RequestMapping注解用于定义处理方法的路径和HTTP请求方法。路径可以是相对于类级别路径的相对路径,也可以是绝对路径。例如,如果一个处理方法被注解为@RequestMapping("/users"),那么它的完整路径将是类级别路径加上方法级别路径,即"/api/users"。 除了路径之外,@RequestMapping注解还可以指定其他属性,例如HTTP请求方法、请求参数、请求头等。这些属性可以帮助我们更精确地定义请求的处理方式。 下面是一个示例,演示了如何使用@RequestMapping注解来定义一个处理方法: ```java @RestController @RequestMapping("/api") public class UserController { @RequestMapping(value = "/users", method = RequestMethod.GET) public List<User> getUsers() { // 处理获取用户列表的逻辑 } } ``` 在上面的示例中,@RestController注解表示这是一个控制器类,@RequestMapping("/api")注解定义了类级别的根路径。而在getUsers()方法上,@RequestMapping注解定义了方法级别的路径"/users"和HTTP请求方法GET。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值