IDEA 搭建SSM

本文转载自https://blog.csdn.net/qq_28008917/article/details/79755935###

首先说明这是我一个不熟悉idea和SSM框架的新手小白遇到的坑,适合用idea搭建SSM框架的小伙伴看一看,老鸟就不用看了。以下为详细步骤(傻瓜教程,超级细节)

搭建SSM框架的前提当然是我们已经准备好一下环境

安装好的intellige idea, java环境,tomcat服务器,maven仓库,mysql数据库。

打开idea,new一个project,选择maven项目,如图,注意不要选错成上面那个webapp


点击next继续,


groupid一般是公司名,Artfactid一般为项目名,对于idea的项目目录结构,我自己也没弄明白,不过这并不影响我们的目标

点击next继续,


这里我们使用自己的本地maven仓库,注意setting.xml,repository路径的修改。next继续,然后finish。

第一次建web maven项目可能需要的时间比较长,耐心等待Maven execution finished。最后的项目结构如下图


我们需要在main包下面新建一个java根目录


然后将java目录改成资源根目录。


然后再java目录下创建package  com.ssm 如图

再在com.ssm下创建一个a.txt文件来分隔路径 

然后在com.ssm 下创建一下6个package,然后删除a.txt,最后如下


修改pom.xml的内容如下

<project xmlns=“http://maven.apache.org/POM/4.0.0xmlns: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>自己项目的groupId</groupId>
<artifactId>自己项目对应</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>同上对应 Maven Webapp</name>
<url>http://maven.apache.org</url>
<properties>
<!-- spring版本号 -->
<spring.version>4.0.2.RELEASE</spring.version>
<!-- mybatis版本号 -->
<mybatis.version>3.2.6</mybatis.version>
<!-- log4j日志文件管理包版本 -->
<slf4j.version>1.7.7</slf4j.version>
<log4j.version>1.2.17</log4j.version>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<!-- 表示开发的时候引入,发布的时候不会加载此包 -->
<scope>test</scope>
</dependency>
<!-- spring核心包 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>${spring.version}</version>
</dependency>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-web<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-oxm<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-tx<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-jdbc<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-webmvc<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-aop<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-context-support<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-test<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${spring.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span style="color:#808080;"><em>&lt;!-- mybatis核心包 --&gt;

<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>KaTeX parse error: Expected 'EOF', got '&' at position 24: ….version}<span>&̲lt;/</span><spa…{log4j.version}</version>
</dependency>

<span style="color:#808080;"><em>&lt;!-- 格式化对象,方便输出日志 --&gt;

<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.1.41</version>
</dependency>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.slf4j<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>slf4j-api<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${slf4j.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.slf4j<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>slf4j-log4j12<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>${slf4j.version}<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span style="color:#808080;"><em>&lt;!-- log end --&gt;

<!-- 映入JSON -->
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
<!-- 上传组件包 -->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>1.9</version>
</dependency>

<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-messaging<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>4.0.5.RELEASE<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>org.springframework<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>spring-websocket<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>4.0.5.RELEASE<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
<span>&lt;</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>com.google.code.gson<span>&lt;/</span><span style="color:#000080;"><strong>groupId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>gson<span>&lt;/</span><span style="color:#000080;"><strong>artifactId</strong></span><span>&gt;</span>
  <span>&lt;</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>2.3.1<span>&lt;/</span><span style="color:#000080;"><strong>version</strong></span><span>&gt;</span>
<span>&lt;/</span><span style="color:#000080;"><strong>dependency</strong></span><span>&gt;</span>

</dependencies>

<!-- 千万不要遗漏下面的内容,我就是遗漏了,导致deploment的war包里没有mapper里的xml文件 ,ecilpse中则不会出现这个问题–>
  <build>
<finalName>ProjectMatch</finalName>
<resources>
<resource>
<directory>${basedir}/src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
</build>
</project>

然后在resources目录下新建如下4个文件如图


jdbc.properties 内容如下,标红的地方都需要按自己数据库修改,test为数据库名

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8
username=root
password=123456
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000

log4j.properties内容如下,可完全复制

#定义LOG输出级别
log4j.rootLogger=INFO,Console,File
#定义日志输出目的地为控制台
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
#可以灵活地指定日志输出格式,下面一行是指定具体的格式
log4j.appender.Console.layout = org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n

#文件大小到达指定尺寸的时候产生一个新的文件
log4j.appender.File = org.apache.log4j.RollingFileAppender
#指定输出目录
log4j.appender.File.File = logs/ssm.log
#定义文件最大大小
log4j.appender.File.MaxFileSize = 10MB
# 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志
log4j.appender.File.Threshold = ALL
log4j.appender.File.layout = org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c]%m%n

