1.打开idea,新建项目,选择maven骨架,而后填写包名和项目名称,一直下一步。css
接着下一步,配置项目的maven环境前端
建立完成以后,以下图:(上边的项目名字只是例子,具体的以本身搭建的项目名为准)java
能够看新建完成的项目src/main/webapp的文件夹,还少两个root文件夹,分别是:src/main/java 和 src/main/resources 文件夹。接下来建立:mysql
建立后以下,这只是一个简单的文件夹,而一般这两个文件夹都是用来放咱们的java文件和资源文件的,因此必须将他们呢标记为root,linux
标记完成以下:web
其中java中创建包文件放咱们项目中的java文件也就是一些类,resources中放的是一些资源文件如各类xml等,这两个文件编译后统一都会编译到项目的根目录。spring
项目创建完成以后,就开始咱们的后续工做了,因为这是搭建一个简单的SSM项目,我们就先把须要的依赖给添加一下。sql
在pom.xml添加依赖,这样maven就会去中央仓库下载jar包,提供给项目使用。数据库
简单的ssm框架包括的依赖无非就是这几种,spring家族的依赖,mybatis的依赖,mybatis-spring关联的依赖,数据库链接以及链接池依赖,java的servlet依赖等。express
下面粘贴相出pom中所需的依赖(spring相关依赖的版本须要保持一直,否侧会有冲突)
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> <spring.version>4.3.18.RELEASE</spring.version> <mybatis.version>3.4.1</mybatis.version> </properties> <dependencies> <!--Spring系列--> <!-- spring-context --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-core --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-beans --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-web --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-webmvc --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-jdbc --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-tx --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <!-- spring-test --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> <scope>test</scope> </dependency> <!--MyBatis--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!--Mybatis-spring-connection--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.3.1</version> </dependency> <!--java 基本依赖--> <!-- javaee-api --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> <scope>provided</scope> </dependency> <!-- mysql-connector-java --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.11</version> </dependency> <!-- druid数据库链接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.10</version> </dependency> <!-- fastjson --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.47</version> </dependency> </dependencies>
接下里在java目录下建立package,resources下建立xml
conrtroler控制器创建控制层代码,主要用于接受前端的访问和返回数据,
service:controller层接受到请求进行业务处理的一层,直接到serviceimpl中进行业务逻辑的编写
dao: mybatis的dao文件生成的地方
util:一些工具类相关
spring中存放的是与spring相关的配置文件,如spring-context,spring-mvc.spring-datasources等
如今先开始编写配置文件:
直接粘贴处各个配置文件:
applicationContext.xml
<?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:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd"> <context:component-scan base-package="com.webforlinux.cn" use-default-filters="false"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan> <context:property-placeholder location="classpath:*.properties" ignore-unresolvable="true"/> <context:property-placeholder location="classpath*:*/*.properties" ignore-unresolvable="true"/> <import resource="spring-datesource.xml"/> <import resource="spring-mvc.xml"/> </beans>
spring-mvc.xml
<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/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <mvc:annotation-driven /> <mvc:default-servlet-handler /> <!--静态资源放行不拦截--> <!--<mvc:resources mapping="/js/**" location="/js/"/> <mvc:resources mapping="/fonts/**" location="/font/"/> <mvc:resources mapping="/css/**" location="/css/"/>--> <!--视图解析--> <!--<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/"/> <property name="suffix" value=".jsp" /> </bean>--> </beans>
spring-datasource.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <!--durid链接池--> <bean id="dateSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="clone"> <property name="driverClassName" value="${jdbc.driverCLassName}"/> <property name="url" value="${jdbc.url}"/> <property name="username" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> <property name="initialSize" value="${jdbc.initialSize}"/> <property name="minIdle" value="${jdbc.minIdle}"/> <property name="maxActive" value="${jdbc.maxActive}"/> <!--链接超时等待时间--> <property name="maxWait" value="${maxWait}"/> <!--检测须要关闭的空闲链接--> <property name="timeBetweenEvictionRunsMillis" value="${jdbc.timeBetweenEvictionRunsMillis}"/> <!--一个链接在池中最小的生存空间--> <property name="minEvictableIdleTimeMillis" value="${jdbc.minEvictableIdleTimeMillis}"/> <property name="testWhileIdle" value="true"/> </bean> <!--配置SqlSessionFactory对象--> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dateSource"/> <property name="mapperLocations" value="classpath:mapper/*.xml"/> </bean> <!--扫描dao包--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.*.*.*"/> -----根据本身dao所在的包名编写 <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean> <!--事务--> <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dateSource"/> </bean> <tx:annotation-driven transaction-manager="txManager"/> </beans>
其中spring-datasource.xml配置文件中须要引入数据库链接的配置文件,还须要在resources目录下建立jdbc.properties
jdbc.properties
jdbc.driverCLassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true jdbc.username=root jdbc.password=123456 jdbc.initialSize=1 jdbc.minIdle=1 jdbc.maxActive=10 maxWait=10000 jdbc.timeBetweenEvictionRunsMillis=60000 jdbc.minEvictableIdleTimeMillis=300000
reosurce目录下建立Mybatsi自动生成文件
generatorConfig.xml
以上红框内根据本身的配置本身修改,分别是数据库连接信息,和 生成mapper,dao,以及xml的地址,自行修改,能够用本身建好的包,没有新建的话,会自动生成。
classPathEntry 标签内的是须要一个连接的jar包的,去官网下载而后放到一个目录,而后指向它。
使用其以前先创建好数据库以及数据库表:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <generatorConfiguration> <classPathEntry location="C:\work\enviroment\resources/mysql-connector-java-5.1.47.jar"/> <context id="DB2Tables1" targetRuntime="MyBatis3"> <!-- 配置pojo的序列化 --> <plugin type="org.mybatis.generator.plugins.SerializablePlugin" /> <commentGenerator> <property name="suppressAllComments" value="true"/> </commentGenerator> <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/shop" userId="root" password="0000"/> <javaTypeResolver type=""> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <javaModelGenerator targetPackage="com.eva.cn.pojo" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <sqlMapGenerator targetPackage="mybatis" targetProject="src/main/resources"> <property name="enableSuzbPackages" value="true"/> </sqlMapGenerator> <!-- ANNOTATEDMAPPER XMLMAPPER --> <javaClientGenerator type="XMLMAPPER" targetPackage="com.eva.cn.dao" targetProject="src/main/java"> <property name="enableSubPackages" value="true"/> </javaClientGenerator> <table tableName="user" domainObjectName="User" enableSelectByExample="false" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false"> <generatedKey column="id" sqlStatement="MySql" identity="true"/> </table> </context> </generatorConfiguration>
创建完数据库和数据库表以后,要确认和jdbc.properties的信息一致,以及和generatorConfig.xml的信息一致,而后开始使用自动生成文件。(小项目也能够本身手写,可是这确实是一个这个能够帮咱们作不少事)
首先在pom中添加该插件的依赖:
<build> <finalName>webforlinux</finalName> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> </plugin> </plugins> </build>
此时idea的右侧边栏目中的maven菜单里卖打开插件会发现已经有了
接下里,双击插件,出现以下
如上,关于mybatis的相关文件上传文件生成成功(包括 实体类+dao + dao.mapper):
作到这,咱们能够配置一下web.xml,而后先跑一下项目,看是否能够跑起来了,以确保添加配置文件都没问题。
跑的没问题了再开始搭建一个很简单的页面看一下SSM的执行流程:
想run任何一个java项目都得有应用服务器,应用服务器会读取项目的web.xml,来启动项目作一些初始化的配置,如今粘贴出web.xml的配置:
<!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> <!--加载spring--> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:/spring/applicationContext.xml</param-value> </context-param> <context-param> <param-name>contextClass</param-name> <param-value>org.springframework.web.context.support.XmlWebApplicationContext</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!--springMVC--> <servlet> <servlet-name>SpringDispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextClass</param-name> <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>SpringDispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
接下来配置tomcat:
添加tomcat成功后,点击run或者 debug便可
如上,系统启动成功::
至此,SSM框架搭建完成,接下里本身就能够在controller层写控制层代码等,有点累,就先写到这吧。下次有时间在分享。谢谢你们的查看,鄙人拙见,有什么问题,还望指出。