当前位置:   article > 正文

创建Gradle多Model模块_gradle model

gradle model

这步加不加入仓库jar包的优先级 都可以

在GradelParent工程选择new model

此时新建完的工程 默认都是gradle Java工程 要改成web工程:

添加组件war

在main下面建立webapp 、webapp下面建立WEB-INF目录 、WEB-INF目录 下面添加web.xml文件、WEB-INF目录下面添加pages目录(这个可以自定义,看我们spring-mvc里面配置的是什么视图解析路径)、添加各种spring配置文件

把之前的gradel web工程里面的内容copy过来:

build.gradle(该文件 不必拷贝 在后面 会在父类的build.gradle文件中 引入jar包依赖 达到所有子模块公用的效果)

  1. plugins {
  2. id 'java'
  3. /**
  4. * 打成war包的形式
  5. */
  6. id 'war'
  7. }
  8. group 'com.lz.web'
  9. version '1.0-SNAPSHOT'
  10. sourceCompatibility = 1.8
  11. repositories {
  12. mavenLocal()
  13. mavenCentral()
  14. }
  15. /**
  16. * maven:provided
  17. * provided:在编译和测试的过程有效,最后生成war包时不会加入,诸如:servlet-api,
  18. * 因为servlet-api,tomcat等web服务器已经存在了,如果再打包会冲突
  19. * gradle:provided和compile的区别:
  20. * 如果你的jar包/依赖代码 仅在编译的时候需要,但是在运行时不需要依赖,就用providedCompile
  21. * 此属性 替代了maven中的provided
  22. */
  23. dependencies {
  24. testCompile group: 'junit', name: 'junit', version: '4.12'
  25. compile group: 'org.springframework', name: 'spring-context', version: '5.0.2.RELEASE'
  26. compile group: 'org.springframework', name: 'spring-web', version: '5.0.2.RELEASE'
  27. compile group: 'org.springframework', name: 'spring-webmvc', version: '5.0.2.RELEASE'
  28. compile group: 'org.springframework', name: 'spring-tx', version: '5.0.2.RELEASE'
  29. compileOnly group: 'javax.servlet', name: 'javax.servlet-api', version:'3.1.0'
  30. compileOnly ('javax.servlet:jsp-api:2.0'){
  31. exclude group: 'javax.servlet'
  32. }
  33. compile group: 'com.alibaba', name: 'fastjson', version: '1.2.54'
  34. compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.11.1'
  35. compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.11.1'
  36. compile group: 'org.apache.logging.log4j', name: 'log4j-web', version: '2.11.1'
  37. }

