SSM 整合配置以及一个简单登陆案例(个人记录)

SSM 文件以及大部分参考博客 https://blog.csdn.net/qq598535550/article/details/51703190

简答的登陆注册案例下载链接在末尾补贴图了

我建立的是 IDEA maven 项目 pomxml 文件如下

  1 <?xml version="1.0" encoding="UTF-8"?>
  2
  3 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5   <modelVersion>4.0.0</modelVersion>
  6
  7   <groupId>com</groupId>
  8   <artifactId>SSMLoginEnd</artifactId>
  9   <version>1.0-SNAPSHOT</version>
 10   <packaging>war</packaging>
 11
 12   <name>SSMLoginEnd Maven Webapp</name>
 13   <!-- FIXME change it to the project‘s website -->
 14   <url>http://www.example.com</url>
 15
 16   <properties>
 17     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 18     <maven.compiler.source>1.7</maven.compiler.source>
 19     <maven.compiler.target>1.7</maven.compiler.target>
 20   </properties>
 21
 22   <dependencies>
 23     <!-- 单元测试 -->
 24     <dependency>
 25       <groupId>junit</groupId>
 26       <artifactId>junit</artifactId>
 27       <version>4.12</version>
 28     </dependency>
 29
 30     <!-- 1.日志 -->
 31     <!-- 实现slf4j接口并整合 -->
 32     <dependency>
 33       <groupId>ch.qos.logback</groupId>
 34       <artifactId>logback-classic</artifactId>
 35       <version>1.1.1</version>
 36     </dependency>
 37
 38     <!-- 2.数据库 -->
 39     <dependency>
 40       <groupId>mysql</groupId>
 41       <artifactId>mysql-connector-java</artifactId>
 42       <version>5.1.37</version>
 43       <scope>runtime</scope>
 44     </dependency>
 45     <dependency>
 46       <groupId>c3p0</groupId>
 47       <artifactId>c3p0</artifactId>
 48       <version>0.9.1.2</version>
 49     </dependency>
 50
 51     <!-- DAO: MyBatis -->
 52     <dependency>
 53       <groupId>org.mybatis</groupId>
 54       <artifactId>mybatis</artifactId>
 55       <version>3.3.0</version>
 56     </dependency>
 57     <dependency>
 58       <groupId>org.mybatis</groupId>
 59       <artifactId>mybatis-spring</artifactId>
 60       <version>1.2.3</version>
 61     </dependency>
 62
 63     <!-- 3.Servlet web -->
 64     <dependency>
 65       <groupId>taglibs</groupId>
 66       <artifactId>standard</artifactId>
 67       <version>1.1.2</version>
 68     </dependency>
 69     <dependency>
 70       <groupId>jstl</groupId>
 71       <artifactId>jstl</artifactId>
 72       <version>1.2</version>
 73     </dependency>
 74     <dependency>
 75       <groupId>com.fasterxml.jackson.core</groupId>
 76       <artifactId>jackson-databind</artifactId>
 77       <version>2.5.4</version>
 78     </dependency>
 79     <dependency>
 80       <groupId>javax.servlet</groupId>
 81       <artifactId>javax.servlet-api</artifactId>
 82       <version>3.1.0</version>
 83     </dependency>
 84
 85     <!-- 4.Spring -->
 86     <!-- 1)Spring核心 -->
 87     <dependency>
 88       <groupId>org.springframework</groupId>
 89       <artifactId>spring-core</artifactId>
 90       <version>5.1.5.RELEASE</version>
 91     </dependency>
 92     <dependency>
 93       <groupId>org.springframework</groupId>
 94       <artifactId>spring-beans</artifactId>
 95       <version>5.1.5.RELEASE</version>
 96     </dependency>
 97     <dependency>
 98       <groupId>org.springframework</groupId>
 99       <artifactId>spring-context</artifactId>
