一、SpringMVC注解入门

1. 创建web项目
2. 在springmvc的配置文件中指定注解驱动,配置扫描器

  1. <!-- mvc的注解驱动 -->
  2. <mvc:annotation-driven />
  3. <!--只要定义了扫描器,注解驱动就不需要,扫描器已经有了注解驱动的功能 -->
  4. <context:component-scan base-package="org.study1.mvc.controller" />
  5. <!-- 前缀+ viewName +后缀 -->
  6. <bean
  7. class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  8. <!-- WebContent(WebRoot)到某一指定的文件夹的路径 ,如下表示/WEB-INF/view/*.jsp -->
  9. <property name="prefix" value="/WEB-INF/view/"></property>
  10. <!-- 视图名称的后缀 -->
  11. <property name="suffix" value=".jsp"></property>
  12. </bean>

<context:component-scan/> 扫描指定的包中的类上的注解,常用的注解有:

@Controller 声明Action组件
@Service    声明Service组件    @Service("myMovieLister") 
@Repository 声明Dao组件
@Component   泛指组件, 当不好归类时. 
@RequestMapping("/menu")  请求映射
@Resource  用于注入,( j2ee提供的 ) 默认按名称装配,@Resource(name="beanName") 
@Autowired 用于注入,(srping提供的) 默认按类型装配 
@Transactional( rollbackFor={Exception.class}) 事务管理
@ResponseBody
@Scope("prototype")   设定bean的作用

3. @controller:标识当前类是控制层的一个具体的实现
4. @requestMapping:放在方法上面用来指定某个方法的路径,当它放在类上的时候相当于命名空间需要组合方法上的requestmapping来访问。

  1. @Controller // 用来标注当前类是springmvc的控制层的类
  2. @RequestMapping("/test") // RequestMapping表示 该控制器的唯一标识或者命名空间
  3. public class TestController {
  4. /**
  5. * 方法的返回值是ModelAndView中的
  6. */
  7. @RequestMapping("/hello.do") // 用来访问控制层的方法的注解
  8. public String hello() {
  9. System.out.println("springmvc annotation... ");
  10. return "jsp1/index";
  11. }
  12. //*****
  13. }

在本例中,项目部署名为mvc,tomcat url为 http://localhost,所以实际为:http://localhos/mvc

在本例中,因为有命名空间 /test,所以请求hello方法地址为:http://localhost/mvc/test/hello.do

输出:springmvc annotation...

二、注解形式的参数接收

1. HttpServletRequest可以直接定义在参数的列表,通过该请求可以传递参数

url:http://localhost/mvc/test/toPerson.do?name=zhangsan

  1. /**
  2. * HttpServletRequest可以直接定义在参数的列表,
  3. *
  4. */
  5. @RequestMapping("/toPerson.do")
  6. public String toPerson(HttpServletRequest request) {
  7. String result = request.getParameter("name");
  8. System.out.println(result);
  9. return "jsp1/index";
  10. }

可以从HttpServletRequest 取出“name”属性,然后进行操作!如上,可以取出 “name=zhangsan”

输出:zhangsan
2. 在参数列表上直接定义要接收的参数名称,只要参数名称能匹配的上就能接收所传过来的数据, 可以自动转换成参数列表里面的类型,注意的是值与类型之间是可以转换的

2.1传递多种不同类型的参数:

url:http://localhost/mvc/test/toPerson1.do?name=zhangsan&age=14&address=china&birthday=2000-2-11

  1. /**
  2. * 传递的参数的名字必须要与实体类的属性set方法后面的字符串匹配的上才能接收到参数,首字符的大小写不区分
  3. * 请求中传的参数只要是能和参数列表里面的变量名或者实体里面的set后面的字符串匹配的上就能接收到 a
  4. *
  5. */
  6. @RequestMapping("/toPerson1.do")
  7. public String toPerson1(String name, Integer age, String address,
  8. Date birthday) {
  9. System.out.println(name + " " + age + " " + address + " " + birthday);
  10. return "jsp1/index";
  11. }
  12. /**
  13. * 注册时间类型的属性编辑器,将String转化为Date
  14. */
  15. @InitBinder
  16. public void initBinder(ServletRequestDataBinder binder) {
  17. binder.registerCustomEditor(Date.class, new CustomDateEditor(
  18. new SimpleDateFormat("yyyy-MM-dd"), true));
  19. }

