勾選Create from archetypehtml
點擊Nextjava
點擊Nextmysql
點擊Finish,完成基本項目建立web
在main上右鍵new Directory並命名爲java;spring
同時在Project Structure中,將java目錄設置爲Sources,而後Apply,點擊OK。sql
能夠在maven倉庫進行相關依賴搜索:http://www.mvnrepository.com/數據庫
利用<dependency>元素進行項目所依賴的jar包配置,maven經過對pom.xml的配置使得再也不須要導入jar包那麼麻煩apache
IDEA的maven項目中,默認源代碼目錄下的xml等資源文件並不會在編譯的時候一塊打包進classes文件夾,而是直接捨棄掉。spring-mvc
項目中可能包含一些靜態資源如:mapping/*.xml,又或者一些spring的配置文件:spring.xml、spring-mvc.xml等等。這些靜態資源都要配置到target目錄下才能保證項目運行,不然會報找不到運行所需的這些文件。tomcat
target目錄設置,以下圖:
pom.xml在resources中配置靜態資源文件的目錄:
<resources> <!-- 該配置很重要,用於將directory下的資源複製到classpath下面。即target/classes下面--> <resource> <targetPath>whu/edu/irlab/mapping/</targetPath> <directory>src/main/java/whu/edu/irlab/mapping/</directory> <includes> <include>*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> </resource> </resources>
在pom.xml配置後能夠看見target目錄以下,配置的靜態資源文件被包含進來了
注: 在WEB-INFO/lib下存放有jstl.jar和standard.jar,須要將其導入項目的Libraries中(通常使用Maven不這樣作,直接在pom.xml裏面配置響應的jar包依賴就行,當時自動填補依賴有些問題故採起比較麻煩的方式作)
如圖:
<?xml version="1.0" encoding="UTF-8"?> <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> <packaging>war</packaging> <name>MavenDemo</name> <groupId>MavenDemo</groupId> <artifactId>MavenDemo</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <!-- spring start--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>4.1.6.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.1.6.RELEASE</version> </dependency> <!-- spring end--> <!-- mybatis start--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.2.8</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- mybatis end--> <!-- mysql connector start--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.34</version> </dependency> <!-- mysql connector end--> <!-- junit start--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> </dependency> <!-- junit end--> <!-- 阿里巴巴數據源包 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.0.2</version> </dependency> </dependencies> </project>
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <listener> <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class> </listener> <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>/index.jsp</welcome-file> </welcome-file-list> </web-app>
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.0.xsd "> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/mybatis" /> <property name="username" value="root" /> <property name="password" value="root" /> </bean> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> </bean> <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="mapper" /> </bean> </beans>
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd"> <mvc:default-servlet-handler /> <mvc:annotation-driven /> <context:component-scan base-package="controller" /> <context:component-scan base-package="mapper" /> <context:component-scan base-package="service" /> <bean id="viewResovler" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/" /> <property name="suffix" value=".jsp" /> </bean> </beans>
package model; /** * Created by Roger on 2015/9/17. */ public class User { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
package mapper; import model.User; import org.apache.ibatis.annotations.Result; import org.apache.ibatis.annotations.Results; import org.apache.ibatis.annotations.Select; import org.springframework.stereotype.Repository; import java.util.List; /** * Created by Roger on 2015/9/17. */ @Repository("userMapper") public interface UserMapper { @Select("select * from user") @Results(value = {@Result(id = true, property = "id", column = "id"), @Result(property = "name", column = "name")}) public List<User> selectAll(); }
package service.impl; import mapper.UserMapper; import model.User; import org.springframework.stereotype.Service; import service.UserService; import javax.annotation.Resource; import java.util.List; /** * Created by Roger on 2015/9/17. */ @Service("userService") public class UserServiceImpl implements UserService { @Resource(name = "userMapper") private UserMapper userMapper; public List<User> selectAll() { return userMapper.selectAll(); } }
package controller; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import service.UserService; import javax.annotation.Resource; /** * Created by Roger on 2015/9/17. */ @Controller public class UserController { @Resource(name = "userService") private UserService userService; @RequestMapping("/getUser") public String getUser(Model model) { System.out.println(userService.selectAll().size()); model.addAttribute("user", userService.selectAll()); return "listUser"; } }
<%-- Created by IntelliJ IDEA. User: Roger Date: 2015/9/17 Time: 11:01 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt" %> <html> <head> <title>list user</title> </head> <body> <c:forEach items="${user}" var="item"> ${item.id}--${item.name} <br> </c:forEach> </body> </html>
經過getUser來訪問數據庫中user表格的數據
完成代碼下載連接:http://pan.baidu.com/s/1qW01FmW