100       <version>5.1.5.RELEASE</version>
101     </dependency>
102     <!-- 2)Spring DAO层 -->
103     <dependency>
104       <groupId>org.springframework</groupId>
105       <artifactId>spring-jdbc</artifactId>
106       <version>5.1.5.RELEASE</version>
107     </dependency>
108     <dependency>
109       <groupId>org.springframework</groupId>
110       <artifactId>spring-tx</artifactId>
111       <version>5.1.5.RELEASE</version>
112     </dependency>
113     <!-- 3)Spring web -->
114     <dependency>
115       <groupId>org.springframework</groupId>
116       <artifactId>spring-web</artifactId>
117       <version>5.1.5.RELEASE</version>
118     </dependency>
119     <dependency>
120       <groupId>org.springframework</groupId>
121       <artifactId>spring-webmvc</artifactId>
122       <version>5.1.5.RELEASE</version>
123     </dependency>
124     <!-- 4)Spring test -->
125     <dependency>
126       <groupId>org.springframework</groupId>
127       <artifactId>spring-test</artifactId>
128       <version>5.1.5.RELEASE</version>
129     </dependency>
130
131     <!-- redis客户端:Jedis -->
132     <dependency>
133       <groupId>redis.clients</groupId>
134       <artifactId>jedis</artifactId>
135       <version>2.7.3</version>
136     </dependency>
137     <dependency>
138       <groupId>com.dyuproject.protostuff</groupId>
139       <artifactId>protostuff-core</artifactId>
140       <version>1.0.8</version>
141     </dependency>
142     <dependency>
143       <groupId>com.dyuproject.protostuff</groupId>
144       <artifactId>protostuff-runtime</artifactId>
145       <version>1.0.8</version>
146     </dependency>
147
148     <!-- Map工具类 -->
149     <dependency>
150       <groupId>commons-collections</groupId>
151       <artifactId>commons-collections</artifactId>
152       <version>3.2</version>
153     </dependency>
154   </dependencies>
155   <build>
156     <finalName>ssm</finalName>
157   </build>
158 </project>

在main文件夹下建立resource 文件夹 并设置为 把resource资源文件夹 目录如下

mapper 下储存你 写为sql 语句xml

spring 下的spring-dao.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"
       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.xsd">
    <!-- 配置整合mybatis过程 -->
    <!-- 1.配置数据库相关参数properties的属性:${url} -->
    <context:property-placeholder location="classpath:jdbc.properties" />

    <!-- 2.数据库连接池 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <!-- 配置连接池属性 -->
        <property name="driverClass" value="${jdbc.driver}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="user" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />

        <!-- c3p0连接池的私有属性 -->
        <property name="maxPoolSize" value="30" />
        <property name="minPoolSize" value="10" />
        <!-- 关闭连接后不自动commit -->
        <property name="autoCommitOnClose" value="false" />
        <!-- 获取连接超时时间 -->
        <property name="checkoutTimeout" value="10000" />
        <!-- 当获取连接失败重试次数 -->
        <property name="acquireRetryAttempts" value="2" />
    </bean>

    <!-- 3.配置SqlSessionFactory对象 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
        <!-- 配置MyBaties全局配置文件:mybatis-config.xml -->
        <property name="configLocation" value="classpath:mybatis-config.xml" />
        <!-- bean 使用别名 -->
        <property name="typeAliasesPackage" value="bean" />
        <!-- 扫描sql配置文件:mapper需要的xml文件 -->
        <property name="mapperLocations" value="classpath:mapper/*.xml" />
    </bean>

    <!-- 4.配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 注入sqlSessionFactory -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
        <!-- 给出需要扫描mapper接口包  -->
        <property name="basePackage" value="mapper" />
    </bean>
</beans>

spring 下的spring-service.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:tx="http://www.springframework.org/schema/tx"
       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.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd">
    <!-- 扫描service包下所有使用注解的类型 -->
    <context:component-scan base-package="service" />

    <!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <!-- 注入数据库连接池 -->
        <property name="dataSource" ref="dataSource" />
    </bean>

    <!-- 配置基于注解的声明式事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" />
</beans>

spring 下的spring-web

