学习OA系统制作历程day1

什么是OA系统?

    OA是Office Automation的缩写,也就是办公自动化。OA系统是处理一个组织内部的事务性工作、辅助管理以及提高办公效率的系统。它能够将一个组织需要人工管控和调度的所有相关信息集中起来进行信息化管理,不同的企业对OA系统有不同的需求,所以OA系统需要定制化。

OA系统的开发

设计

分层

view:severlet/action
Service:接口/实现类
Dao:接口/实现类
耦合
解耦

使用技术

    SSH框架:Struts2 + Hibernate + Spring + Maven

    测试使用Junit4.1

开发环境

    Windows10、Tomcat、Intellij IDEA 2019.1.3、Mysql

规范

    编码统一使用UTF-8,防止后期出现乱码问题。

OA系统功能模块设计

    暂未完善

系统模块功能列表

准备

数据库

    在mysql的目录下命令行,登陆mysql,创建新数据库comoasystem。

    mysql -u (?) -p (?)

    mysql>create database comoasystem default character set utf8;

IDEA项目创建

    在IDEA上方菜单栏找到相应菜单File>>New>Project…

    在New Project窗口中的左侧寻找Maven,右侧第二行将Create from archetype打勾,选中org.apache.maven.archetypes:maven-archetype-webapp,然后next。
在这里插入图片描述
    groupId :the unique identifier of the organization or group that created the project

    artifactId :unique base name of the primary artifact being generated by this project

    GroupID 是项目组织唯一的标识符,实际对应JAVA的包的结构,是main目录里java的目录结构。

    ArtifactID是项目的唯一的标识符,实际对应项目的名称,就是项目根目录的名称。

    理解之后将图中webapp更换成想输入的标识符,并next。
在这里插入图片描述
点击Properties栏中的“+”弹出Add Maven Property窗口,在Name中输入archetypeCatelog,在Value中输入internal,接着点击Next。这个作用是让maven框架加快创建速度。
在这里插入图片描述
    最后取好项目名,选好目录,直接Finish创建。

    创建完成后右下角会弹出Maven project need to be imported的提示,选择Enable Auto-Import,每次更新pom.xml的时候才会自动下载和导入,否则需要手动更新比较麻烦。
在这里插入图片描述

需要配置的文件

    需要新建resource文件夹以及新建和配置如下文件:
在这里插入图片描述

pom.xml

    在pom.xml中输入如下配置,让Maven去下载所需框架和依赖:

<?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.ryougishiki.oa</groupId>
  <artifactId>OASystem</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>war</packaging>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <maven.compiler.target>1.7</maven.compiler.target>
  </properties>

  <dependencies>

    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context</artifactId>
      <version>5.1.4.RELEASE</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework/spring-core -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>5.1.4.RELEASE</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework/spring-orm -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-orm</artifactId>
      <version>5.1.4.RELEASE</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.springframework/spring-web -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>5.1.4.RELEASE</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.apache.struts/struts2-core -->
    <dependency>
      <groupId>org.apache.struts</groupId>
      <artifactId>struts2-core</artifactId>
      <version>2.5.20</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/org.apache.struts/struts2-spring-plugin -->
    <dependency>
      <groupId>org.apache.struts</groupId>
      <artifactId>struts2-spring-plugin</artifactId>
      <version>2.5.20</version>
    </dependency>
    
    <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->
    <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-core</artifactId>
      <version>5.4.1.Final</version>
    </dependency>
    
    <dependency>
      <groupId>org.junit.jupiter</groupId>
      <artifactId>junit-jupiter-api</artifactId>
      <version>5.3.2</version>
      <scope>compile</scope>
    </dependency>

    <!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
    <dependency>
      <groupId>com.mchange</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.5.2</version>
    </dependency>


    <!-- https://mvnrepository.com/artifact/c3p0/c3p0 -->
    <dependency>
      <groupId>c3p0</groupId>
      <artifactId>c3p0</artifactId>
      <version>0.9.1.2</version>
    </dependency>


    <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-c3p0 -->
    <dependency>
      <groupId>org.hibernate</groupId>
      <artifactId>hibernate-c3p0</artifactId>
      <version>5.4.1.Final</version>
    </dependency>

    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>8.0.13</version>
    </dependency>

      <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-log4j12</artifactId>
          <version>1.7.2</version>
      </dependency>

    <dependency>
      <groupId>org.apache.logging.log4j</groupId>
      <artifactId>log4j-core</artifactId>
      <version>2.10.0</version>
    </dependency>
    
    <!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-api -->
    <dependency>
      <groupId>org.apache.logging.log4j</groupId>
      <artifactId>log4j-api</artifactId>
      <version>2.10.0</version>
    </dependency>
  </dependencies>

  <build>
    <finalName>infoManeger</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.1.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.8.0</version>
        </plugin>
        <plugin>
          <artifactId>maven-surefire-plugin</artifactId>
          <version>2.22.1</version>
        </plugin>
        <plugin>
          <artifactId>maven-war-plugin</artifactId>
          <version>3.2.2</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>
