SSM1_Spring+SpringMVC

一.Spring

1.1 常用注解⭐⭐⭐

<!--  指定注解扫描包  -->
<context:component-scan base-package="com.kuang.pojo"/>
<context:annotation-config/> 
//1. 自动装配的注解, 放在属性字段上;
@Autowired: 自动装配通过类型(byType) -> 名字(byName);
@Qualifier(value="xxx"): 当类型相同时, @Autowired不能唯一自动装配上属性, 可以使用该注解指定唯一名称的;
@Resource[(name="xxx")]: 自动装配通过名字(byName) -> 类型(byType); 
[相当于@Autowired@Qualifier的联合使用, 但是效率会低一些.](jdk1.5中的注解);
@Nullable: 标注字段可以为空;

//2. 分层的注解
@Component: ;
//@Value: ;
@Repository: [dao层];
@Service: [service层];
@Controller: [web/controller层];
//@Scope: 作用域;

//3.编写配置类
@Configuration: 配置类注解;
@Bean:
@ConponentScan:
@Import:

// 4.AOP切面编程的注解
@Aspect: 标注这个类是一个切面;
@Before:;
@After:;
@Around:;

1.2 IOC 和 AOP

  • IOC和AOP的不同:

    1、定义不同
    ioc:控制反转(Inversion of Control,缩写为IoC),是面向对象编程中的一种设计原则,可以用来减低计算机代码之间的耦合度。
    
    aop:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。
    ---------------------------------------------------------------------------
    
    2、功能不同
    ioc:Class A中用到了Class B的对象b,一般情况下,需要在A的代码中显式的new一个B的对象。
    采用依赖注入技术之后,A的代码只需要定义一个私有的B对象,不需要直接new来获得这个对象,而是通过相关的容器控制程序来将B对象在外部new出来并注入到A类里的引用中。而具体获取的方法、对象被获取时的状态由配置文件(如XML)来指定。
    
    aop:将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来,通过对这些行为的分离,我们希望可以将它们独立到非指导业务逻辑的方法中,进而改变这些行为的时候不影响业务逻辑的代码
    

DI: 依赖注入, 这是IOC实现的方法;

  • DI的两种主要方式:

    • Constructor-based dependency injection (基于构造方法)

    • Setter-based dependency injection (基于Set方法)

二.Spring MVC

一. 项目构建步骤:

  1. 新建一个web项目;
  • 添加框架支持-> 右击项目-> Add Framework Support… -> 选择java, 添加web4.0的框架支持;
  1. 导入相关jar包;
  • Project Structure-> Artifacts-> WEB-INF目录下添加一个lib目录, 并导入相关的jar包;
  1. 编写web.xml , 注册DispatcherServlet;
  • 设置DispatcherServlet; 设置过滤器;
  1. 编写springmvc配置文件;
  • 1.配置自动扫描包: <context:component-scan base-package="xxx"/>
    2.注解驱动: <mvc:annotation-driven/>
    3.静态资源过滤: <mvc:default-servlet-handler/>
    4.视图解析器: org.springframework.web.servlet.view.InternalResourceViewResolver
    
  1. 接下来就是去创建对应的控制类 , controller;

  2. 最后完善前端视图和controller之间的对应;

  3. 测试运行调试;

二.如何写源码

源码写法:重载 -> 利用重载,"简单的少参数的" 去调用 "复杂的多参数的", 缺少的参数即为null;

三.注意点

目录结构: ???

在WEB-INF下的所有页面或者资源,只能通过controller,或者servlet进行访问