spring-mvc.xml内容如下 ,红色标记需要自己对应修改

<?xml version=“1.0” encoding=“UTF-8”?>
<beans xmlns=“http://www.springframework.org/schema/beans
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instancexmlns:p=“http://www.springframework.org/schema/p
xmlns:context=“http://www.springframework.org/schema/context
xmlns:mvc=“http://www.springframework.org/schema/mvc
xsi:schemaLocation=“http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd>
<!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 -->
<context:component-scan base-package=“com.qihang.controller” />
<!–避免IE执行AJAX时,返回JSON出现下载文件 -->
<bean id=“mappingJacksonHttpMessageConverter”
class=“org.springframework.http.converter.json.MappingJacksonHttpMessageConverter”>
<property name=“supportedMediaTypes”>
<list>
<value>text/html;charset=UTF-8</value>
</list>
</property>
</bean>
<span>&lt;</span><span style="color:#000080;"><strong>import </strong></span><span style="color:#0000ff;"><strong>resource</strong></span><span style="color:#008000;"><strong>="classpath:spring-mybatis.xml" </strong></span><span>/&gt;</span>

<span style="color:#808080;"><em>&lt;!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 --&gt;

<bean
class=“org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter”>
<property name=“messageConverters”>
<list>
<ref bean=“mappingJacksonHttpMessageConverter” /> <!-- JSON转换器 -->
</list>
</property>
</bean>

<span style="color:#808080;"><em>&lt;!-- 定义跳转的文件的前后缀 ,视图模式配置--&gt;

<bean class=“org.springframework.web.servlet.view.InternalResourceViewResolver”>
<!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->
<property name=“prefix” value="/WEB-INF/page/" />
<property name=“suffix” value=".jsp" />
</bean>

<span style="color:#808080;"><em>&lt;!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 --&gt;

<bean id=“multipartResolver”
class=“org.springframework.web.multipart.commons.CommonsMultipartResolver”>
<!-- 默认编码 -->
<property name=“defaultEncoding” value=“utf-8” />
<!-- 文件大小最大值 -->
<property name=“maxUploadSize” value=“10485760000” />
<!-- 内存中的最大值 -->
<property name=“maxInMemorySize” value=“40960” />
</bean>

<span>&lt;</span><span style="color:#660e7a;"><strong>mvc</strong></span><span style="color:#000080;"><strong>:annotation-driven</strong></span><span>/&gt;</span>
<span>&lt;</span><span style="color:#660e7a;"><strong>mvc</strong></span><span style="color:#000080;"><strong>:default-servlet-handler</strong></span><span>/&gt;</span>
<span style="color:#808080;"><em>&lt;!--&lt;mvc:resources location="/" mapping="/js/**" /&gt;--&gt;

<!–<mvc:resources location="/css/" mapping="/css/"/>–>
<!–<mvc:resources location="/fonts/" mapping="/fonts/"/>–>
<!–<mvc:resources location="/resources/" mapping="/resources/**"/>–>
</beans>spring-mybatis.xml内容如下 同上

