SpringMVC(1)

SpringMVC(1)

一、三层架构

表现层:Web层,用于和客户端进行数据交互,采用MVC设计模型,Controller(SpringMVC)
业务层:处理业务逻辑,Service(Spring)
持久层:操作数据库,Dao(MyBatis)

二、入门案例

步骤:
  1. pom.xml中引入jar包
  2. webapp/WEB-INF/web.xml中配置核心控制器DispatcherServlet
  3. src/main/resources下创建SpringMVC.xml配置文件
  4. webapp下创建首页页面index.jsp
  5. src/main/java/controller下创建HelloController控制器类
  6. webapp/WEB-INF/pages下创建跳转成功页面success.jsp
具体实现:
  1. web.xml:配置前端控制器和解决中文乱码的过滤器

     使用前端控制器servlet来加载后续的SprigMVC的xml配置文件
     ==> 开启注解扫描
     ==> Controller类启动
     ==> 页面发送请求,Controller类中的方法生效
     ==> 跳转成功页面
    
<web-app>
    <display-name>Archetype Created Web Application</display-name>

    <!-- 配置解决中文乱码的过滤器 -->
    <filter>
        <filter-name>encodingFilter</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>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    
    <!-- 前端控制器 -->
    <servlet>
        <servlet-name>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>dispatcherServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>
注意:在前端控制器里要配置初始化参数contextConfigLocation,使得servlet启动时能够加载SpringMVC的xml配置文件
  1. SpringMVC.xml

      - 开启注解扫描
      - 配置视图解析器
      - 开启SpringMVC框架注解的支持
    
	<!-- 开启注解扫描 -->
    <context:component-scan base-package="com.Lemon"/>

    <!-- 视图解析器
        prefix:文件所在目录
        suffix:文件的后缀
    -->
    <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/pages/"/>
        <property name="suffix" value=".jsp"/>
    </bean>

    <!-- 开启SpringMVC框架注解的支持 -->
    <mvc:annotation-driven/>
  1. index.jsp:首页页面
<body>
    <h3>入门程序</h3>
	<!-- 超链接 -->
	<a href="hello">入门程序</a>
</body>
  1. HelloController.java:控制器类,通过配置xml文件开启注解扫描后,只需要在该类上加上@Controller注解,交给IOC容器管理即可
@Controller
public class HelloController {

    /**
     * 入门案例:
     *  jsp页面发送请求到后台,调用sayHello方法,需要加上@RequestMapping请求映射注解,并指定路径
     */
    @RequestMapping(path = "/hello")
    public String sayHello(){
        System.out.println("Hello SpringMVC");
        return "success"; // 如果方法生效了,就应该要跳转到success.jsp页面
    }
  1. sunccess.jsp:成功页面

    当在首页点击超链接后,jsp页面发送请求到后端,
    由于超链接的href指向了sayHello()方法的@RequestMapping所指的路径,
    所以,会调用sayHello()方法,方法生效执行成功return "success"
    那么就会跳转到success.jsp页面,
    最终页面会显示success.jsp的“入门成功”,并且后台打印sayHello()方法的"Hello SpringMVC"。

<body>
    <h3>入门成功</h3>
</body>

三、请求参数的绑定

  1. 提交表单的数据格式:K=V,中间用&连接例如:username=hehe&password=123
  2. SpringMVC参数绑定过程:把表单提交的请求参数,作为Controller控制器类中的方法的参数进行绑定,要求表单的name必须和参数的名称相同
  3. 支持的数据类型

– 基本数据类型和字符串类型
具体代码:

首页param.jsp

<body>

    <%-- (1)基本数据类型和字符串类型   --%>
    <a href="param/testParam?username=hehe&password=123">请求参数的绑定</a>
    
</body>    

控制器类ParamController.java

@Controller
@RequestMapping("/param")
public class ParamController {
    // (1)基本数据类型和字符串类型
    @RequestMapping("/testParam")
    public String testParam1(String username, String password){
        System.out.println("执行了...");

        System.out.println("用户名:" + username);
        System.out.println("密码:" + password);

        return "success";
    }
}
要求:超链接的name(href?username=hehe)必须和方法参数String username相同
效果:SpringMVC会将页面请求参数赋值给控制器类方法的形参,在后台会打印页面输入的username和password的具体数据hehe和123,页面会跳转到success页面

– 实体类类型JavaBean对象
具体代码:

param.jsp

<body>