输出:zhangsan 14 china Fri Feb 11 00:00:00 CST 2000

2.2传递数组:

url:http://localhost/mvc/test/toPerson2.do?name=tom&name=jack

  1. /**
  2. * 对数组的接收,定义为同名即可
  3. */
  4. @RequestMapping("/toPerson2.do")
  5. public String toPerson2(String[] name) {
  6. for (String result : name) {
  7. System.out.println(result);
  8. }
  9. return "jsp1/index";
  10. }

输出:tom jack

2.3传递自定义对象(可多个):

url:http://localhost/mvc/test/toPerson3.do?name=zhangsan&age=14&address=china&birthday=2000-2-11

User 定义的属性有:name,age,并且有各自属性的对应的set方法以及toString方法

Person定义的属性有:name,age.address,birthday,并且有各自属性的对应的set方法以及toString方法

  1. /**
  2. *
  3. * 传递的参数的名字必须要与实体类的属性set方法后面的字符串匹配的上才能接收到参数,首字符的大小写不区分
  4. * 请求中传的参数只要是能和参数列表里面的变量名或者实体里面的set后面的字符串匹配的上就能接收到
  5. *
  6. */
  7. @RequestMapping("/toPerson3.do")
  8. public String toPerson3(Person person, User user) {
  9. System.out.println(person);
  10. System.out.println(user);
  11. return "jsp1/index";
  12. }

输出:

Person [name=zhangsan, age=14, address=china, birthday=Fri Feb 11 00:00:00 CST 2000]
User [name=zhangsan, age=14]

自动封装了对象,并且被分别注入进来!

三、注解形式的结果返回

1. 数据写到页面,方法的返回值采用ModelAndView, new ModelAndView("index", map);,相当于把结果数据放到response里面

url:http://localhost/mvc/test/toPerson41.do

url:http://localhost/mvc/test/toPerson42.do

url:http://localhost/mvc/test/toPerson43.do

url:http://localhost/mvc/test/toPerson44.do

  1. /**
  2. * HttpServletRequest可以直接定义在参数的列表,并且带回返回结果
  3. *
  4. */
  5. @RequestMapping("/toPerson41.do")
  6. public String toPerson41(HttpServletRequest request) throws Exception {
  7. request.setAttribute("p", newPesion());
  8. return "index";
  9. }
  10. /**
  11. *
  12. * 方法的返回值采用ModelAndView, new ModelAndView("index", map);
  13. * ,相当于把结果数据放到Request里面,不建议使用
  14. *
  15. */
  16. @RequestMapping("/toPerson42.do")
  17. public ModelAndView toPerson42() throws Exception {
  18. Map<String, Object> map = new HashMap<String, Object>();
  19. map.put("p", newPesion());
  20. return new ModelAndView("index", map);
  21. }
  22. /**
  23. *
  24. * 直接在方法的参数列表中来定义Map,这个Map即使ModelAndView里面的Map,
  25. * 由视图解析器统一处理,统一走ModelAndView的接口,也不建议使用
  26. */
  27. @RequestMapping("/toPerson43.do")
  28. public String toPerson43(Map<String, Object> map) throws Exception {
  29. map.put("p", newPesion());
  30. return "index";
  31. }
  32. /**
  33. *
  34. * 在参数列表中直接定义Model,model.addAttribute("p", person);
  35. * 把参数值放到request类里面去,建议使用
  36. *
  37. */
  38. @RequestMapping("/toPerson44.do")
  39. public String toPerson44(Model model) throws Exception {
  40. // 把参数值放到request类里面去
  41. model.addAttribute("p", newPesion());
  42. return "index";
  43. }
  44. /**
  45. * 为了测试,创建一个Persion对象
  46. *
  47. */
  48. public Person newPesion(){
  49. Person person = new Person();
  50. person.setName("james");
  51. person.setAge(29);
  52. person.setAddress("maami");
  53. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
  54. Date date = format.parse("1984-12-28");
  55. person.setBirthday(date);
  56. return person;
  57. }

以上四种方式均能达到相同的效果,但在参数列表中直接定义Model,model.addAttribute("p", person);把参数值放到request类里面去,建议使用

2. Ajax调用springmvc的方法:直接在参数的列表上定义PrintWriter,out.write(result);把结果写到页面,建议使用的

