首页 > 代码库 > SpringMVC05使用注解的方式
SpringMVC05使用注解的方式
<body> <a href="http://www.mamicode.com/add">新增</a> <a href="http://www.mamicode.com/update">修改</a> <a href="http://www.mamicode.com/del">删除</a> </body>
<body> <a href="http://www.mamicode.com/add">新增</a> <a href="http://www.mamicode.com/update">修改</a> <a href="http://www.mamicode.com/del">删除</a> </body>
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <!-- 配置需要扫描的包 --> <context:component-scan base-package="cn.bdqn.controller"/> </beans>
@Controller public class MyController { /** * @RequestMapping("/add") 等于@RequestMapping(value="http://www.mamicode.com/add") * 如果只有value属性值,可以省略 * 代表用户访问的url * 新增 */ @RequestMapping("/add") public ModelAndView add(HttpServletRequest request, HttpServletResponse response) { return new ModelAndView("/WEB-INF/jsp/success.jsp", "result", "新增的方法......"); } // 修改 @RequestMapping("/update") public ModelAndView update(HttpServletRequest request, HttpServletResponse response) { return new ModelAndView("/WEB-INF/jsp/success.jsp", "result", "修改的方法......"); } // 删除 @RequestMapping("/del") public ModelAndView del(HttpServletRequest request, HttpServletResponse response) { return new ModelAndView("/WEB-INF/jsp/success.jsp", "result", "删除的方法......"); } }
=======================请求参数的传递========================
<body> <%-- 01.使用注解实现页面之间的跳转 --%> <a href="http://www.mamicode.com/user/add">增加</a> <a href="http://www.mamicode.com/user/update">修改</a> <a href="http://www.mamicode.com/user/del">删除</a> <%-- 02.请求中 携带参数 --%> <form action="user/addUser" method="post"> <input type="text" name="userName"/> <input type="password" name="pwd"/> <input type="submit" value="http://www.mamicode.com/新增"/> </form> </body>
package cn.bdqn.controller; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.servlet.ModelAndView; /** * @Controller: 就是配置我们的控制器 * * 既然 每个方法上面都有 user * 那么我们只需要在 @Controller中新增@RequestMapping("/user") * 就相当于我们的namespace! 每个方法的@RequestMapping中都前缀加上了/user */ @Controller @RequestMapping("/user") public class UserController { /** * @RequestMapping("/add") :用户访问的url /add 等同于 @RequestMapping(value="http://www.mamicode.com/add") * 如果只有一个value属性,则可以省略value,直接书写value 的属性值! * 如果有多个属性的时候,切记,value不能省略! */ @RequestMapping("/add") public String add(){ System.out.println("add"); return "success"; } @RequestMapping("/update") public String update(){ System.out.println("update"); return "success"; } /** * 通配符的使用 * *:只能是一级目录 * user/sasas/del true * user/sasas/sas/del false * **:可以没有 也可以多个目录! 0-N * user/sasas/del true * user/sasas/sas/del false */ @RequestMapping("/**/del") public String del(){ System.out.println("del"); return "success"; } /** * 请求中携带参数 * @RequestMapping(value=http://www.mamicode.com/{"/addUser","/haha","heihei"}) * @RequestMapping({"/addUser","/haha","heihei"}) * 多个请求 都会匹配我们当前的方法 @RequestMapping(value=http://www.mamicode.com/{"/addUser","/haha","heihei"}) public String addUser(HttpServletRequest request,HttpServletResponse response){ System.out.println(request.getParameter("userName")); System.out.println(request.getParameter("pwd")); return "success"; } */ /** * params={"userName"}:请求过来的时候,参数必须有userName * params={"!userName"}:请求过来的时候,参数必须没有userName * params={"userName=admin"}:请求过来的时候,参数userName的值必须是admin */ @RequestMapping(value="http://www.mamicode.com/addUser",params={"userName=admin"}) public String addUser(HttpServletRequest request,HttpServletResponse response){ System.out.println(request.getParameter("userName")); System.out.println(request.getParameter("pwd")); return "success"; } }
======================获取前台的数据 并解决乱码问题=======================
在index页面新增
<%-- 03.请求中 携带参数 后台接收的时候出现乱码 并且返回 get方式乱码: conf文件夹下面的server.xml文件中配置 URIEncoding=UTF-8 post:使用filter ! spring mvc给你写好了!我们需要配置即可! --%> <form action="user/addUser2" method="post"> <input type="text" name="userName"/> <input type="password" name="pwd"/> <input type="submit" value="http://www.mamicode.com/新增"/> </form>
在controller中新增
@RequestMapping(value="http://www.mamicode.com/addUser2") public String addUser2(HttpServletRequest request,HttpServletResponse response){ System.out.println(request.getParameter("userName")); System.out.println(request.getParameter("pwd")); return "success"; }
发现乱码问题,在web.xml文件中新增
<!--解决post请求乱码的问题 --> <filter> <filter-name>charset</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <!--保证后台的encoding 不为空 而且还设置了编码格式 --> <init-param> <param-name>encoding</param-name> <param-value>utf-8</param-value> </init-param> <!-- 底层代码 this.encoding != null && (this.forceEncoding || request.getCharacterEncoding() == null) request.getCharacterEncoding():什么时候不为null 01.前台设置了contentType="text/html; charset=ISO-8859-1" 02.设置request.setCharacterEncoding() 我们必须强制的让forceEncoding=true --> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>charset</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
Request.getCharacterEncoding()
有两种情况不会为null
第一种是在jsp页面设置了contentType="text/html; charset=ISO-8859-1"
还有一种就是setCharacterEncoding了
一旦前台设置了contentType="text/html; charset=ISO-8859-1"
那么就会默认执行前台设置的编码! 为了按照我们定义的编码格式
所以 需要在web.xml中也要摄者forceEncoding=true
这样就能保证无论前台有没有设置 都会执行我们设置的utf-8格式
SpringMVC05使用注解的方式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。