<?xml version=“1.0” encoding=“UTF-8”?>
<beans xmlns=“http://www.springframework.org/schema/beans
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instancexmlns:p=“http://www.springframework.org/schema/p
xmlns:context=“http://www.springframework.org/schema/context
xmlns:mvc=“http://www.springframework.org/schema/mvc
xsi:schemaLocation=“http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd>
<!-- 自动扫描 -->
<context:component-scan base-package=“com.qihang/>
<!-- 引入配置文件 -->
<bean id=“propertyConfigurer”
class=“org.springframework.beans.factory.config.PropertyPlaceholderConfigurer”>
<property name=“location” value=“classpath:jdbc.properties” />
</bean>
<span>&lt;</span><span style="color:#000080;"><strong>bean </strong></span><span style="color:#0000ff;"><strong>id</strong></span><span style="color:#008000;"><strong>="dataSource" </strong></span><span style="color:#0000ff;"><strong>class</strong></span><span style="color:#008000;"><strong>="org.apache.commons.dbcp.BasicDataSource"

destroy-method=“close”>
<property name=“driverClassName” value="KaTeX parse error: Expected 'EOF', got '&' at position 34: …></span><span>/&̲gt;</span> …{url}" />
<property name=“username” value="KaTeX parse error: Expected 'EOF', got '&' at position 36: …></span><span>/&̲gt;</span> …{password}" />
<!-- 初始化连接大小 -->
<property name=“initialSize” value="KaTeX parse error: Expected 'EOF', got '&' at position 37: …g></span><span>&̲gt;&lt;/</span>…{maxActive}"></property>
<!-- 连接池最大空闲 -->
<property name=“maxIdle” value="KaTeX parse error: Expected 'EOF', got '&' at position 33: …g></span><span>&̲gt;&lt;/</span>…{minIdle}"></property>
<!-- 获取连接最大等待时间 -->
<property name=“maxWait” value="${maxWait}"></property>
</bean>

<span style="color:#808080;"><em>&lt;!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --&gt;