url:http://localhost/mvc/test/toAjax.do

  1. /**
  2. *
  3. * ajax的请求返回值类型应该是void,参数列表里直接定义HttpServletResponse,
  4. * 获得PrintWriter的类,最后可把结果写到页面 不建议使用
  5. */
  6. @RequestMapping("/ajax1.do")
  7. public void ajax1(String name, HttpServletResponse response) {
  8. String result = "hello " + name;
  9. try {
  10. response.getWriter().write(result);
  11. } catch (IOException e) {
  12. e.printStackTrace();
  13. }
  14. }
  15. /**
  16. *
  17. * 直接在参数的列表上定义PrintWriter,out.write(result);
  18. * 把结果写到页面,建议使用的
  19. *
  20. */
  21. @RequestMapping("/ajax2.do")
  22. public void ajax2(String name, PrintWriter out) {
  23. String result = "hello " + name;
  24. out.write(result);
  25. }
  26. /**
  27. * 转向ajax.jsp页面
  28. */
  29. @RequestMapping("/toAjax.do")
  30. public String toAjax() {
  31. return "ajax";
  32. }

ajax页面代码如下:

  1. <script type="text/javascript" src="js/jquery-1.6.2.js"></script>
  2. <script type="text/javascript">
  3. $(function(){
  4. $("#mybutton").click(function(){
  5. $.ajax({
  6. url:"test/ajax1.do",
  7. type:"post",
  8. dataType:"text",
  9. data:{
  10. name:"zhangsan"
  11. },
  12. success:function(responseText){
  13. alert(responseText);
  14. },
  15. error:function(){
  16. alert("system error");
  17. }
  18. });
  19. });
  20. });
  21. </script>
  22. </head>
  23. <body>
  24. <input id="mybutton" type="button" value="click">
  25. </body>

四、表单提交和重定向

1、表单提交:

请求方式的指定:@RequestMapping( method=RequestMethod.POST )可以指定请求方式,前台页面就必须要以它制定好的方式来访问,否则出现405错误

表单jsp页面:

  1. <html>
  2. <head>
  3. <base href="<%=basePath%>">
  4. <title>SpringMVC Form</title>
  5. </head>
  6. <body>
  7. <form action="test/toPerson5.do" method="post">
  8. name:<input name="name" type="text"><br>
  9. age:<input name="age" type="text"><br>
  10. address:<input name="address" type="text"><br>
  11. birthday:<input name="birthday" type="text"><br>
  12. <input type="submit" value="submit"><br>
  13. </form>
  14. </body>
  15. </html>

对应方法为:

  1. /**
  2. * 转向form.jsp页面
  3. * @return
  4. */
  5. @RequestMapping("/toform.do")
  6. public String toForm() {
  7. return "form";
  8. }
  9. /**
  10. *
  11. * @RequestMapping( method=RequestMethod.POST)
  12. * 可以指定请求方式,前台页面就必须要以它制定好的方式来访问,否则出现405错误 a
  13. *
  14. */
  15. @RequestMapping(value = "/toPerson5.do", method = RequestMethod.POST)
  16. public String toPerson5(Person person) {
  17. System.out.println(person);
  18. return "jsp1/index";
  19. }

url:http://localhost/mvc/test/toform.do  

2. 重定向:controller内部重定向,redirect:加上同一个controller中的requestMapping的值,controller之间的重定向:必须要指定好controller的命名空间再指定requestMapping的值,redirect:后必须要加/,是从根目录开始
  1. /**
  2. *
  3. * controller内部重定向
  4. * redirect:加上同一个controller中的requestMapping的值
  5. *
  6. */
  7. @RequestMapping("/redirectToForm.do")
  8. public String redirectToForm() {
  9. return "redirect:toform.do";
  10. }
  11. /**
  12. *
  13. * controller之间的重定向:必须要指定好controller的命名空间再指定requestMapping的值,
  14. * redirect:后必须要加/,是从根目录开始
  15. */
  16. @RequestMapping("/redirectToForm1.do")
  17. public String redirectToForm1() {
  18. //test1表示另一个Controller的命名空间
  19. return "redirect:/test1/toForm.do";
  20. }