<?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:mvc="http://www.springframework.org/schema/mvc"
       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.xsd
    http://www.springframework.org/schema/mvc
    http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
    <!-- 配置SpringMVC -->
    <!-- 1.开启SpringMVC注解模式 -->
    <!-- 简化配置:
        (1)自动注册DefaultAnootationHandlerMapping,AnotationMethodHandlerAdapter
        (2)提供一些列:数据绑定,数字和日期的format @NumberFormat, @DateTimeFormat, xml,json默认读写支持
    -->
    <mvc:annotation-driven />

    <!-- 2.静态资源默认servlet配置
        (1)加入对静态资源的处理:js,gif,png
        (2)允许使用"/"做整体映射
     -->
    <mvc:default-servlet-handler/>

    <!-- 3.配置jsp 显示ViewResolver -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
        <property name="prefix" value="/WEB-INF/jsp/" />
        <property name="suffix" value=".jsp" />
    </bean>

    <!-- 4.扫描web相关的controller -->
    <context:component-scan base-package="controller" />
</beans>

jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
#数据库地址
jdbc.url=jdbc:mysql://localhost:3306/db_test?useUnicode=true&characterEncoding=utf8
#用户名
jdbc.username=root
#密码
jdbc.password=root

logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <!-- encoders are by default assigned the type ch.qos.logback.classic.encoder.PatternLayoutEncoder -->
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <root level="debug">
        <appender-ref ref="STDOUT" />
    </root>
</configuration>

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!-- 配置全局属性 -->
    <settings>
        <!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
        <setting name="useGeneratedKeys" value="true" />

        <!-- 使用列别名替换列名 默认:true -->
        <setting name="useColumnLabel" value="true" />

        <!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>
</configuration>

web.xml

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
                      http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1" metadata-complete="true">
  <!-- 如果是用mvn命令生成的xml,需要修改servlet版本为3.1 -->
  <!-- 配置DispatcherServlet -->
  <welcome-file-list>
    <welcome-file>portal/index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>portal/index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

  <servlet>
    <servlet-name>seckill-dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!-- 配置springMVC需要加载的配置文件
        spring-dao.xml,spring-service.xml,spring-web.xml
        Mybatis - > spring -> springmvc
     -->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>classpath:spring/spring-*.xml</param-value>
    </init-param>
  </servlet>
  <servlet-mapping>
    <servlet-name>seckill-dispatcher</servlet-name>
    <!-- 默认匹配所有的请求 -->
    <url-pattern>/</url-pattern>
  </servlet-mapping>
</web-app>

测试基类 测试的时候继承这个类 加个@Test就行

package test;

import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
// 告诉junit spring配置文件
@ContextConfiguration({ "classpath:spring/spring-dao.xml", "classpath:spring/spring-service.xml" })
public class BaseTest {
}

遇到的问题(刚学也没系统的看教程)

1 里面配置不太清楚 准备日后理解 这是一个模板

2 三层关系要搞清楚

JAVAEE 开发三层

Controller 和页面进行数据交互
Service Controller 调用Service ,进行业务逻辑操作 Service 调用mapper 查询数据操作
mapper ,dao 和数据库进行数据交hu

3 进行  数据库参数大于1 的操作时要加 @parm

例如

boolean insertUser(@Param("username")String username, @Param("password")String password);具体参照 https://blog.csdn.net/weixin_37139197/article/details/82975594

源代码 下载地址 https://www.lanzous.com/i3d5vgd

原文地址:https://www.cnblogs.com/xuexidememeda/p/10498677.html

时间: 2024-10-08 14:17:25

SSM 整合配置以及一个简单登陆案例(个人记录)的相关文章

SSM整合配置

SSM三大框架整合详细教程(Spring+SpringMVC+MyBatis) 使用SSM(Spring.SpringMVC和Mybatis)已经有三个多月了,项目在技术上已经没有什么难点了,基于现有的技术就可以实现想要的功能,当然肯定有很多可以改进的地方.之前没有记录SSM整合的过程,这次刚刚好基于自己的一个小项目重新搭建了一次,而且比项目搭建的要更好一些.以前解决问题的过程和方法并没有及时记录,以后在自己的小项目中遇到我再整理分享一下.这次,先说说三大框架整合过程.个人认为使用框架并不是很难

ASP.NET Aries 入门开发教程2:配置出一个简单的列表页面

