您的位置:首页 > 其它

interlij idea给Web项目添加SSM(零配置文件

2017-07-25 19:07 459 查看

0、前言

    这里说的零配置文件是Spring上的零配置文件,Mybatis不想去折腾了,虽然也可以零配置文件,其实我觉得,如果真的零配置文件就有点倒退了,毕竟出现xml,是因为修改xml可以不改变程序,就改变程序行为的目的,而全用类来配置,每次都要修改然后编译,各有好处,不是新的一定好,也不是因循守旧,找到合适自己的才是最重要的,同时掌握它的编程技巧,自己能看到其他人代码即可,毕竟只是编码,花太多精力不太好。

Mybatis的零配置可以看这个:mybatis-Java API

Spring的零配置的话,我是看书的,而且我去Spring官网好像也找不到SpringMVC的专栏。现在Spring的最新版4.0(包括Spring MVC),Spring 5.0也快出来了。

环境使用的是Maven搭建,新建项目请看这里interlij idea创建给Web项目添加Hibernate2、创建项目

这里说下将xml转换成class的技巧。先将以下知识:

1、WebApplicationInitializer是Spring提供用来配置Servlet3.0+配置的接口,从而实现了替代web.xml的位置。实现此接口将会自动被SpringServletContainerInitializer(用来启动Servlet3.0容器)获取到

2、Spring配置文件同样是一个普通的Class,通过代码注册到WebApplicationInitializeronStartup中即可,同时继承WebMvcConfigurerAdapter,重写其方法可对Spring MVC进行配置(前提是类上有@EnableWebMvc),不继承就没Spring MVC的功能咯

说到这里两个重要的文件(web.xml、spring配置文件)都可以用类来表示了。

我们了解一下bean节点的结构,无非就是id(实例名)、class(类名)、property(成员变量)。我们举个例子:

<bean id="a" class"xxx.xxx.B">
<property name="c" value="d"/>
<property name="e">
<value>f</value>
</property>
</bean>
import xxx.xxx;
@Bean
public B getB(){
B b = new B();
b.setC("d");
b.setE("f");
return B;
}


只要在Spring配置文件的类中做这种转换,将bean标签,变为@Bean注解的方法即可。

注解是Spring的一个构建的一个重要手段,减少写配置文件,下面解释一下一些要用到的注解:

@Configuration 作用于类上面,声明当前类是一个配置类(相当于一个Spring的xml文件)

@ComponentScan(“xxx”) 作用于类上面,自动扫描xxx包名下所有使用@Service、@Component、@Repository和@Controller的类,并注册为Bean

@Bean 作用与类和方法上,相当于Spring配置文件bean节点

@EnableWebMvc 作用于类,开启一些默认配置,如一些ViewResolver或者MessageConverter

@RequestMapping 作用于类、方法,配置URL和方法之间的映射

@RequestBody 作用于参数前,允许request的参数在request体中,而不是在直接链接在地址后面

@ResponseBody 作用于返回值、方法上,支持将返回值放在response体中,而不是返回一个页面。

@RequestParam 作用于参数前,将form的对应name值映射到当前参数中

1、系统环境

IDE:InterliJ IDEA 2017.1.5

jdk版本:1.8

Maven版本:3.5

Spring版本:4.3.9.RELEASE

Spring MVC版本:4.3.9.RELEASE

Mybatis版本:3.X

数据库:MySQL 5.7 包含user表的sql脚本

Mybatis环境搭建相关知识请查看: interlij idea创建给Web项目添加Mybatis

项目的初次创建请查看:interlij idea创建给Web项目添加Hibernate

2、spring环境搭建(包含Spring MVC)

2.1、添加Maven依赖

在pom.xml根节点project下添加如下节点:

<properties>
<spring-framework.version>4.3.9.RELEASE</spring-framework.version>
<logback.version>1.2.3</logback.version>
</properties>


这是下面依赖要用到的一些全局属性

在dependencies节点下,添加如下依赖:

<!-- ********************** Java Servlet API 4.0.0-b01 ********************** -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.0-b01</version>
</dependency>

<!-- ********************** 添加jstl(JSP Standard Tag Library)支持 ********************** -->
<dependency>
<groupId>org.eclipse.jetty</groupId>
<artifactId>apache-jstl</artifactId>
<version>9.4.6.v20170531</version>
</dependency>

<!-- ********************** Spring 4.2.4.RELEASE ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring-framework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>${spring-framework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring-framework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring-framework.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>${spring-framework.version}</version>
</dependency>

<!-- ********************** Spring MVC ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring-framework.version}</version>
</dependency>

<!-- ********************** Spring and Transactions ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>${spring-framework.version}</version>
</dependency>

<!-- ********************** spring单元测试依赖 ********************** -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${spring-framework.version}</version>
<scope>test</scope>
</dependency>


若Maven依赖下载特别慢,请自行添加国内Maven镜像。

2.2、导入静态资源

在WEB-INF中,直接粘贴boostrap的标准资源,并新建一个views文件夹,将index.jsp拉进去,将自己写的Login.jsp(这个页面要的话去码云找吧)复制进去,效果如下(顺便删了web.xml):



2.3、创建SpringConfig类(Spring配置文件)

首先新建文件夹space.xxhui.config,新建类SpringConfig类,继承WebMvcConfigurerAdapter,并配置一些必要的方法

@Configuration
@EnableWebMvc//若无此注解,WebMvcConfigurerAdapter无效
@ComponentScan("space.xxhui")
public class SpringConfig extends WebMvcConfigurerAdapter {//继承WebMvcConfigurerAdapter,重写其方法可对Spring MVC进行配置'
//添加一个ViewResolver解析view
@Bean
public InternalResourceViewResolver viewResolver(){
InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
viewResolver.setPrefix("/WEB-INF/views/");
viewResolver.setSuffix(".jsp");
viewResolver.setViewClass(JstlView.class);
return viewResolver;
}
//注册静态资源,没注册的话,网站是访问不了的
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/css/**").addResourceLocations("/WEB-INF/css/");
registry.addResourceHandler("/js/**").addResourceLocations("/WEB-INF/js/");
registry.addResourceHandler("/fonts/**").addResourceLocations("/WEB-INF/fonts/");
}
//根目录的时候直接跳转到登录界面
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/").setViewName("Login");
}
}


看一下对比图:



2.4、创建WebInitializer类(web.xml)

在congfig下创建WebInitializer类,实现WebApplicationInitializer接口,实现方法,方法内容如下:

AnnotationConfigWebApplicationContext ctx = new AnnotationConfigWebApplicationContext();
ctx.register(SpringConfig.class);
ctx.setServletContext(servletContext);
ServletRegistration.Dynamic dynamic = servletContext.addServlet("dispatcher",new DispatcherServlet(ctx));
dynamic.addMapping("/");
dynamic.setLoadOnStartup(1);


配置文件和类版本对比:



在上写文中注册Spring配置文件,添加DispatcherServlet到上下文中。

2.5添加LoginController

新建文件夹controller



在controller文件夹,新建一个LoginController类,在类上,添加@Controller注解,详细代码如下:

package space.xxhui.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

@Controller
public class LoginController {

@RequestMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("pwd") String pwd) {
String forword = null;
if (username.equals("Hitvz") && pwd.equals("123456")) {
forword = "index";//登录成功跳转到index.jsp
} else {
System.out.println("no such user");
forword = "Login";//登录失败跳转到Login.jsp继续登录操作
}
return forword;
}

}


根目录的跳转在SpringConfig.java中已经添加相应ViewController。

添加tomcat,运行



正常运行和跳转。

3、Spring整合MyBatis

追加如下依赖:

<!-- ********************** Mysql JDBC驱动 ********************** -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
<!-- ********************** Mybatis依赖 ********************** -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.4</version>
</dependency>

<!-- ********************** Mybatis-Spring插件********************** -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
<!-- ********************** Druid数据库连接池 ********************** -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.31</version>
</dependency>
<!-- ********************** junit单元测试依赖 ********************** -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>


3.1添加映射文件

在space.xxhui下,新建文件夹DAO、POJO,resource文件夹下,新建文件夹mapper

效果如下:



在POJO文件夹下,新建一个User实体类:

package space.xxhui.POJO;

import java.util.Date;

public class User {

private int id;
private String name;
private Date birth;
private Integer sex;
private Integer age;
private String phone;
private String email;
private String pwd;
// 省略各属性getter和setter方法、toString方法
}


生成DAO和mapper的xml文件:(这个插件添加,可以去 interlij idea创建给Web项目添加Mybatis了解

alt+insert快捷键,选最后一个





图片忘了标出,去掉下面第一个和第四个的复选框,自己注意去掉,这里没有所以我没生成。

在UserDAO.xml的mapper节点下,添加如下:

<select id="getUserById" resultType="space.xxhui.POJO.User">
SELECT * FROM USER WHERE id = #{id};
</select>


在UserDAO.Java添加如下:

//使用xml配置文件
User getUserById(int id);
//不使用配置文件使用注解
@Select("Select * from user where id = #{id}")
User getUserByIdForAnnotation(int id);
@Select("Select * from user where name = #{user.name} and pwd = #{user.pwd}")
User checkUser(@Param("user") User user);






3.2、添加配置文件

添加mybatis-config.xml(Mybatis-config的模板创建,参见 interlij idea创建给Web项目添加Mybatis



删去environments节点。

要这个文件的主要目的是要一个settings节点

<settings>
<!--当返回行的所有列都是空时,MyBatis默认返回null-->
<setting name="returnInstanceForEmptyRow" value="true"/>
</settings>


当然不用这个设置功能,可以完全不建这个xml。

在config文件夹下,新建SpringBean类

@Configuration
@EnableWebMvc//若无此注解,WebMvcConfigurerAdapter无效
@ComponentScan("space.xxhui")
public class SpringBean {

@Bean
public DriverManagerDataSource dataSource(){
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/networkalbum?useSSL=false&serverTimezone=GMT%2B8");
dataSource.setUsername("root");
dataSource.setPassword("root");
return dataSource;
}

@Bean
public SqlSessionFactoryBean sqlSessionFactory(){
SqlSessionFactoryBean sqlSessionFactory = new SqlSessionFactoryBean();
sqlSessionFactory.setDataSource(dataSource());
sqlSessionFactory.setMapperLocations(new Resource[]{new ClassPathResource("mapper/UserDao.xml")});
sqlSessionFactory.setConfigLocation(new ClassPathResource("mybatis-config.xml"));
return sqlSessionFactory;
}

@Bean
public MapperScannerConfigurer mapperScanner(){
MapperScannerConfigurer mapperScanner = new MapperScannerConfigurer();
mapperScanner.setSqlSessionFactoryBeanName("sqlSessionFactory");
mapperScanner.setBasePackage("space.xxhui.DAO");
return mapperScanner;
}

}


对比图:



bean标签节点是这么写,其他标签相信也是差不多方法写出来的。

3.3、编写测试用例

package space.xxhui;

import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import space.xxhui.DAO.UserDao;
import space.xxhui.POJO.User;
import space.xxhui.config.SpringBean;
import space.xxhui.config.SpringConfig;

/**
* Created by hui on 2017/7/25.
*/

/**
* 配置spring和junit整合,junit启动时加载springIOC容器 spring-test,junit
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {SpringConfig.class ,SpringBean.class})
@WebAppConfiguration("src/main/space/xxhui/config")
public class UserDAOTest {

@Autowired
private UserDao userDao;

@org.junit.Test
public void getMapper(){
User user = userDao.getUserById(1);
System.out.println(user.toString());
User user1 = userDao.getUserByIdForAnnotation(2);
System.out.println(user1.toString());
}
}




code 0说明正常退出。

4、整合SpringMVC和Mybatis

其实就是controller调用DAO而已

LoginController.java添加如下:

@Autowired
private UserDao userDao;
//login方法替换为如下方法
@RequestMapping("/login")
public String login(@RequestParam("username") String username , @RequestParam("pwd") String pwd){
String forword = null;
User userEntity =new User();
userEntity.setName(username);
userEntity.setPwd(pwd);
//mybatis配置文件中设置了,如果没有查询到返回null
User entity = userDao.checkUser(userEntity);
//if (username.equals("Hitvz") && pwd.equals("123456")) {
if(entity!=null){
forword = "404page";
} else {
System.out.println("no such user");
forword = "Login";
}
return forword;
}




最后成功运行登录的我就不展示了。

源码:码云-SpringMVCDemoByClass

源码:码云-SpringMVCDemoByXml
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: