搭建SSM项目框架全过程及思考

1.前言

 以前都是在现有框架下进行写代码或者老是看一些别人的架构,总会眼高手低。因而打算本身完整的走一遍流程,同时把所遇到的问题,思考的问题记下来,供你们参考。因为是工做年限不高,属于新手,不足之处还请各位大牛指正。css

 项目选用Spring为基础框架,因为目前项目中采用的是Hibernate(在多表关联查询方面以及复杂的统计计算方面,同时要兼顾性能的时候吃了很多苦头),因此这里采起Mybatis作持久化框架(没实战搭建过),Spring MVC框架。在权限控制方面现有项目中采用的是shiro(为了学习,这里使用spring security)。其余的细节问题会在下面各小节中叙述。html

 另说明一点的是操做系统是mac。前端

 github项目源码在https://github.com/sjlian/sjlian 欢迎clone并提出意见。java

2. 建立mvn项目、完善目录结构

  首先安装和配置环境,主要包括jdk、mysql、maven等,其余如redis、nginx、ActiveMQ等在初始版本还暂时没上传和使用。这些入门知识再也不赘述。mysql

  在idea上新建一个mvn项目,而后有一个create from archetype,里面有不少选项,因而有个疑问到底用哪一个呢?遂逐一查看名字,看到mvn-archetypr-webapp,听名字就以为和本身的预期是同样的啊,因而果断选择。期间又试了下其余的各个archetype,发现这这是一个模板,能够根据本身须要选择,也能够默认缺省的。这里附上mvn官方标准化的目录结构以下图:nginx

 一个好的程序员都善于用命令行的方式解决问题,因而思考怎么用mvn命令行建立项目。最简单的方式就是mvn archetype:generate,这个命令是默认的 archetype,若是须要生成特定模板的项目呢?从maven的Repository里查找arche types发现有几百个,咱们平时用的也就那么几个,因为太多就变得很不方便起来,因而搜索资料,查到 http://maven.40175.n5.nabble.com/archetype-catalog-xml-location-archetype-crawl-versus-archetype-generate-td113741.html git

  

  完善目录结构大体如上图(是demo最终版本),这个时候只须要在java目录下新建几个包,进行分层,使项目结构变得清晰。程序员

  common主要放置一些通用的非工具类,如exception相关,结果相关,拦截器,servlet,VO类等。github

  Controller、DAO、model、service顾名思义,分别是控制层、持久层、数据模型层、业务处理层。web

  util主要存放各类工具类,例如字符串、时间、poi、邮件、ip等

  resource主要是配置文件,包括spring相关配置文件、mybatis配置文件、mybatis映射文件、日志配置文件等

  web-inf下最重要是web.xml,做为启动须要首先加载的文件,引入其余配置文件、配置listener、servlet、filter、Interceptor等。

  其余是和前端相关文件

  test是和测试相关。

  建好以上目录,开始进入正题。

 3. 引入Spring

  3.1 web.xml

  web程序启动会去读取它的配置文件 web.xml,首先须要配置web.xml,添加上spring的监听器、spring mvc的Servlet。

  ContextLoaderListener 它实现了ServletContextListener这个接口,在web.xml配置这个监听器,启动容器时,就会默认执行它实现的方法。在ContextLoaderListener中关联了ContextLoader这个类,因此整个加载配置过程由ContextLoader来完成。

  RequestContextListener implements ServletRequestListener,监听用户的请求,用于日志系统,不是必需的。

  IntrospectorCleanupListener监听器主要用于解决java.beans.Introspector致使的内存泄漏的问题(Quartz,Struts),若是没有struts和quartz不是必需的。

  Spring MVC 以自启动servlet的形式加载,同时引入相关spring/spring-mvc.xml配置文件。文件路径classpath:开头,从classpath加载,不然尝试URL,若是失败,调用 getResourceByPath。

  此外,为了防止中文乱码,须要encodingFilter;设置session超时时间、用户自定义Listener、servlet、filter、interceptor等。

  3.2 pom.xml

  直接把Listener复制到xml中,会发现ide并不识别,是由于相关依赖尚未导入项目中的缘由。 在pom.xml中引入spring相关,引入的时候会发现depency有一些属性值,如groupId、artifactId等,对于开源项目来讲,这两项是固定的,按照文档导入便可,version是版本号,为了便于升级和管理,建议版本号统一配置。

 

 

  有时候会发现还有scope属性,如junit的scope属性值是test用于test任务时使用;compile(default)编译时使用;provided相似于编译但支持你期待jdk或者容器提供,相似于classpath;runtime在执行时须要使用;system须要外在提供相应得元素。经过systemPath来取得;

  有时候会遇到依赖冲突,例如同时导入了A、B包,可是A包又引用了B包,当版本不一致时就会冲突,解决方式是mvn dependency:tree 分析冲突的包,而后在相应的A包中配置<exclusions> 把B包排除在外。

  若是想引入本地依赖,一、使用scope system和systemPath指向依赖包;二、mvn install命令进行安装并配置group和artifact,而后直接引入。三、创建pom依赖关系。POM关系主要为依赖,继承,合成,在这个小项目中用不到,且不是重点,故略去。

  3.3 其余配置文件

  spring-mvc.xml主要配置以下。

  1.开启注解模式就可使用注解方式@ResponseBody,@RequestMapping等。

  2.对于静态的jpg、css等不须要经过mvc。

  3.添加先后缀,注意路径。  

  4.扫描controller的bean,让spring知道哪些是controller(@Controller)。

  

  若是须要对返回值进行json统一化处理,在这里能够引入json处理,如fastJson、jackson等。fastJson轻量级速度快,可是支持有轻微漏洞,jackson灵活性好,可是比较笨重,这里选用的是fastJson,配置以下。

  若是须要上传文件,还须要配置文件上传,以下:

 

   web.xml中引入配置文件,该配置文件做为spring基础配置文件,再引入其余文件。

  spring.xml中配置以下,这里注入service、引入mybatis、security配置,配置事务管理、开启声明是式事务(@transtraction)。

 4.引入Mybatis

  4.1 文件配置

  在spring.xml中引入了spring-mybatis.xml,用于Mybatis和spring的整合配置。同时pom.xml中引入相关依赖。

  1.配置数据源,数据库链接池,能够选择的有c3p0、druid、dbcp、HikariCP等,这里选择阿里的开源框架druid,配置以下。url、username等建议写在property文件中。

  

   2. 配置sessionFactory, 引入mybatis全局配置文件、entity使用别名,扫描mapping.xml

   3. 配置DAO接口,注入Srping容器中。

 

 4. 配置mybatis-config.xml

 5. mvc层搭建

  5.1 DAO层

    因为mybatis不支持jpa,不能由实体映射数据表,因此须要本身新建数据表和数据实体。

    可使用工具由数据表生成数据实体。

    数据实体在model目录下。

    映射文件在resources/mapper下,若是设置了自动转换对象关系名,这里不在须要配置对象关系的名称映射,可是须要注意命名的书写,注意namespace一致。

    DAO接口文件在dao目录下,DAO实如今mapper的xml中,select/update id和接口中的方法对应便可。在service注入dao的时候会提示没法注入的错误,忽略便可。

  5.2 service层

   在service下定义接口,在service/impl/下定义实现,加上@Service注解

  5.3 Controller层

   在Controller目录下,能够实现封装好的json数据、string链接、ModelAndView。

 6. DEMO完善

  5.1 加入日志系统

    log4j,配置log4j.properties。以下  

   而后能够利用filter作请求参很多天志输出。

   利用aop作一些其余日志输入。

  5.2 封装统一化返回值

  先后端json数据交互,自定义ResponseResult,包括头信息(状态码,错误信息说明,异常),数据信息。

  异常经过@ControllerAdvice 捕获到而后封装处理返回给前端,不至于页面报错,或者自定义异常弹窗。

  5.3 工具类准备

  各类工具类提取

  5.4 权限控制

  使用spring security,目前仍是半成品,之后完善。

  5.5 其余处理

 

 

 

相关文章
相关标签/搜索