前言: 朋友们都期待我稳定地工作,但创业公司若要躺下,也非意念可控. 若人生注定了风雨飘摇,那就雨中前行了. 最机开始看聊新的工作机会,欢迎推荐,创业公司也可! 同时,趁着自由时间,抓紧把这系列教程给写完了. 谢谢大伙的关注和支持. 步骤1:准备好数据库和表(或视图) 由于框架支持跨数据库,所以可以先不用管系统权限的那个数据库,先随意找个数据库. 当然你也可以找个视图(只是视图就不能编辑或删除[权限控制]) 步骤2:配置数据库链接: 以数据库名+Conn 为name(这是跨库的约定,不要乱取).

词法分析程序 LEX和VC6整合使用的一个简单例子

词法分析的理论知识不少,包括了正规式.正规文法.它们之间的转换以及确定的有穷自动机和不确定的有穷自动机等等... 要自己写一个词法分析器也不会很难,只要给出了最简的有穷自动机,就能很方便实现了,用if.switch-case来写一通所谓的状态转换就可以,我近期会写一个简单的词法分析程序来作为例子... 现在已经有人发明了一个叫LEX的工具让你去应用,那我们就省了不少力气,毕竟没到万不得已的时候,我们都没必要重新发明轮子,从另一个角度来说,使用工具是我们人类知识继承的一种方法,也是我们比其他动物优

利用Hessian10分钟配置出一个简单的跨Web服务消息推送

笔者,之前对Web跨服务推送数据一无所知,今天研究了一下.其实有些事物,在不理解的时候完全觉得好似天外来物.但了解一点点之后,又会觉得十分有趣.每天闲扯一下很开心,下面一个简单的实例10分钟配置出跨Web服务的消息推送.一.被调用端web.xml配置 <!--HelloHessian --> <servlet> <servlet-name>HelloHessian</servlet-name> <servlet-class>com.caucho.

SpringMVC+Hibernate框架整合,构建一个简单项目

SpringMVC:简单易用,上手快,项目配置部分很少,注重代码开发层面 Hibernate:ORM(对象关系映射,英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping)框架,轻量级的数据库封装 下面直接上项目: 1.创建Dynamic Web Project项目,命名:SpringMVC_Hibernate ? 如图,缺少web.xml文件,如下图示,加入: ? 2.导入SpringMVC相关jar包 下载地址:SpringMVC下载 ? 3.

axis2与eclipse的整合:开始一个简单的axis2 的demo

1.下载axis2,现在axis2最新版本是axis2-1.6.2,下载地址:http://axis.apache.org/axis2/java/core/download.cgi 2.下载好的zip解压出来放在某个目录下:我这里是放在:C:\software\axis2-1.6.2 3.打开eclipse,windwos-->references-->webservers-->axis2 references  把下载的axis目录添加进去 4.新建一个web项目 5.创建一个包(co

ssm整合配置之springmvc配置

springmvc包含的是我们的severlet层也就是我们的控制器 C  ,这层主要是负责数据的接受和转发,还有页面跳转的操作,所以我们需要在xml里去进行配置操作,首先 1.我们应该先开启扫描器,来扫描我们控制器 这样,控制器里请求转发等注解才会生效 include-filter是只扫描包含@controller注解的操作,其他的不扫描,这个是@controller的类 我们还需要 2.配置用于收发的视图解析器, 3.之后就是两个万能的标准配置 原文地址:https://www.cnblog

做一个简单下载功能的记录

给同事做一个下载的功能,将数据库关联查询后生产csv文件供下载,期间遇到的小问题,记录下. 1,数据库的关联查询 查询出来的数据结构是:一个表TABLE_A的部分数据,和TABLE_A的每条数据在TABLE_B表中的个数 mapper.xml文件 sql语句(下面的方式可能会引发一些问题,下面讲) <resultMap id="aAndCount" type="com.model.AandCount"> <result column="f

一个简单的程序,记录伪代码的使用

计算工资 1 Display "Enter working time: " 2 3 Input workTime 4 5 Display "Enter salary: " 6 7 Input salary 8 9 Display "Your total salary are ", salary * workTime Display 表示打印一串字符串 Input 表示输入数据 原文地址:https://www.cnblogs.com/new-mo