springmvc注解和参数传递的更多相关文章

  1. springMVC注解的参数传递

    1.web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi=&qu ...

  2. springmvc入门基础之注解和参数传递

    一.SpringMVC注解入门 1. 创建web项目2. 在springmvc的配置文件中指定注解驱动,配置扫描器 <!-- mvc的注解驱动 --> <mvc:annotation ...

  3. springMVC 注解版

    http://blog.csdn.net/liuxiit/article/details/5756115 http://blog.csdn.net/hantiannan/article/categor ...

  4. springMVC注解初步

    一.(补充)视图解析器---XmlViewResolver 作用:分离配置信息. 在视图解析器---BeanNameViewResolver的基础之上进行扩充,新建一个myView.xml分离信息 在 ...

  5. SpringMVC注解开发初步

    一.(补充)视图解析器---XmlViewResolver 作用:分离配置信息. 在视图解析器---BeanNameViewResolver的基础之上进行扩充,新建一个myView.xml分离信息 在 ...

  6. SpringMVC注解汇总(二)-请求映射规则

    接上一节SpringMVC注解汇总-定义 讲到Httpy请求信息 URL路径映射 1)普通URL路径映射 @RequestMapping(value={"/test1", &quo ...

  7. springMVC注解启用及优化

    使用注解的原因 最方便的还是启用注解 注解方便,而且项目中很流行. 配置文件尽量减少,主要使用注解方式. Springmvc的注解是在2.5版本后有了注解,如何开启注解配置文件 Web.xml文件中不 ...

  8. 6.SpringMVC注解启用

    SpringMVC注解可以帮助我们快速地注入 属性和参数 提高开发效率. 由于 有相当一部分人讨厌xml配置方式 注解可以覆盖 xml则不能 使用注解比xml规范化,因为很多注解都是java的规范的范 ...

  9. springMVC(注解版笔记)

    springMVC(注解版) 较之于非注解版本,发生一下变化: 1.配置文件需要配置的标签有: <!-- 包的扫描,此包下面的所有包都启用注解 --> <context:compon ...

随机推荐

  1. android 利用 aapt 解析 apk 得到应用名称 包名 版本号 权限等信息

    在上传各大市场时发现 apk 上传后能自动解析出应用名称.包名.版本号.使用权限等信息,所以就研究了一下 1 直接解压 apk 解析  AndroidManifest.xml 是不行的,因为 apk ...

  2. 24.Semaphore

    Semaphore     在进程方面完成信号线的控制,可以控制某个资源下,可被同时访问的线程个数.对系统的访问量进行评估,信号量维护了一个许可集:在许可前会阻塞每一个 semaphore.acqui ...

  3. Objective-C:NSDectionary字典的常见操作

    NSDectionary字典:它是一个存储键值的容器,每一个键key都对应着一个值value,可以通过键key一次性找到目标值value,这是一个比较好的存储器,相比于数组而言,它明显提高了查询效率. ...

  4. 倒计时实现方案总结 Timer Handler

    利用Timer实现倒计时 @BindView(R.id.send) Button send;//发送验证码 private int time = 60;//倒计时 private Timer time ...

  5. 比较全的OA系统功能模块列表

    如何判断一款协同OA软件,是否智能,是否注重细节,是否足够成熟呢?产品的设计优势.功能特性,需要我们总结,也需要让更多的用户了解.功能到底强在哪里?下文中将给出一个详尽的答案. 软件安装 傻瓜化向导式 ...

  6. 伪元素 :Before 和 :After的学习

    层叠样式表(CSS)的主要目的是给HTML元素添加样式,然而,在一些案例中给文档添加额外的元素是多余的或是不可能的.事实上CSS中有一个特性允许我们添加额外元素而不扰乱文档本身,这就是“伪元素”. 你 ...

  7. COM中的HRESULT

  8. JSON字符串转换为Map

    本文是利用阿里巴巴封装的FastJSON来转换json字符串的.例子如下: package com.zkn.newlearn.json; import com.alibaba.fastjson.JSO ...

  9. IE 之 应用小结

    1. 导出收藏夹(IE11) 导出:打开浏览器, 文件(F) → 导入和导出(M)... → 导出到文件(E) → 指定导出内容 → 指定保存路径导入:打开浏览器,文件(F) → 导入和导出(M).. ...

  10. Android运行机制

    一. Android平台各层 Android平台架构图,如下图:由上到下依次为应用程序.应用程序框架.库.Android运行时.Linux内核. 1.Linux内核: Android系统基于Linux ...