elementui_day02

Elementui_day02

1. maven多模块搭建

1.1 搭建多模块的好处

1. 方便维护(代码增加,拆分越细,越好维护)

2. 有些公共的内容(BaseDomain.BaseService...)除了这一个项目可以使用,其他项目也可以使用

3. 如果有些代码不希望任何人都可以修改,也可以把这些内容单独抽取出来,放到一个模块里面去

4. 如果不去拆分项目,所有业务的增加,代码越来越多,pom.xml越来越长,导致编译也变得越来越久

1.2 搭建多模块

elementui_day02

 

 

 

1.3 代码放的位置

basic_core: basedomain baseService baseMapper baseServiceImpl

basic_util: ajaxResult pageList

crm_comomon: department departmentQuery

crm_mapper: DepartmentMapper.java

crm_service:IDepartmentService DepartmentServiceImpl

crm_web: DepartmentController

1.4 引用关系

crm_web -->crm_service

crm_service-->crm_mapper

crm_mapper-->crm_common

crm_common-->basic_core

basic_core->basic_util

1.5 配置文件

web.xml -->crm_web

applicationContext-mvc.xml-->crm_web

applicationContext.xml -->crm_service

db.properties-->crm_service/crm_mapper

1.6 导入jar包关系

crm_parent: 公共的spring的包

crm_web: spring-web spring-webmvc

crm_service: 引用crm_mapper

crm_mapper: mybatis dbcp 等

1.7 写代码满足的要求

(1) 开闭原则:

对扩展开发

对修改关闭 -- 一些公共的内容

(2) 低耦合 高内聚

低耦合: 模块和模块直接,类和类之间 耦合度要低

高内聚: 指的类里面的方法,它应该达到高内聚的效率

save -->保存的使用 代码30-40行

2. restfull风格

2.1 使用restfull风格的好处

以前我们在发送的请求 常用 get/post, 但是现在发送请求,就要增加 delete/put/options

以前发送请求:

删除: get(post) /deleteProduct?id=1 (动作+资源在一起)

现在删除: --restfull的风格 好处:不会暴露资源

delete(动作) (/product/1 资源) -->动作+资源

前后端分离的项目:

采用restful的风格来交互,使用json来传递数据

2.2 restfull风格规范

put -- 新增 (修改)

post --修改(新增)

get --查询

delete --删除

patch --查询

head --头信息(不用)

3. Swagger用法

3.1 swagger有什么用

swagger:可以根据controller生成接口文档

3.2 使用swagger步骤

(1) 导入jar包

 

<!--swagger配置-->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>${springfox.version}</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>${springfox.version}</version>
        </dependency>

 

(2)写一个配置类

扫描controller 生成文档

 

@Configuration   //相当于写了spring配置 applicationContext.xml

@EnableWebMvc   //开启webmvc

@EnableSwagger2 //开启swagger

//扫描个包下面controller来生成接口描述

@ComponentScan(basePackages="cn.itsource.crm.web.controller")
public class SwaggerConfig {
    //<bean class=""></bean>
    @Bean
    public Docket api(){
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(this.apiInfo())
                .select()
                .apis(RequestHandlerSelectors.basePackage("cn.itsource.crm.web.controller"))
                .paths(PathSelectors.any())
                .build();
    }
    //描述信息
    private ApiInfo apiInfo(){
         @SuppressWarnings("deprecation")
        ApiInfo info=new ApiInfo(
                 "itsource20190924crud测试",
                 "一个完成crud",
                 "v1",
                 "http://www.itsource.cn",
                 "zytest",
                 "apache",
                 "http://www.itsource.cn");
         return info;
    }
}

 

(3)扫描的配置

 <context:component-scan base-package="cn.itsource.crm.web.config"/>

(4)启动测试

http://localhost/swagger-ui.html

4. Postman

4.1 postman是什么

就是一个工具,可以来发送各种http请求,可以用它来测试http协议接口.

  postman就是httm协议接口测试工具

5. vue-admin-master模块

导入后

npm install

npm run dev

上一篇:swagger在spring cloud中的单个集成


下一篇:电商项目实战——Swagger-UI实现在线api文档