struts.xml

    配置Struts的模式、扩展名配置、主题配置以及命名空间。

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE struts PUBLIC
        "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN"
        "http://struts.apache.org/dtds/struts-2.5.dtd">

<struts>
    <!-- 配置为开发模式 -->
    <constant name="struts.devMode" value="true"></constant>
    <!-- 扩展名配置为action -->
    <constant name="struts.action.extension" value="action"></constant>
    <!-- 主题配置为simple -->
    <constant name="struts.ui.theme" value="simple"></constant>

    <package name="default" namespace="/" extends="struts-default">
    </package>
</struts>
hibernate.cfg.xml

    在hibernate.cfg.xml中配置数据库的驱动为方言、事务提交和上下文设定。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
    <session-factory>

        <!-- hibernate.connection.driver_class : 连接数据库的驱动  -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>

        <!-- show_sql: 操作数据库时,会 向控制台打印sql语句 -->
        <property name="show_sql">true</property>

        <!-- format_sql: 打印sql语句前,会将sql语句先格式化  -->
        <property name="format_sql">true</property>
        <property name="hbm2ddl.auto">update</property>

        <!-- hibernate.connection.autocommit: 事务自动提交  -->
        <property name="hibernate.connection.autocommit">true</property>
        <!-- hibernate.current_session_context_class:上下文设定 -->
        <property name="hibernate.current_session_context_class">org.springframework.orm.hibernate5.SpringSessionContext</property>
    </session-factory>
</hibernate-configuration>
applicationContext.xml

    在applicationConetext.xml中配置自动注解bean和外部导入jdbc的配置文件以及相关数据库配置,声明式事务管理

<?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"
        xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">

    <!-- 自动扫描与装配bean -->
    <context:component-scan base-package="com.ryougishiki.oa"></context:component-scan>

    <!-- 导入外部的properties文件 -->
    <context:property-placeholder location="classpath:jdbc.properties"></context:property-placeholder>

    <!-- 配置SessionFactory -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
        <!-- 指定hibernate的配置文件位置 -->
        <property name="configLocation" value="classpath:hibernate.cfg.xml"></property>
        <!-- 配置c3p0数据库连接池 -->
        <property name="dataSource">
            <bean class="com.mchange.v2.c3p0.ComboPooledDataSource">
                <!-- 数据库连接信息 -->
                <property name="jdbcUrl" value="${jdbcUrl}"></property>
                <property name="driverClass" value="${driverClass}"></property>
                <property name="user" value="${user}"></property>
                <property name="password" value="${password}"></property>
                <!-- 其他配置 -->
                <!-- 初始化是获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default:3 -->
                <property name="initialPoolSize" value="3"></property>
                <!-- 连接池中保留的最小连接数。Default:3 -->
                <property name="minPoolSize" value="3"></property>
                <!-- 连接池中保留的最大连接数。Default:15 -->
                <property name="maxPoolSize" value="15"></property>
                <!-- 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default:3 -->
                <property name="acquireIncrement" value="3"></property>
                <!-- 控制数据源内加载的PrepareStatements数量。如果maxStatements与maxStatementsPerConnection均为0,啧缓存被关闭。Default:0 -->
                <property name="maxStatements" value="8"></property>
                <!-- maxStatementsPerConnection定义了连接池内单个连接所拥有的的最大缓存statements数。Default:0 -->
                <property name="maxStatementsPerConnection" value="5"></property>
                <!-- 最大空闲时间,1800秒内未使用则连接被丢弃。若为0则永不丢弃。Default:0 -->
                <property name="maxIdleTime" value="1800"></property>

            </bean>
        </property>
    </bean>

    <!-- 配置声明式事务管理(采用注解的方式) -->
    <bean id="txManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>
    <tx:annotation-driven transaction-manager="txManager"/>
</beans>
log4j2.properties

    顾名思义,log4j的配置文件,可到jar依赖包中自行搜索。

web.xml

    在webapp/WEB-INF目录下,配置整合Spring和Struts2的重要成员之一。

<?xml version="1.0" encoding="UTF-8"?>
<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_4_0.xsd"
         version="4.0">

    <!-- 配置Spring的用于初始化容器对象的监听器 -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext*.xml</param-value>
    </context-param>

    <!-- 配置Struts2的核心的过滤器 -->
    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <welcome-file-list>
        <welcome-file>/index.jsp</welcome-file>
    </welcome-file-list>
    <absolute-ordering></absolute-ordering>
</web-app>

项目配置

    在IDEA上方菜单栏选择File>>Project Structure

    在左侧Modules检查是否有Struts2、Spring、Hibernate的配置文件,没有就点“+”进行添加。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
    选中Web文件夹勾选右侧下方的Source Roots栏中的所有选项
在这里插入图片描述
    选择左侧的Artifact,右键Available Element的目录,点击Put into Output Root。
在这里插入图片描述
    到此就告一段落。

遇坑

在hibernate.cfg.xml中

原本配置的是

        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property>

但是在执行MYSQL的语句的时候后面会多添加一个type = MyISAM,MYSQL 5.x以上无法识别,默认的表模式是InnoDB,于是换成了MYSQL的方言驱动。

        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值