項目需求分析:
功能需求:登錄,商品列表查詢,修改
項目環境及技術棧:
項目構成及環境: 本項目采用 maven 構建 環境要求: IDEA Version: 2017.2.5 Tomcat Version: 8.5.x > 用到的技術 IOC 容器 spring, 前端web控制層 springmvc, 持久層: mybatis --> mysql
技術棧: J2EE 一系列規范
正式開發:
1、使用 IDEA + maven 搭建整合的 ssm 框架
File --> New Project (注意勾選 Create from archetype 使用模板方便自動生成 webapp 等目錄)
特別需要注意的是應該選 maven-archetype-webapp
這個而不應該選另外一個cocoon-22-archetype-webapp


一路 next 點擊創建后 稍微等待一下,等待 mvn 后台構建項目,如果中間被打斷很可能會出現未知的異常
接下來,就是配置 pom.xml 項目管理文件了,這部分如果不知道如何操作可以單獨學習一下 maven 項目管理
主要是 依賴包(dependency)的配置以及 properties (項目構建編碼,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/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.ghc</groupId> <artifactId>gom</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>gom Maven Webapp</name> <!-- FIXME change it to the project's website --> <url>http://www.example.com</url> <properties> <!-- 設置項目編碼編碼 --> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <!-- spring版本號 --> <spring.version>4.3.5.RELEASE</spring.version> <!-- mybatis版本號 --> <mybatis.version>3.4.1</mybatis.version> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> </properties> <dependencies> <!-- java ee --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> </dependency> <!-- 單元測試 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency> <!--taglib 包--> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> <!-- 實現slf4j接口並整合 --> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.2.2</version> </dependency> <!-- JSON --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.8.7</version> </dependency> <!-- 數據庫驅動包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.41</version> <scope>runtime</scope> </dependency> <!-- 數據庫c3p0連接池 --> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.5.2</version> </dependency> <!-- MyBatis jar包--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!-- mybatis/spring整合包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.3.1</version> </dependency> <!-- Spring 所有依賴包--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency> </dependencies> <build> <finalName>gom</finalName> <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> <plugins> <plugin> <artifactId>maven-clean-plugin</artifactId> <version>3.0.0</version> </plugin> <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging --> <plugin> <artifactId>maven-resources-plugin</artifactId> <version>3.0.2</version> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.7.0</version> </plugin> <plugin> <artifactId>maven-surefire-plugin</artifactId> <version>2.20.1</version> </plugin> <plugin> <artifactId>maven-war-plugin</artifactId> <version>3.2.0</version> </plugin> <plugin> <artifactId>maven-install-plugin</artifactId> <version>2.5.2</version> </plugin> <plugin> <artifactId>maven-deploy-plugin</artifactId> <version>2.8.2</version> </plugin> </plugins> </pluginManagement> </build> </project>
修改 java web 項目的 web.xml 添加 前端中央控制器 DispatchServlet 以及 configContext 文件監聽器
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" > <web-app> <display-name>Archetype Created Web Application</display-name> <!--添加 contextConfigLocation 配置文件監聽器 mybatis 配置文件等--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:/mybatis/spring-mybatis.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!--配置springmvc最重要的前端中央控制器 DispatcherServlet--> <servlet> <servlet-name>SpringMVC</servlet-name> <servlet-class >org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:/spring/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!--添加控制器的 url 映射--> <servlet-mapping> <servlet-name>SpringMVC</servlet-name> <!--為了編寫 RESTful 風格的 url 不用 *.action *.do--> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
mapper.xml 文件編寫
<sql id="where_name_password">
<where>
<if test="name!=null and name!='' and password!=null and password!=''">
name=#{name} and password=#{password}
</if>
<!--可惜沒有 else 所以這里換成 choose when otherwise 進行判斷-->
</where>
mysql 腳本
drop schema if exists gom; CREATE SCHEMA gom; use gom; drop table if exists t_user; -- 用戶表 create table t_user( id int auto_increment primary key, email varchar(25), name varchar(20), password varchar(20), -- md5 存儲, reg_ip varchar(30), reg_date datetime ) ; -- 登錄日志信息表 -- 如果已經有 user_id 存在於 loginfo表則更新之,否則插入 drop table if exists t_loginfo; create table t_loginfo( user_id int, login_ip varchar(30), login_date datetime, FOREIGN KEY(user_id) references t_user(id) ); -- 在未開發注冊頁面之前插入一條測試數據alter insert into t_user(id,email, name , password , reg_ip , reg_date ) values(0,'frank@gmail.com','frank','123','127.0.0.1',sysdate()); insert into t_loginfo(user_id,login_ip,login_date) select id,reg_ip,reg_date from t_user