<bean id=“sqlSessionFactory” class=“org.mybatis.spring.SqlSessionFactoryBean”>
<property name=“dataSource” ref=“dataSource” />
<property name=“configLocation” value=“classpath:/mybatis-config.xml”></property>
<!-- 自动扫描mapping.xml文件 -->
<property name=“mapperLocations” value=“classpath:com/qihang/mapper/*.xml></property>
</bean>

<span style="color:#808080;"><em>&lt;!--&amp;lt;!&amp;ndash; spring和MyBatis完美整合,不需要mybatis的配置映射文件 &amp;ndash;&amp;gt;--&gt;

<!–<bean id=“sqlSessionFactory” class=“org.mybatis.spring.SqlSessionFactoryBean”>–>
<!–<property name=“dataSource” ref=“dataSource” />–>
<!–<property name=“configLocation” value=“classpath:/mybatis-config.xml”></property>–>
<!–&lt;!&ndash; 自动扫描mapping.xml文件 &ndash;&gt;–>
<!–<property name=“mapperLocations” value=“classpath:com/qihang/mapper/*.xml”></property>–>
<!–</bean>–>

<!-- DAO接口所在包名,Spring会自动查找其下的类 -->
<bean class=“org.mybatis.spring.mapper.MapperScannerConfigurer”>
<property name=“basePackage” value=“com.qihang.dao/>
<property name=“sqlSessionFactoryBeanName” value=“sqlSessionFactory”></property>
</bean>

<span style="color:#808080;"><em>&lt;!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --&gt;

<bean id=“transactionManager”
class=“org.springframework.jdbc.datasource.DataSourceTransactionManager”>
<property name=“dataSource” ref=“dataSource” />
</bean>

</beans>

然后项目的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 xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance
xmlns=“http://java.sun.com/xml/ns/javaee
xsi:schemaLocation=“http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd
version=“3.0”>
<display-name>Archetype Created Web Application</display-name>
<!-- Spring和mybatis的配置文件 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mybatis.xml</param-value>
</context-param>

<!–Log4j配置–>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>60000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

<!-- 编码过滤器 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>

<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<!–Spring监听器 ApplicationContext 载入 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 防止Spring内存溢出监听器 -->
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>

<!-- Spring MVC 核心配置开始 -->
<servlet>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 可以通过contextConfigLocation来自定义SpringMVC配置文件的位置,如不指定,则默认在WEB-INF目录下,名称为[<servlet-name>]-servlet.xml,
此时文件名必须为[<servlet-name>]-servlet.xml,否则会出错–>
<!–以下init-param是自定义SpringMVC的配置文件的位置 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>

<!-- 拦截设置 -->
<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<!-- 此处可以可以配置成*.do,对应struts的后缀习惯 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
<!-- Spring MVC 核心配置结束 -->

<!-- 配置SESSION超时,单位是分钟 -->
<session-config>
<session-timeout>15</session-timeout>
</session-config>

</web-app>

然后我们就可以编写测试了。

在数据库中创建user表,有两条记录,如图


在pojo包中创建user类

package com.qihang.pojo;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Table;

@Entity
@Table(name = “user”)
public class user {

<span style="color:#808000;">@Column</span>(name = <span style="color:#008000;"><strong>"username"</strong></span>)
String <span style="color:#660e7a;"><strong>username</strong></span>;

<span style="color:#808000;">@Column</span>(name = <span style="color:#008000;"><strong>"password"</strong></span>)
String <span style="color:#660e7a;"><strong>password</strong></span>;

<span style="color:#000080;"><strong>public </strong></span>String getUsername() {
    <span style="color:#000080;"><strong>return </strong></span><span style="color:#660e7a;"><strong>username</strong></span>;
}

<span style="color:#000080;"><strong>public void </strong></span>setUsername(String username) {
    <span style="color:#000080;"><strong>this</strong></span>.<span style="color:#660e7a;"><strong>username </strong></span>= username;
}

<span style="color:#000080;"><strong>public </strong></span>String getPassword() {
    <span style="color:#000080;"><strong>return </strong></span><span style="color:#660e7a;"><strong>password</strong></span>;
}

<span style="color:#000080;"><strong>public void </strong></span>setPassword(String password) {
    <span style="color:#000080;"><strong>this</strong></span>.<span style="color:#660e7a;"><strong>password </strong></span>= password;
}

}

在dao包中创建userDao接口

package com.qihang.dao;

import com.qihang.pojo.user;

public interface userDao {
public user selectByUserId(String username);

<span style="color:#000080;"><strong>public int </strong></span>insertUser(user user);

}

在mapper包中创建userMapping.xml

<?xml version=“1.0” encoding=“UTF-8” ?>
<!DOCTYPE mapper PUBLIC “-//mybatis.org//DTD Mapper 3.0//EN” http://mybatis.org/dtd/mybatis-3-mapper.dtd>
<mapper namespace=“com.qihang.dao.userDao” >
<resultMap id=“BaseResultMap” type=“com.qihang.pojo.user” ><!–对应的实体类位置 -->
<result column=“username” property=“username” jdbcType=“VARCHAR” />
<result column=“password” property=“password” jdbcType=“VARCHAR” />
</resultMap>
<span>&lt;</span><span style="color:#000080;"><strong>sql </strong></span><span style="color:#0000ff;"><strong>id</strong></span><span style="color:#008000;"><strong>="userAtr"</strong></span><span>&gt;</span>
    #{username},#{password}
<span>&lt;/</span><span style="color:#000080;"><strong>sql</strong></span><span>&gt;</span>

<span>&lt;</span><span style="color:#000080;"><strong>select </strong></span><span style="color:#0000ff;"><strong>id</strong></span><span style="color:#008000;"><strong>="selectByUserId" </strong></span><span style="color:#0000ff;"><strong>parameterType</strong></span><span style="color:#008000;"><strong>="String" </strong></span><span style="color:#0000ff;"><strong>resultMap</strong></span><span style="color:#008000;"><strong>="BaseResultMap"</strong></span><span>&gt;</span>
    SELECT
    <span style="font-style:italic;">*

FROM user
WHERE 1=1
<if test="_parameter != null">
AND username = #{username}
</if>
</select>

<span>&lt;</span><span style="color:#000080;"><strong>insert </strong></span><span style="color:#0000ff;"><strong>id</strong></span><span style="color:#008000;"><strong>="insertUser" </strong></span><span style="color:#0000ff;"><strong>parameterType</strong></span><span style="color:#008000;"><strong>="java.util.HashMap"</strong></span><span>&gt;</span>
    INSERT  INTO user
    VALUE(<span>&lt;</span><span style="color:#000080;"><strong>include </strong></span><span style="color:#0000ff;"><strong>refid</strong></span><span style="color:#008000;"><strong>="userAtr"</strong></span><span>&gt;&lt;/</span><span style="color:#000080;"><strong>include</strong></span><span>&gt;</span>)
<span>&lt;/</span><span style="color:#000080;"><strong>insert</strong></span><span>&gt;</span>

</mapper>

在services包中创建userService接口

package com.qihang.services;

import com.qihang.pojo.user;

public interface userService {
public user querybyUsername(String username);

<span style="color:#000080;"><strong>public int </strong></span>insert(user user);

}在servicesImp中创建userServiceImp类

package com.qihang.servicesImp;

import com.qihang.pojo.user;
import com.qihang.services.userService;
import com.qihang.dao.userDao;
import org.springframework.stereotype.Service;
import org.springframework.beans.factory.annotation.Autowired;

@Service(“userServiceImp”)
public class userServiceImp implements userService {

<span style="color:#808000;">@Autowired

private userDao userDao;
public int insert(user user) {
return userDao.insertUser(user);
}

<span style="color:#000080;"><strong>public </strong></span>user querybyUsername(String username) {
    <span style="color:#000080;"><strong>return </strong></span><span style="color:#660e7a;"><strong>userDao</strong></span>.selectByUserId(username);
}

}

在WEB-INF下创建page包,然后在page包中创建test.jsp文件 如图


<%@ page contentType=“text/html;charset=UTF-8language=“java” %>
<html>
<body>
用户名<h1>KaTeX parse error: Expected '}', got '#' at position 63: …n style="color:#̲000080;"><stron…{user.password}</h1>
</body>
</html>

然后在controller包下创建userController类

package com.qihang.controller;

import com.qihang.pojo.user;
import com.qihang.services.userService;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestParam;

@Controller
public class UserController {
@Autowired
private userService userService;

<span style="color:#808000;">@RequestMapping</span>(<span style="color:#008000;"><strong>"/query"</strong></span>)
<span style="color:#000080;"><strong>public </strong></span>String query(<span style="color:#808000;">@RequestParam</span>(value = <span style="color:#008000;"><strong>"username"</strong></span>,required = <span style="color:#000080;"><strong>true</strong></span>) String username, Model model){
    user user = <span style="color:#000080;"><strong>new </strong></span>user();
    user = <span style="color:#660e7a;"><strong>userService</strong></span>.querybyUsername(username);
    model.addAttribute(<span style="color:#008000;"><strong>"user"</strong></span>,user);
    <span style="color:#000080;"><strong>return </strong></span><span style="color:#008000;"><strong>"test"</strong></span>;

做到这里就把测试domo写完了,下一步将项目部署到服务器。

如图点击配置

点击 +


将本地tomcat配置好,按如图deployment 


配置好就完成了。点击运行,在浏览器上输入

http://localhost:8080/query?username=lisi

看到如下就说明我们配置ok了



谢谢你们,看到这里也是幸苦了,如果还没有成功的再认真看看还有哪里是不是遗漏了,也可以在楼下留言,千万别灰心,程序员工作就是与bug作斗争的过程,也是在这些坑中慢慢学习的。

对于新手小白,经常会花很多时间在这些框架的搭建上或是一些工具的配置,而且由于不熟悉,会踩很多坑,花大量时间在这上面确实很不值得的。写这篇博客也是为大家能在学习的路上能更顺利些,当然也是给自己的踩坑路做个记录吧

转载请注明出处

                                                                                                                                





 
 
 



Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值