springmvc入门小结

1.用户接受请求,然后请求会被我们配置在web.xml中的前端控制器dispatcherServlet进行拦截,然后我们的前端控制器会将请求信息传给我们的处理器映射器,我们的处理器映射器会根据我们传入的路径找到我们的handler,返回我们的处理器执行链其中包含有拦截器和我们的handler,返回给我们的前端控制器。
2。我们的前端控制器再将我们的handler交给我们处理器适配器,我们的处理器适配器则会根据我们的handler类型(比如注解形式,配置形式等)来对应地执行我们的handler,我们的handler执行完成后,就会返回一个modelAndView给我们的前端控制器。
3.同样地我们的前端控制前会将这个modelView交给我们的视图解析器来处理,视图解析器也会根据我们使用的技术类型(比如jsp,freemaker等)来对应的返回我们的视图对象。然后我们的前端控制器会渲染这个视图(即将模型数据进行返回)返回给我们的html页面来显示
这里我们说几个 核心组件:
1.前端控制器(DispatcherServlet):是我们整个mvc中的c,整个处理请求流程的控制中心,由它来调配几个执行方面的核心组件,这样的好处是让我们的组件与组件之间进行分离,起到了解耦合的作用
2.处理器映射器(HandlerMapping):会根据你传过来的路径来匹配对应的handler,然后将处理链返回
3.处理器适配器(HandlerAdapter):会根据传过来的handler来选择对应的适配器来执行handler(比如注解形式的handler就使用注解形式的处理器适配器来处理)
4.视图解析器(View Resolver):实际上就是根据我们modelView中的逻辑视图(也就是视图文件名)找到我们的物理视图(也就是我们的真是路径),并且将模型数据进行封装。然后返回view给我们的核心控制器,核心控制器再进行渲染。

springmvc配置
springmvc我们用的时候会发现,其实不用我们配置什么东西,这是因为我们导入的jar包中包含DispatcherServlet.properties这个文件已经帮我们初始化了一个默认的配置。但是我们默认配置的类已经过期,我们需要自己重新配置。而我们配置处理器映射器和处理器可以<mvc:annotation-driven> 来自动加载。但是我们的视图解析器得自己配置,我们也要配置我们的扫描controller层注解的扫描器,这里我们来说一下springmvc关键的注解@RequestMapping,它既可以配置到方法上也可以配置到类上,因为我们springmvc是基于方法开发的,放到类上的作用单纯就像是我们对url路径进行了分类而已
{
< bean   class = "org.springframework.web.servlet.view.InternalResourceViewResolver" >
< property   name = "viewClass"
value = "org.springframework.web.servlet.view.JstlView"   />
< property   name = "prefix"   value = "/WEB-INF/jsp/"   />
< property   name = "suffix"   value = ".jsp"   />
</ bean >
}
ViewClass比如我们如果用jsp视图,就会调用我们jsp的jstl标签库。这个可以不用配置

关于我们spring-springmvc-mybatis整合
我们只要将mybatis里面的sqlSessionFactory交由spring来管理,并且在spring中配置mapper扫描器。因为我们spirng和springmvc是属于同一家公司开发,所以它们两个的继承并不用特意配置什么。当然我们必须在web.xml里面配置我们的spring初始化容器的
{
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/applicationContext-*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
}
也要配置我们的springmvc的前端控制器
{
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
}
再去配置关于service和dao层的配置,这个太过简单就不赘述了。


接下来我们就说关于springmvc关于 前端参数的绑定
1.我们可以在方法中传入形参HttpServletRequest以及关于Http部分的参数,通过Request来获取我们的页面传入的参数,但是这种方法太过low,不推荐使用。
2.我们可以在方法参数部分传入一个想得到的参数,并且我们的参数名和我们的表单上的name名一致,就可以完成接收
3.我们有时候可能有特殊情况,我们的参数名不能对应时,我们可以通过注解@RequestParam()里面有三个参数,
(1).value:我们想要匹配的参数名
(2).defaultValue:是指如果我们如果没传入参数的时候,它会有一个默认值
(3).required是指我们这个参数值是否必须,如果我们设置为true以后,如果传参为空,则会报错。
4.我们可以用一个pojo类来接受,放一个对象放在我们的方法参数上,但是我们pojo类的字段名必须和我们表单的name名一一对应,不然就不能接受成功。
5.我们也可以用包装pojo来接受,我们可以在pojo中再定义pojo当然和我们的pojo类的方法差不多一致,当然我们也可以接受一个数组以及集合

然后我们来说关于 我们的方法返回值的问题
方法返回值可以有多种类型,我们平常见的就一下几种
1.返回一个ModelAndView对象,我们在方法内将数据存储到modelAndView对象中。也可以设置我们的逻辑视图交给我们的视图解析器来找到我们的物理视图
2.返回一个字符串,这个字符串是我们的图片路径名或者我们的action的路径。这里如果我们要传数据,通常方法形参传入一个Model对象。
3.我们返回一个对象,但是不是单纯的对象,我们会在上面加上@ResponseBody将返回的对象转化成一个json字符串返回。同样地我们也可以从客户端接收一个json格式的数据,我们可以用pojo类来传送,我们会用@RequestBody这个注解来接受。

这里我们来说一下springmvc关于中文乱码的解决方式
如果是post方式,我们可以配置一个filter来解决,具体配置方式如下
{
< 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 >
}
如果是get方式,则有两种,一种是在tomcat中配置
{
<Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
}
或者是接收后再重新编码

我们还做了一个 异常处理器。
通常我们做异常处理会创建两个东西,一个是我们会自定义一个异常处理器,我们也会自己自定义一个异常。我们的自定义异常处理器会实现一个接口HandlerExceptionResolver。我们只要以Bean的形式将我们的自定义异常处理器配置就行了,我们的异常处理器的作用是我们如果程序出现了异常,这时候我们不可能给用户一个报错信息,我们需要给用户返回一个友好界面,这时候我们就会拦截异常,进行异常信息的处理。
拦截器的使用
我们上文中说到了,我们在处理器映射器操作后,返回的是一个操作链而不是单纯的只有一个handler,而这其中就包含我们的拦截器,我们定义的拦截器通常会处理什么业务呢?我们自定义的拦截器需要实现我们的HandlerInteceptor这个接口,它有三个实现方法,
1.preHandle用来执行业务前的操作, 可以实现对数据的预处理,比如:编码、防重复提交安全控制等。
2.postHandle该方法在action执行后,生成视图前执行。在这里,我们有机会修改视图层数据。
3.afterCompletion最后执行,通常用于释放资源,处理异常。我们可以根据ex是否为空,来进行相关的异常处理。
springmvc的图片上传,需要两个jar包commons-io,commons-fileupload。方法上传入一个MultipartFile形参。就能够操作了

springmvc和struts2的区别
1.sturts2的入口是一个filter,而springmvc入口是一个servlet
2.struts2是基于类开发,它的参数一般都是成员变量,所以,它必须是基于多例模式开发,而springmvc是基于方法开发,它的参数一般都是方法参数。所以它可以支持单例也可以支持多例(但是我们支持单例)
3.struts2大部分是通过值栈向页面传数据,但是springmvc是通过request域。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值