      <%-- (2)实体类型JavaBean --%>
     <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" name="提交"/>
    </form>
    
</body>    

ParamController.java

@Controller
@RequestMapping("/param")
public class ParamController {
    // (2)实体类型JavaBean
    @RequestMapping("/saveAccount")
    public String testParam2(Account account){
        System.out.println("执行了...");

        System.out.println(account);

        return "success";
    }
}

实体类Account.java加上get,set,toString方法

public class Account implements Serializable {

    private String username;
    private String password;
    private Double money;

    // (2)实体类型JavaBean
    private User user;
}

实体类User.java加上get,set,toString方法

public class User implements Serializable {

    private String uname;
    private Integer age;

    // 自定义类型转换器
    private Date date;
}
要求:
  1. 提交表单中的name(name="username")必须和实体类Account的属性名相同。
  2. 如果实体类中有引用类型属性(另一个JavaBean对象User user),那么可以在表单中使用对象.属性user.uname调用引用类型属性的属性
  3. 当页面提交表单数据,会调用属性的set方法设置数据;方法生效时,传入JavaBean对象,就可以调用get方法获得数据

– 集合数据类型(List,Map等)
具体代码:

param.jsp

<body>

     <%--  (3)集合数据类型 --%>
     <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>
    
</body>    

ParamController.java

@Controller
@RequestMapping("/param")
public class ParamController {
    // (2)实体类型JavaBean
    @RequestMapping("/saveAccount")
    public String testParam2(Account account){
        System.out.println("执行了...");

        System.out.println(account);

        return "success";
    }
}

实体类Account.java加上get,set,toString方法

public class Account implements Serializable {

    private String username;
    private String password;
    private Double money;

    // (2)实体类型JavaBean
    private User user;

    // (3)集合数据类型(List,Map等)
    private List<User> list;
    private Map<String, User> map;
}

实体类User.java加上get,set,toString方法

public class User implements Serializable {

    private String uname;
    private Integer age;

    // 自定义类型转换器
    private Date date;
}
要求:
  1. 对于List类型,表单使用 list[0].uname
  2. 对于Map类型,表单使用 map['one'].uname

四、自定义类型转换器

表单提交的都是字符串类型,就算后台定义Integer类型,数据也可以封装上
这说明,Spring框架会默认进行数据类型转换
但是,如果是自定义的类型,那么需要自定义类型转换器
步骤:
 * 1.定义一个类型转换的方法,并实现Convert接口
 *      implements Converter<S, T>:S是String类型,T是自定义类型
 * 2.在SpringMVC.xml配置文件中配置自定义类型转换器
 *   同时,要把自定义的类型转换的方法注册进来,需要在SpringMVC框架注解中注册自定义类型转换器
 *   ConversionServiceFactoryBean
 *      <bean class="com.Lemon.utils.StringToDateConverter"/>
 *      <mvc:annotation-driven conversion-service="conversionService"/>
具体代码:
自定义一个日期类型的转换器
因为SpringMVC默认只能将yyyy/MM/dd的字符串转换成日期
现在要求能将yyyy-MM-dd的字符串转换成日期。

StringToDateConverter.java:把字符串转换成日期的自定义类型转换器

public class StringToDateConverter implements Converter<String, Date> {

    @Override
    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

    <!-- 配置自定义类型转换器
        1. 需要把自定义的类型转换的方法注册进来
        2. 需要在SpringMVC框架注解中注册自定义类型转换器
    -->
    <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean">
        <property name="converters">
            <set>
                <bean class="com.Lemon.utils.StringToDateConverter"/>
            </set>
        </property>
    </bean>

    <!-- 开启SpringMVC框架注解的支持 -->
    <mvc:annotation-driven conversion-service="conversionService"/>

ParamController.java

@Controller
@RequestMapping("/param")
public class ParamController {
	// 自定义类型转换器
    @RequestMapping("/saveUser")
    public String testParam3(User user){
        System.out.println("执行了...");

        System.out.println(user);

        return "success";
    }
}

五、获取原生的Servlet的API对象

只需要在Controller控制器类的方法的形参列表中定义HttpServletRequestHttpServletResponse对象即可使用

ParamController.java

@Controller
@RequestMapping("/param")
public class ParamController {
	// 获取原生的Servlet的API对象
    @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";
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值