2.1 常用注解⭐⭐⭐


  • @Controller: 通过注解定义控制器, 负责解析用户的请求并将其转换为一个模型;

    [会走视图解析器];

  • @ResponseBody: 一般在@Controller下使用, 配置后它不会走视图解析器, 会直接返回一个字符串;

    [优点: 不走视图解析器, 所以不用花时间写对应的页面来测试! ]


  • @RestController: 返回值不会被视图解析器解析, 它就是一个字符串;

    [ => 相当于@Controller和@ResponseBody联合使用; ]


  • @RequestMapping: [返回值会被视图解析器解析;] 用于映射url到控制器类或一个特定的处理程序方法。可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。

  • ⭐@PathVariable: 让方法参数的值对应绑定到一个URI模板变量上。

    [ 主要应用于RestFul风格的代码 ! ]

    用于Restfull风格的注解: 
    /*  Restful风格:http://localhost:8080/s4/add/a/b; 案例如下: */
    @Test
    @RequestMapping(value = "/add/{a}/{b}",method = RequestMethod.GET)
    public String test2(@PathVariable int a, @PathVariable String b, Model model){...}
    

  • ⭐@RequestParam(“username”): 表示要从前端接收的参数名;

    [ 主要用于接收http://host:port/path?参数名=参数值数据,这里后面也可以不跟参数值。]

    //@RequestParam用法,注意这里请求后面没有添加参数
    @RequestMapping(value = "/test",method = RequestMethod.POST)
    public Result test(@RequestParam(value="id",required=false,defaultValue="0")String blogId){...}
    
    注意上面@RequestParam用法当中的参数:
    value表示接收数据的名称。required表示接收的参数值是否必须,默认为true,既默认参数必须不为空,当传递过来的参数可能为空的时候可以设置required=false。此外还有一个参数defaultValue 表示如果此次参数未空则为其设置一个默认值。
    

2.2 MVC

2.2.1、什么是MVC

MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种软件设计规范。

是将业务逻辑、数据、显示分离的方法来组织代码。

MVC主要作用是降低了视图与业务逻辑间的双向偶合。

MVC不是一种设计模式,MVC是一种架构模式。当然不同的MVC存在差异。

Model(模型):数据模型,提供要展示的数据,因此包含数据和行为,可以认为是领域模型或JavaBean组件(包含数据和行为),不过现在一般都分离开来:Value Object(数据Dao) 和 服务层(行为Service)。也就是模型提供了模型数据查询和模型数据的状态更新等功能,包括数据和业务。

View(视图):负责进行模型的展示,一般就是我们见到的用户界面,客户想看到的东西。

Controller(控制器):接收用户请求,委托给模型进行处理(状态改变),处理完毕后把返回的模型数据返回给视图,由视图负责展示。也就是说控制器做了个调度员的工作。

[最典型的MVC就是JSP + servlet + javabean的模式。]

2.3 SpringMVC执行原理
请添加图片描述

图为SpringMVC的一个较完整的流程图,实线表示SpringMVC框架提供的技术,不需要开发者实现,虚线表示需要开发者实现。

简要分析执行流程

  1. DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心。用户发出请求,DispatcherServlet接收请求并拦截请求。

    • 我们假设请求的url为 : http://localhost:8080/SpringMVC/hello

    • 如上url拆分成三部分:

    • http://localhost:8080 ------> 服务器域名

    • SpringMVC ------> 部署在服务器上的web站点

    • hello ------> 表示控制器

    • 通过分析,如上url表示为:请求位于服务器localhost:8080上的SpringMVC站点的hello控制器。

  2. HandlerMapping为处理器映射。DispatcherServlet调用HandlerMapping,HandlerMapping根据请求url查找Handler。

  3. HandlerExecution表示具体的Handler,其主要作用是根据url查找控制器,如上url被查找控制器为:hello。

  4. HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等。

  5. HandlerAdapter表示处理器适配器,其按照特定的规则去执行Handler。

  6. Handler让具体的Controller执行。

  7. Controller将具体的执行信息返回给HandlerAdapter,如ModelAndView。

  8. HandlerAdapter将视图逻辑名或模型传递给DispatcherServlet。

  9. DispatcherServlet调用视图解析器(ViewResolver)来解析HandlerAdapter传递的逻辑视图名。

  10. 视图解析器将解析的逻辑视图名传给DispatcherServlet。

  11. DispatcherServlet根据视图解析器解析的视图结果,调用具体的视图。

  12. 最终视图呈现给用户。

2.4 JSON

<!--  注解驱动, 并解决JSON乱码问题的配置  (用了jackson,就可以配置这一段固定的代码)  -->
<mvc:annotation-driven>
    <mvc:message-converters register-defaults="true">
        <bean class="org.springframework.http.converter.StringHttpMessageConverter">
            <constructor-arg value="UTF-8"/>
        </bean>
        <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
            <property name="objectMapper">
                <bean class="org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean">
                    <property name="failOnEmptyBeans" value="false"/>
                </bean>
            </property>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>

2.5 AJAX

jQuery.ajax(...)
1.部分参数:
    url:请求地址;⭐
    type:请求方式,GET、POST(1.9.0之后用method)
    headers:请求头
    data:要发送的数据;⭐
    contentType:即将发送信息至服务器的内容编码类型(默认: "application/x-www-form-urlencoded; charset=UTF-8")
    async:是否异步
    timeout:设置请求超时时间(毫秒)
    beforeSend:发送请求前执行的函数(全局)
    complete:完成之后执行的回调函数(全局)
    success:成功之后执行的回调函数(全局);⭐
    error:失败之后执行的回调函数(全局);⭐
    accepts:通过请求头发送给服务器,告诉服务器当前客户端可接受的数据类型
    dataType:将服务器端返回的数据转换成指定类型
    "xml": 将服务器端返回的内容转换成xml格式
    "text": 将服务器端返回的内容转换成普通文本格式
    "html": 将服务器端返回的内容转换成普通文本格式,在插入DOM中时,如果包含JavaScript标签,则会尝试去执行。
    "script": 尝试将返回值当作JavaScript去执行,然后再将服务器端返回的内容转换成普通文本格式
    "json": 将服务器端返回的内容转换成相应的JavaScript对象
    "jsonp": JSONP 格式使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数
    
2.案例:
    <script>
        function a(){
            $.post({
                url:"${pageContext.request.contextPath}/a1",
                data:{"name":$("#username").val()},
                success:function (data,status) {
                    console.log("data="+data);
                    console.log("status="+status);
                    //200:成功;300:重定向或转发; 400:客户端错误; 500:服务器错误;
                },
                error:function () {
                }
            })
        }
    </script>

2.6 拦截器


2.7 文件上传⭐⭐⭐


常见问题以及解决方法

1.项目可能遇到的问题:访问出现404,排查步骤:
//一.可能没有添加lib依赖;
①查看控制台输出,看一下是不是缺少了什么jar包;
②如果jar包存在,显示无法输出,就在IDEA的项目发布中,添加lib依赖;
③重启Tomcat 即可解决;
//二.可能是打包发布输出的out目录中缺少了某些文件;  [不知道是不是idea版本的问题,这两天不小心打错文件名, 然后out目录中的文件重新生成后总是缺少classes或lib依赖;]


2.乱码问题解决:
<!-- 注意: 在springMVC中,/ 和 /* 的区别:
            /: 只匹配所有的请求,不会去匹配jsp页面;
            /*: 匹配所有的请求,包括jsp页面;    (一般url请求使用"/", 过滤器使用"/*"[比如乱码过滤, 过滤所有请求和jsp页面, 防止乱码产生]; ) -->

<!-- 1.以前的过滤器-->
<filter>
    <filter-name>encoding</filter-name>
    <filter-class>com.kuang.filter.EncodingFilter</filter-class>
</filter>
<filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

<!-- 或2.配置SpringMVC的过滤器 -->
<filter>
    <filter-name>encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <!--自定义过滤器: <filter-class>com.kuang.filter.EncodingFilter</filter-class>-->
    <init-param>
        <param-name>encoding</param-name>
        <param-value>utf-8</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

三.SSM整合

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值