web.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns="http://java.sun.com/xml/ns/javaee"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  5. id="WebApp_ID" version="2.5">
  6. <display-name>chinaTelecomLogAnalyzer</display-name>
  7. <welcome-file-list>
  8. <welcome-file>index.html</welcome-file>
  9. <welcome-file>index.htm</welcome-file>
  10. <welcome-file>index.jsp</welcome-file>
  11. </welcome-file-list>
  12. <!-- spring配置文件路径 -->
  13. <context-param>
  14. <param-name>contextConfigLocation</param-name>
  15. <param-value>classpath:applicationContext.xml</param-value>
  16. </context-param>
  17. <!-- Spring监听器 -->
  18. <listener>
  19. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  20. </listener>
  21. <!-- log4j2配置 -->
  22. <context-param>
  23. <param-name>log4jConfiguration</param-name>
  24. <param-value>classpath:log4j2.xml</param-value>
  25. </context-param>
  26. <listener>
  27. <listener-class>org.apache.logging.log4j.web.Log4jServletContextListener
  28. </listener-class>
  29. </listener>
  30. <filter>
  31. <filter-name>log4jServletFilter</filter-name>
  32. <filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class>
  33. </filter>
  34. <filter-mapping>
  35. <filter-name>log4jServletFilter</filter-name>
  36. <url-pattern>/*</url-pattern>
  37. <dispatcher>REQUEST</dispatcher>
  38. <dispatcher>FORWARD</dispatcher>
  39. <dispatcher>INCLUDE</dispatcher>
  40. <dispatcher>ERROR</dispatcher>
  41. </filter-mapping>
  42. <!-- 添加SpringMvc -->
  43. <servlet>
  44. <servlet-name>manager</servlet-name>
  45. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  46. <init-param>
  47. <description>springmvc</description>
  48. <param-name>contextConfigLocation</param-name>
  49. <param-value>classpath:spring-mvc.xml</param-value>
  50. </init-param>
  51. <load-on-startup>1</load-on-startup>
  52. </servlet>
  53. <servlet-mapping>
  54. <servlet-name>manager</servlet-name>
  55. <url-pattern>/</url-pattern>
  56. </servlet-mapping>
  57. <!-- 乱码处理 -->
  58. <filter>
  59. <filter-name>characterEncodingFilter</filter-name>
  60. <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  61. <init-param>
  62. <param-name>encoding</param-name>
  63. <param-value>utf-8</param-value>
  64. </init-param>
  65. </filter>
  66. <filter-mapping>
  67. <filter-name>characterEncodingFilter</filter-name>
  68. <url-pattern>*</url-pattern>
  69. </filter-mapping>
  70. </web-app>

applicationContext.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:context="http://www.springframework.org/schema/context"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xmlns:aop="http://www.springframework.org/schema/aop"
  6. xmlns:tx="http://www.springframework.org/schema/tx"
  7. xsi:schemaLocation="
  8. http://www.springframework.org/schema/beans
  9. http://www.springframework.org/schema/beans/spring-beans.xsd
  10. http://www.springframework.org/schema/tx
  11. http://www.springframework.org/schema/tx/spring-tx.xsd
  12. http://www.springframework.org/schema/aop
  13. http://www.springframework.org/schema/aop/spring-aop.xsd
  14. http://www.springframework.org/schema/context
  15. http://www.springframework.org/schema/context/spring-context.xsd">
  16. <!-- 加载配置属性文件 -->
  17. <context:property-placeholder
  18. ignore-unresolvable="true" location="classpath:config.properties" />
  19. </beans>

log4j2.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <Configuration>
  3. <Appenders>
  4. <Console name="STDOUT" target="SYSTEM_OUT">
  5. <!-- 输出格式 -->
  6. <PatternLayout
  7. pattern="[%l] [%t] [%-4r] [%d{yyyy-MM-dd HH:mm:ss,SSS}] [%p] \: %m%n" />
  8. </Console>
  9. </Appenders>
  10. <Loggers>
  11. <!-- 配置记录器级别 -->
  12. <Root level="debug">
  13. <!-- 输出设置 -->
  14. <AppenderRef ref="STDOUT" />
  15. </Root>
  16. <!-- 将调用mybatis的dao的包填入此处即可 -->
  17. <logger name="com.levi.mappers">
  18. <level value="DEBUG" />
  19. <AppenderRef ref="STDOUT" />
  20. </logger>
  21. </Loggers>
  22. </Configuration>

config.properties:

#待添加配置

 

spring-mvc.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:p="http://www.springframework.org/schema/p"
  5. xmlns:context="http://www.springframework.org/schema/context"
  6. xmlns:mvc="http://www.springframework.org/schema/mvc"
  7. xsi:schemaLocation="
  8. http://www.springframework.org/schema/beans
  9. http://www.springframework.org/schema/beans/spring-beans.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc.xsd
  12. http://www.springframework.org/schema/context
  13. http://www.springframework.org/schema/context/spring-context.xsd">
  14. <!-- 使用注解的包,包括子集 -->
  15. <context:component-scan base-package="com.lz"/>
  16. <!-- 启动注解驱动,支持对象与json的转换。 -->
  17. <mvc:annotation-driven>
  18. <mvc:message-converters>
  19. <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"/>
  20. </mvc:message-converters>
  21. </mvc:annotation-driven>
  22. <!-- 视图解析器 -->
  23. <bean id="viewResolver"
  24. class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  25. <property name="prefix" value="/WEB-INF/pages/" />
  26. <property name="suffix" value=".jsp"></property>
  27. </bean>
  28. <!--释放静态资源-->
  29. <mvc:default-servlet-handler/>
  30. </beans>

hello.jsp:

  1. <%--
  2. Created by IntelliJ IDEA.
  3. User: Administrator
  4. Date: 2018/12/31
  5. Time: 22:34
  6. To change this template use File | Settings | File Templates.
  7. --%>
  8. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  9. <html>
  10. <head>
  11. <title>Title</title>
  12. </head>
  13. <body>
  14. hello jsp!
  15. </body>
  16. </html>

index.jsp:

  1. <%--
  2. Created by IntelliJ IDEA.
  3. User: Administrator
  4. Date: 2018/12/31
  5. Time: 22:39
  6. To change this template use File | Settings | File Templates.
  7. --%>
  8. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  9. <html>
  10. <head>
  11. <title>Title</title>
  12. </head>
  13. <body>
  14. <jsp:forward page="hello/toHelloJsp"/>
  15. </body>
  16. </html>

HelloController:

  1. package com.lz.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.web.bind.annotation.RequestMapping;
  4. @Controller
  5. @RequestMapping("/hello")
  6. public class HelloController {
  7. @RequestMapping("/toHelloJsp")
  8. public String toHelloJsp(){
  9. return "hello";
  10. }
  11. }

gradle-web model的目录结构:

接下来 再新建其他model模块(如gradle-service、gradle-dao、gradle-domain) 如果是web工程 接着如上将java gradle工程改造成web gradle工程 如果仅仅是java gradle工程 那么不用改造 

 

 建立完成后 工程结构如图:

此时位于父类工程GradleParent下面的settings.gradle文件 可以看到父子工程结构

此时在父类工程的build.gradle文件中 引入jar包依赖达到所有子模块 公用父类引入jar包的作用

首先需要将父类工程的build.gradle所有内容包裹在标签:subprojects{}中:

  1. /**所有子项目的通用配置
  2. * 插件 不支持这种写法:
  3. * plugins {
  4. * id 'java'
  5. * }
  6. */
  7. subprojects {
  8. apply plugin: 'java'
  9. group 'com.lz.gradle'
  10. version '1.0-SNAPSHOT'
  11. sourceCompatibility = 1.8
  12. repositories {
  13. mavenLocal()
  14. mavenCentral()
  15. }
  16. /**
  17. * maven:provided
  18. * provided:在编译和测试的过程有效,最后生成war包时不会加入,诸如:servlet-api,
  19. * 因为servlet-api,tomcat等web服务器已经存在了,如果再打包会冲突
  20. * gradle:provided和compile的区别:
  21. * 如果你的jar包/依赖代码 仅在编译的时候需要,但是在运行时不需要依赖,就用providedCompile
  22. * 此属性 替代了maven中的provided
  23. */
  24. dependencies {
  25. testCompile group: 'junit', name: 'junit', version: '4.12'
  26. compile group: 'org.springframework', name: 'spring-context', version: '5.0.2.RELEASE'
  27. compile group: 'org.springframework', name: 'spring-web', version: '5.0.2.RELEASE'
  28. compile group: 'org.springframework', name: 'spring-webmvc', version: '5.0.2.RELEASE'
  29. compile group: 'org.springframework', name: 'spring-tx', version: '5.0.2.RELEASE'
  30. compileOnly group: 'javax.servlet', name: 'javax.servlet-api', version:'3.1.0'
  31. compileOnly ('javax.servlet:jsp-api:2.0'){
  32. exclude group: 'javax.servlet'
  33. }
  34. compile group: 'com.alibaba', name: 'fastjson', version: '1.2.54'
  35. compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.11.1'
  36. compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.11.1'
  37. compile group: 'org.apache.logging.log4j', name: 'log4j-web', version: '2.11.1'
  38. }
  39. }

 把所有子模块中的build.gradle文件重复的元素都清空,所以只有gadle的web工程的build.gradle文件 会留下 其余的非web工程的build.gradel文件 将都是清空

