作为一个Spring MVC新手最基本的功夫就是学会如何使用开发工具创建一个完整的Spring MVC项目,本文站在一个新手的角度讲述如何一步一步创建一个基于Spring MVC, Hibernate, My SQL的Maven项目。
本项目的目的:
- 学习如何创建并配置一个基于maven的Spring MVC项目
- 学习如何映射数据表到对象
- 学习如何使用Hibernate操纵数据库数据
- 学习如何使用拦截器过滤未授权的访问
因为在使用不同的IDEA 版本、不同的Spring MVC版本或者不同Hibernate版本创建项目的时候创建方式和配置都有可能一些不一样,下面列出本文所使用的各个组件的版本,如果你所使用的版本和我的不一样,请灵活做出改变~
- JDK: 1.8
- IDEA Ultimate: 2016
- Spring MVC: 4.3.3
- Hibernate: 5.2.3
创建一个基于Maven的Webapp项目
- 新建一个项目:Maven -> Create from archetype -> org.apache.maven.archetypes:maven-archetype-webapp
注意别一不小心选择了org.apche.cocoon:cocoon-22-archetype-webapp
- 下一步主要是需要输入项目的GroupId和ArtifactId,比较简单就不上图了。
- 下下一步也没有什么特别要设置的,可以直接再下一步。
- 点击完成后需要稍微等一下,因为要根据Webapp框架下载一些依赖包和创建项目索引,耐心等个一两分钟,一个基础的Webapp项目就创建好了。
新建一个运行配置
- Running -> Edit Configurations...
- 在Deployment选项卡里添加一个Artifacts:
- 全部的运行配置如下:
配置好了之后,点击那个三角按钮运行,哈哈~Hello World! 出来了。
至此一个基本的web项目已经创建好并可以运行。
创建数据库
在这里我使用的是My SQL数据库,只创建一个表用于存放用户信息,里面只有三个字段:
CREATE DATABASE demo; USE demo; CREATE TABLE user_info ( id INT(11) PRIMARY KEY NOT NULL AUTO_INCREMENT, user_name VARCHAR(100) NOT NULL, password VARCHAR(100) NOT NULL ); CREATE UNIQUE INDEX table_name_id_uindex ON user_info (id); INSERT INTO user_info (user_name, password) VALUES ("admin", "admin");
创建Spring MVC目录结构
打开Project Structure,创建如下图红框内的文件夹:
- java: 标记为Sources(从颜色可看出与其他文件夹的区别)
- controller: 控制器代码,主要是提供web接口。
- dao: 数据访问对象代码,用于操纵数据库。
- entity: 实体类代码,对应数据库表的映射。
- interceptor: 拦截器代码,比如可用用来拦截未经验证的请求。
- service: 业务层代码
- utils: 工具类代码
配置文件
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.example</groupId> <artifactId>maven-springmvc-hibernate-mysql-demo</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>maven-springmvc-hibernate-mysql-demo Maven Webapp</name> <url>http://maven.apache.org</url> <dependencies> <!-- Spring --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.2.release</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.3.2.release</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>4.3.2.release</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>4.3.2.RELEASE</version> </dependency> <!-- Hibernate --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>5.2.3.Final</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>5.2.3.Final</version> </dependency> <!-- unit test --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <!-- log --> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.6.1</version> </dependency> <!-- jstl --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <!-- Apache Commons DBCP --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <!-- tomcat servlet api --> <dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-servlet-api</artifactId> <version>7.0.53</version> <scope>provided</scope> </dependency> <!-- MySql 5.5 Connector --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>6.0.4</version> </dependency> </dependencies> <build> <finalName>maven-springmvc-hibernate-mysql-demo</finalName> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.1</version> <configuration> <!--JDK version--> <source>1.8</source> <target>1.8</target> </configuration> </plugin> </plugins> </build> </project>