gradle-web-->build.gradle文件:

  1. plugins {
  2. /**
  3. * 打成war包的形式
  4. */
  5. id 'war'
  6. }

gradle-dao-->build.gradle文件:

#清空了

gradle-service-->build.gradle文件:

#清空了

gradle-domain-->build.gradle文件:

#清空了

接下来 在各个子模块中的build.gradle文件 开始加入 model之间的引用关系,格式为:

  1. dependencies {
  2. compile project(":父类工程settings.gradle文件中模块名称")
  3. }

各个模块的引用链关系为:web->service->dao->domain

gradle-domain-->build.gradle文件:

#清空了

gradle-domain-->build.gradle文件:

  1. dependencies {
  2. compile project(":gradle-domain")
  3. }

gradle-service-->build.gradle文件:

  1. dependencies {
  2. compile project(":gradle-dao")
  3. }

gradle-web-->build.gradle文件:

  1. plugins {
  2. /**
  3. * 打成war包的形式
  4. */
  5. id 'war'
  6. }
  7. dependencies {
  8. compile project(":gradle-service")
  9. }

在各个模块 编写dao service

Hello
  1. package com.lz.pojo;
  2. public class Hello {
  3. private String msg;
  4. public String getMsg() {
  5. return msg;
  6. }
  7. public void setMsg(String msg) {
  8. this.msg = msg;
  9. }
  10. }

HelloDao: 

  1. package com.lz.dao;
  2. import com.lz.pojo.Hello;
  3. public interface HelloDao {
  4. public Hello getHello();
  5. }

HelloDaoImpl: 

  1. package com.lz.dao.impl;
  2. import com.lz.dao.HelloDao;
  3. import com.lz.pojo.Hello;
  4. import org.springframework.stereotype.Component;
  5. @Component("helloDao")
  6. public class HelloDaoImpl implements HelloDao {
  7. @Override
  8. public Hello getHello() {
  9. Hello hello = new Hello();
  10. hello.setMsg("hahhah");
  11. return hello;
  12. }
  13. }

HelloService: 

  1. package com.lz.service;
  2. import com.lz.pojo.Hello;
  3. public interface HelloService {
  4. public Hello getHello();
  5. }

HelloServiceImpl 

  1. package com.lz.service.impl;
  2. import com.lz.dao.HelloDao;
  3. import com.lz.pojo.Hello;
  4. import com.lz.service.HelloService;
  5. import org.springframework.stereotype.Service;
  6. import javax.annotation.Resource;
  7. @Service("helloService")
  8. public class HelloServiceImpl implements HelloService {
  9. @Resource
  10. private HelloDao helloDao;
  11. @Override
  12. public Hello getHello() {
  13. return helloDao.getHello();
  14. }
  15. }

HelloController改造: 

  1. package com.lz.controller;
  2. import com.lz.pojo.Hello;
  3. import com.lz.service.HelloService;
  4. import org.springframework.stereotype.Controller;
  5. import org.springframework.ui.Model;
  6. import org.springframework.web.bind.annotation.RequestMapping;
  7. import org.springframework.web.servlet.ModelAndView;
  8. import javax.annotation.Resource;
  9. @Controller
  10. @RequestMapping("/hello")
  11. public class HelloController {
  12. @Resource
  13. private HelloService helloService;
  14. @RequestMapping("/toHelloJsp")
  15. public String toHelloJsp(Model model){
  16. Hello hello = helloService.getHello();
  17. model.addAttribute("msg",hello);
  18. return "hello";
  19. }
  20. }

hello.jsp改造:

  1. <%--
  2. Created by IntelliJ IDEA.
  3. User: Administrator
  4. Date: 2018/12/31
  5. Time: 22:34
  6. To change this template use File | Settings | File Templates.
  7. --%>
  8. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  9. <html>
  10. <head>
  11. <title>Title</title>
  12. </head>
  13. <body>
  14. ----${msg.msg}
  15. </body>
  16. </html>

启动项目运行效果:

工程的整体效果如图:

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/307526
推荐阅读
相关标签
  

闽ICP备14008679号