久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

瀏覽:45日期:2023-03-22 08:22:17
導(dǎo)讀 Lombok:可以讓你的POJO代碼特別簡(jiǎn)潔,不止簡(jiǎn)單在BO/VO/DTO/DO等大量使用,還有設(shè)計(jì)模式,對(duì)象對(duì)比等 MybatisPlus:增加版Mybatis,基礎(chǔ)的數(shù)據(jù)庫(kù)CRUD、分頁(yè)等可以直接生成使用,避免了大量的重復(fù)低效代碼,還有數(shù)據(jù)庫(kù)自動(dòng)Java類,sql文件等等,比傳統(tǒng)的更賤簡(jiǎn)介易用 SwaggerUI:接口文檔自動(dòng)生成,對(duì)接前端和測(cè)試更加方便,基于業(yè)界的OpennApi規(guī)范,采用Swagger3.x版本。

技術(shù)棧

SpringBoot2.4+ MybatisPlus+Lombok+Swagger3.x+jdk8+IDEA

在線構(gòu)建項(xiàng)目

點(diǎn)我直達(dá)

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

什么是lombok

官網(wǎng)

點(diǎn)我直達(dá)

一個(gè)優(yōu)秀的Java代碼庫(kù),簡(jiǎn)化了Java的編碼,為Java代碼的精簡(jiǎn)提供了一種方式

添加依賴

<!--lombok--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.16</version> <!--scope=provided,說(shuō)明它是在編譯階段生效,不需要打入包中,Lombok在編譯期將帶Lombok注解的Java文件正確編譯為完整的Class文件--> <scope>provided</scope> </dependency>常見(jiàn)注解@Getter/@Setter# 作用類上,生成所有成員變量的getter/setter方法 作用于成員變量上,生成該成員變量的getter/setter方法 方法控制訪問(wèn)級(jí)別set和get注解加上@Getter(AccessLevel.PROTECTED) 編譯查看字節(jié)碼

mvn compile

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

package com.ybchen.shopmanager.model;import lombok.AccessLevel;import lombok.Getter;import lombok.Setter;/** * @Description: * @Author:chenyanbin * @Date:2021/3/2 下午9:43 * @Versiion:1.0 */@Getter@Setterpublic class User { //不想生成get方法 @Getter(AccessLevel.NONE) int id; //只會(huì)去生成get final String name = 'alex'; String phone; //靜態(tài)成員變量不會(huì)生成set/get方法 static final String pwd = '123';}

@NonNull

作用于方法上或者屬性,用于非空判斷,如果為空則拋異常

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@NoArgsContructor

生成無(wú)參構(gòu)造器

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@AllArgsConstructor

生成全參構(gòu)造器

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@RequiredArgsConstructor

指定參數(shù)的構(gòu)造函數(shù),有以下的特征的字段

final類型未被初始化的屬性,標(biāo)記了@NonNull的屬性 注意:@NoArgsConstructor不能添加

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@ToStringList或者其他集合調(diào)試不方便控制臺(tái)或者日志輸出對(duì)象,默認(rèn)打印的是內(nèi)存地址作用于類,覆蓋默認(rèn)的toString()方法

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

不包括某個(gè)字段

@ToString(exclude={'age'})

只輸出某個(gè)字段

@ToString(of={'name'})

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

為什么對(duì)象要重寫(xiě)hashcode和equal方法

HashCode方法

頂級(jí)類Object里面的方法,所有類都是繼承Object的,返回值Int類型 根據(jù)一定的hash規(guī)則(存儲(chǔ)地址,字段,或者長(zhǎng)度等),映射成一個(gè)數(shù)值,即散列值

Equals方法

頂級(jí)類Object里面的方法,所有類都是繼承Object的,返回值boolean類型 根據(jù)自定義的匹配規(guī)則,用于匹配兩個(gè)對(duì)象是否一樣,一般邏輯如下

1、判斷地址是否一樣2、非空判斷和class類型判斷3、強(qiáng)轉(zhuǎn)4、對(duì)象里面的字段一一匹配

解析

如果兩個(gè)對(duì)象相等,那么它們的hashCode()值一定相同。如果兩個(gè)對(duì)象hashCode()相等,它們并不一定相等。在散列表中hashCode()相等,即兩個(gè)鍵值的哈希值相等。然后哈希值相等,并不一定得出鍵值對(duì)相等,就出現(xiàn)所謂的哈希沖突場(chǎng)景,還需要equals方法判斷對(duì)象是否相等。

應(yīng)用場(chǎng)景

當(dāng)向集合中插入對(duì)象時(shí),如何判別在集合中是否已經(jīng)存在該對(duì)象,比如Set確保存儲(chǔ)對(duì)象的唯一值,并判斷是否同一個(gè)對(duì)象呢?

依據(jù)hashCode和equals進(jìn)行判斷所以Set存儲(chǔ)的對(duì)象必須重寫(xiě)這兩個(gè)方法,判斷兩個(gè)對(duì)象是否一樣首先判斷插入對(duì)象的hashCode值是否存在,hashCode值不存在則直接插入集合;值存在則還需要判斷equals方法判斷對(duì)象是否相等

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@EqualsAndHashCode

作用于類,覆蓋默認(rèn)的equals和hashCode,作用于全部屬性

不包含某個(gè)屬性

@EqualsAndHashCode(exclude={'id'})

只輸出某個(gè)屬性

@EqualsAndHashCode(of={'id'})

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@Data

作用于類上,是以下注解的集合

@ToString

@EqualsAndHashCode

@Getter

@Setter

@RequiredArgsConstructor

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@Builder場(chǎng)景:當(dāng)一個(gè)bean類重載了多個(gè)構(gòu)造方法時(shí),并且參數(shù)隨機(jī)使用時(shí),考慮使用構(gòu)造者模式

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

@Lof/@Slf4j作用于類上,生成日志變量,用于記錄日志

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

MybatisPlus介紹 官網(wǎng):點(diǎn)我直達(dá) 是一個(gè)mybatis的增強(qiáng)工具,在Mybatis的基礎(chǔ)上只做強(qiáng)增不做改變,為簡(jiǎn)化開(kāi)發(fā),提高效率

數(shù)據(jù)庫(kù)腳本

/* Navicat Premium Data Transfer Source Server : localhost Source Server Type : MySQL Source Server Version : 50728 Source Host : localhost:3306 Source Schema : shop Target Server Type : MySQL Target Server Version : 50728 File Encoding : 65001 Date: 04/03/2021 22:17:20*/SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for address-- ----------------------------DROP TABLE IF EXISTS `address`;CREATE TABLE `address` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `user_id` bigint(20) DEFAULT NULL COMMENT ’用戶id’, `default_status` int(1) DEFAULT NULL COMMENT ’是否默認(rèn)收貨地址:0->否;1->是’, `receive_name` varchar(64) DEFAULT NULL COMMENT ’收發(fā)貨人姓名’, `phone` varchar(64) DEFAULT NULL COMMENT ’收貨人電話’, `province` varchar(64) DEFAULT NULL COMMENT ’省/直轄市’, `city` varchar(64) DEFAULT NULL COMMENT ’市’, `region` varchar(64) DEFAULT NULL COMMENT ’區(qū)’, `detail_address` varchar(200) DEFAULT NULL COMMENT ’詳細(xì)地址’, `create_time` datetime DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=’電商-公司收發(fā)貨地址表’;-- ------------------------------ Records of address-- ----------------------------BEGIN;COMMIT;-- ------------------------------ Table structure for banner-- ----------------------------DROP TABLE IF EXISTS `banner`;CREATE TABLE `banner` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `img` varchar(524) DEFAULT NULL COMMENT ’圖片’, `url` varchar(524) DEFAULT NULL COMMENT ’跳轉(zhuǎn)地址’, `weight` int(11) DEFAULT NULL COMMENT ’權(quán)重’, `version` int(11) DEFAULT ’1’, `deleted` int(11) DEFAULT ’0’ COMMENT ’0是未刪除,1是已經(jīng)刪除’, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8mb4;-- ------------------------------ Records of banner-- ----------------------------BEGIN;INSERT INTO `banner` VALUES (1, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, ’https://www.cnblogs.com/chenyanbin/’, 1, 2, 1);INSERT INTO `banner` VALUES (2, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, ’https://www.cnblogs.com/chenyanbin/’, 3, 1, 0);INSERT INTO `banner` VALUES (3, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, ’https://www.cnblogs.com/chenyanbin/’, 2, 1, 0);INSERT INTO `banner` VALUES (7, ’werw’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);INSERT INTO `banner` VALUES (8, ’666666’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);INSERT INTO `banner` VALUES (9, ’sdfds’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);INSERT INTO `banner` VALUES (10, ’323232’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);INSERT INTO `banner` VALUES (11, ’532’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);INSERT INTO `banner` VALUES (12, ’6666’, ’https://images.cnblogs.com/cnblogs_com/chenyanbin/1560326/o_qianxun.jpg’, 2, 1, 0);COMMIT;-- ------------------------------ Table structure for coupon-- ----------------------------DROP TABLE IF EXISTS `coupon`;CREATE TABLE `coupon` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT ’id’, `category` varchar(11) DEFAULT NULL COMMENT ’優(yōu)惠卷類型[NEW_USER注冊(cè)贈(zèng)券,TASK任務(wù)卷,PROMOTION促銷(xiāo)??’, `publish` varchar(11) DEFAULT NULL COMMENT ’發(fā)布狀態(tài), PUBLISH發(fā)布,DRAFT草稿,OFFLINE下線’, `coupon_img` varchar(524) DEFAULT NULL COMMENT ’優(yōu)惠券圖片’, `coupon_title` varchar(128) DEFAULT NULL COMMENT ’優(yōu)惠券標(biāo)題’, `price` decimal(16,2) DEFAULT NULL COMMENT ’抵扣價(jià)格’, `user_limit` int(11) DEFAULT NULL COMMENT ’每人限制張數(shù)’, `start_time` datetime DEFAULT NULL COMMENT ’優(yōu)惠券開(kāi)始有效時(shí)間’, `end_time` datetime DEFAULT NULL COMMENT ’優(yōu)惠券失效時(shí)間’, `publish_count` int(11) DEFAULT NULL COMMENT ’優(yōu)惠券總量’, `stock` int(11) DEFAULT ’0’ COMMENT ’庫(kù)存’, `add_one` int(11) DEFAULT NULL COMMENT ’是否疊加0是不行,1是可以’, `create_time` datetime DEFAULT NULL, `condition_price` decimal(16,2) DEFAULT NULL COMMENT ’滿多少才可以使用’, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;-- ------------------------------ Records of coupon-- ----------------------------BEGIN;COMMIT;-- ------------------------------ Table structure for product-- ----------------------------DROP TABLE IF EXISTS `product`;CREATE TABLE `product` ( `id` bigint(11) unsigned NOT NULL AUTO_INCREMENT, `title` varchar(128) DEFAULT NULL COMMENT ’標(biāo)題’, `cover_img` varchar(128) DEFAULT NULL COMMENT ’封面圖’, `detail` varchar(256) DEFAULT ’’ COMMENT ’詳情’, `old_price` decimal(16,2) DEFAULT NULL COMMENT ’老價(jià)格’, `price` decimal(16,2) DEFAULT NULL COMMENT ’新價(jià)格’, `stock` int(11) DEFAULT NULL COMMENT ’庫(kù)存’, `create_time` datetime DEFAULT NULL COMMENT ’創(chuàng)建時(shí)間’, `lock_stock` int(11) DEFAULT ’0’ COMMENT ’鎖定庫(kù)存’, PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4;-- ------------------------------ Records of product-- ----------------------------BEGIN;COMMIT;-- ------------------------------ Table structure for product_order-- ----------------------------DROP TABLE IF EXISTS `product_order`;CREATE TABLE `product_order` ( `id` bigint(11) NOT NULL AUTO_INCREMENT, `out_trade_no` varchar(64) DEFAULT NULL COMMENT ’訂單唯一標(biāo)識(shí)’, `state` varchar(11) DEFAULT NULL COMMENT ’NEW 未支付訂單,PAY已經(jīng)支付訂單,CANCEL超時(shí)取消訂單’, `create_time` datetime DEFAULT NULL COMMENT ’訂單生成時(shí)間’, `total_fee` decimal(16,2) DEFAULT NULL COMMENT ’訂單總金額’, `pay_fee` decimal(16,2) DEFAULT NULL COMMENT ’訂單實(shí)際支付價(jià)格’, `pay_type` varchar(64) DEFAULT NULL COMMENT ’支付類型,微信-銀行-支付寶’, `nickname` varchar(64) DEFAULT NULL COMMENT ’昵稱’, `head_img` varchar(524) DEFAULT NULL COMMENT ’頭像’, `user_id` int(11) DEFAULT NULL COMMENT ’用戶id’, `del` int(5) DEFAULT ’0’ COMMENT ’0表示未刪除,1表示已經(jīng)刪除’, `update_time` datetime DEFAULT NULL COMMENT ’更新時(shí)間’, `order_type` varchar(32) DEFAULT NULL COMMENT ’訂單類型 DAILY普通單,PROMOTION促銷(xiāo)訂單’, `receiver_address` varchar(1024) DEFAULT NULL COMMENT ’收貨地址 json存儲(chǔ)’, PRIMARY KEY (`id`)) ENGINE=MyISAM DEFAULT CHARSET=utf8;-- ------------------------------ Records of product_order-- ----------------------------BEGIN;COMMIT;-- ------------------------------ Table structure for product_order_item-- ----------------------------DROP TABLE IF EXISTS `product_order_item`;CREATE TABLE `product_order_item` ( `id` bigint(11) unsigned NOT NULL AUTO_INCREMENT, `product_order_id` bigint(11) DEFAULT NULL COMMENT ’訂單號(hào)’, `out_trade_no` varchar(32) DEFAULT NULL, `product_id` bigint(11) DEFAULT NULL COMMENT ’產(chǎn)品id’, `product_name` varchar(128) DEFAULT NULL COMMENT ’商品名稱’, `product_img` varchar(524) DEFAULT NULL COMMENT ’商品圖片’, `buy_num` int(11) DEFAULT NULL COMMENT ’購(gòu)買(mǎi)數(shù)量’, `create_time` datetime DEFAULT NULL, `total_fee` decimal(16,2) DEFAULT NULL COMMENT ’購(gòu)物項(xiàng)商品總價(jià)格’, `pay_fee` decimal(16,0) DEFAULT NULL COMMENT ’購(gòu)物項(xiàng)商品支付總價(jià)格’, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;-- ------------------------------ Records of product_order_item-- ----------------------------BEGIN;COMMIT;-- ------------------------------ Table structure for user-- ----------------------------DROP TABLE IF EXISTS `user`;CREATE TABLE `user` ( `id` bigint(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(128) DEFAULT NULL COMMENT ’昵稱’, `pwd` varchar(124) DEFAULT NULL COMMENT ’密碼’, `head_img` varchar(524) DEFAULT NULL COMMENT ’頭像’, `slogan` varchar(524) DEFAULT NULL COMMENT ’用戶簽名’, `sex` tinyint(2) DEFAULT ’1’ COMMENT ’0表示女,1表示男’, `points` int(10) DEFAULT ’0’ COMMENT ’積分’, `create_time` datetime DEFAULT NULL, `mail` varchar(64) DEFAULT NULL COMMENT ’郵箱’, `secret` varchar(12) DEFAULT NULL COMMENT ’鹽,用于個(gè)人敏感信息處理’, PRIMARY KEY (`id`), UNIQUE KEY `mail_idx` (`mail`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- ------------------------------ Records of user-- ----------------------------BEGIN;COMMIT;SET FOREIGN_KEY_CHECKS = 1;

pom.xml

<!--mysql--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!--mybatis plus和spring boot整合--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency><?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 https://maven.apache.org/xsd/maven-4.0.0.xsd'> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.4.3</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.ybchen</groupId> <artifactId>shop-manager</artifactId> <version>0.0.1-SNAPSHOT</version> <name>shop-manager</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!--lombok--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.16</version> <!--scope=provided,說(shuō)明它是在編譯階段生效,不需要打入包中,Lombok在編譯期將帶Lombok注解的Java文件正確編譯為完整的Class文件--> <scope>provided</scope> </dependency> <!--mysql--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!--mybatis plus和spring boot整合--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <!-- 代碼庫(kù) --> <repositories> <repository> <id>maven-ali</id> <url>http://maven.aliyun.com/nexus/content/groups/public//</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>true</enabled> <updatePolicy>always</updatePolicy> <checksumPolicy>fail</checksumPolicy> </snapshots> </repository> </repositories> <pluginRepositories> <pluginRepository> <id>public</id> <name>aliyun nexus</name> <url>http://maven.aliyun.com/nexus/content/groups/public/</url> <releases> <enabled>true</enabled> </releases> <snapshots> <enabled>false</enabled> </snapshots> </pluginRepository> </pluginRepositories></project>

完整pom.xml配置文件

application.properties

# 端口號(hào)server.port=9999#===========數(shù)據(jù)庫(kù)相關(guān)=============spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.url=jdbc:mysql://127.0.0.1/shop?useUnicode=true&characterEncoding=utf-8&useSSL=falsespring.datasource.username=rootspring.datasource.password=root配置SpringBoot掃描路徑

啟動(dòng)類上添加:@MapperScan('Mapper全包路徑')

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot整合MybatisPlus

統(tǒng)一接口返回協(xié)議

package com.ybchen.shopmanager.utils;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import java.io.Serializable;@Data@AllArgsConstructor@NoArgsConstructorpublic class JsonData implements Serializable { /** * 狀態(tài)碼 0 表示成功,1 表示處理中,-1表示失敗 */ private Integer code; /** * 數(shù)據(jù) */ private Object data; /** * 描述信息 */ private String msg; /** * 成功,無(wú)傳入數(shù)據(jù) * * @return */ public static JsonData buildSuccess() { return new JsonData(0, null, null); } /** * 成功,有傳入數(shù)據(jù) * * @param data 數(shù)據(jù) * @return */ public static JsonData buildSuccess(Object data) { return new JsonData(0, data, null); } /** * 失敗,有返回錯(cuò)誤信息 * * @param msg 描述信息 * @return */ public static JsonData buildError(String msg) { return new JsonData(-1, null, msg); } /** * 失敗,有狀態(tài)碼,描述信息 * * @param code 狀態(tài)碼 * @param msg 描述信息 * @return */ public static JsonData buildError(Integer code, String msg) { return new JsonData(code, null, msg); } /** * 是否返回成功 * @param jsonData * @return */ public static boolean isSuccess(JsonData jsonData) { return jsonData.getCode() == 0; }}

實(shí)體類

package com.ybchen.shopmanager.model;import com.baomidou.mybatisplus.annotation.TableName;import lombok.Data;/** * @Description:輪播圖 * @Author:chenyanbin * @Date:2021/3/4 下午11:00 * @Versiion:1.0 */@Data//數(shù)據(jù)庫(kù)表名@TableName('banner')public class BannerDO { /** * 主鍵 */ private Integer id; /** * 圖片 */ private String img; /** * url跳轉(zhuǎn)地址 */ private String url; /** * 權(quán)重 */ private Integer weight; /** * 版本號(hào) */ private Integer version; /** * 0是未刪除,1是已經(jīng)刪除 */ private Integer deleted;}

service

package com.ybchen.shopmanager.service;import com.ybchen.shopmanager.model.BannerDO;import java.util.List;public interface BannerService { List<BannerDO> list();}package com.ybchen.shopmanager.service.impl;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;import com.ybchen.shopmanager.mapper.BannerMapper;import com.ybchen.shopmanager.model.BannerDO;import com.ybchen.shopmanager.service.BannerService;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;/** * @Description:輪播圖Service * @Author:chenyanbin * @Date:2021/3/4 下午11:04 * @Versiion:1.0 */@Servicepublic class BannerServiceImpl implements BannerService { @Autowired private BannerMapper bannerMapper; @Override public List<BannerDO> list() { return bannerMapper.selectList(new QueryWrapper<>()); }}

Controller

package com.ybchen.shopmanager.controller;import com.ybchen.shopmanager.service.BannerService;import com.ybchen.shopmanager.utils.JsonData;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;/** * @Description:輪播圖Controller * @Author:chenyanbin * @Date:2021/3/4 下午11:06 * @Versiion:1.0 */@RestController@RequestMapping('api/v1/banner')public class BannerController { @Autowired private BannerService bannerService; @GetMapping('list') public JsonData list(){ return JsonData.buildSuccess(bannerService.list()); }}

測(cè)試

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

單元測(cè)試+控制臺(tái)打印sql

單元測(cè)試

package com.ybchen.shopmanager;import com.ybchen.shopmanager.model.BannerDO;import com.ybchen.shopmanager.service.BannerService;import lombok.extern.slf4j.Slf4j;import org.junit.jupiter.api.Test;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import java.util.List;//classes=啟動(dòng)類.class@SpringBootTest(classes = ShopManagerApplication.class)@Slf4jpublic class BannerTest { @Autowired private BannerService bannerService; @Test public void testBannerTest() { List<BannerDO> list = bannerService.list(); log.info('輪播圖列表:{}', list); }}

配置文件

application.properties

# 配置mybatis plus打印sql日志mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

測(cè)試

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

BaseMapperMapper

繼承該接口后,無(wú)需編寫(xiě)mapper.xml文件,即可獲得CRUD功能

/* * Copyright (c) 2011-2020, baomidou (jobob@qq.com). * <p> * Licensed under the Apache License, Version 2.0 (the 'License'); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * <p> * https://www.apache.org/licenses/LICENSE-2.0 * <p> * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an 'AS IS' BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */package com.baomidou.mybatisplus.core.mapper;import com.baomidou.mybatisplus.core.conditions.Wrapper;import com.baomidou.mybatisplus.core.metadata.IPage;import com.baomidou.mybatisplus.core.toolkit.Constants;import org.apache.ibatis.annotations.Param;import java.io.Serializable;import java.util.Collection;import java.util.List;import java.util.Map;/* :` .:, :::,,. :: `:::::: ::` `,:,` .:` `:: `::::::::.:` `:’;,` ::::, .:::` `@++++++++: `` :::` @+++++++++++# :::, #++++++++++++++` ,: `::::::;’##++++++++++ .@#@;` ::::::::::::::::::::; #@####@, :::::::::::::::+#;::. @@######+@:::::::::::::. #@:; , @@########’:::::::::::: .#’’’:` ;##@@@+:##########@::::::::::: @#;.,:. #@@@######++++#####’::::::::: .##+,:#` @@@@@#####+++++’#####+::::::::` ,`::@#:` `@@@@#####++++++’#####+#’:::::::::::@. @@@@######+++++’’#######+##’;::::;’:,` @@@@#####+++++’’’#######++++++++++` #@@#####++++++’’########++++++++’ `#@######+++++’’+########+++++++; `@@#####+++++’’##########++++++, @@######+++++’##########+++++#` @@@@#####+++++############++++; ;#@@@@@####++++##############+++, @@@@@@@@@@@###@###############++’ @#@@@@@@@@@@@@###################+: `@#@@@@@@@@@@@@@@###################’` :@#@@@@@@@@@@@@@@@@@##################, ,@@@@@@@@@@@@@@@@@@@@################; ,#@@@@@@@@@@@@@@@@@@@##############+` .#@@@@@@@@@@@@@@@@@@#############@, @@@@@@@@@@@@@@@@@@@###########@, :#@@@@@@@@@@@@@@@@##########@, `##@@@@@@@@@@@@@@@########+, `+@@@@@@@@@@@@@@@#####@:` `:@@@@@@@@@@@@@@##@;. `,’@@@@##@@@+;,` ``...`` _ _ /_ _ _/_. ____ / _/ / //_//_//_|/ /_ /_///_/_ Talk is cheap. Show me the code. _/ / *//** * Mapper 繼承該接口后,無(wú)需編寫(xiě) mapper.xml 文件,即可獲得CRUD功能 * <p>這個(gè) Mapper 支持 id 泛型</p> * * @author hubin * @since 2016-01-23 */public interface BaseMapper<T> extends Mapper<T> { /** * 插入一條記錄 * * @param entity 實(shí)體對(duì)象 */ int insert(T entity); /** * 根據(jù) ID 刪除 * * @param id 主鍵ID */ int deleteById(Serializable id); /** * 根據(jù) columnMap 條件,刪除記錄 * * @param columnMap 表字段 map 對(duì)象 */ int deleteByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap); /** * 根據(jù) entity 條件,刪除記錄 * * @param wrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ int delete(@Param(Constants.WRAPPER) Wrapper<T> wrapper); /** * 刪除(根據(jù)ID 批量刪除) * * @param idList 主鍵ID列表(不能為 null 以及 empty) */ int deleteBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList); /** * 根據(jù) ID 修改 * * @param entity 實(shí)體對(duì)象 */ int updateById(@Param(Constants.ENTITY) T entity); /** * 根據(jù) whereEntity 條件,更新記錄 * * @param entity 實(shí)體對(duì)象 (set 條件值,可以為 null) * @param updateWrapper 實(shí)體對(duì)象封裝操作類(可以為 null,里面的 entity 用于生成 where 語(yǔ)句) */ int update(@Param(Constants.ENTITY) T entity, @Param(Constants.WRAPPER) Wrapper<T> updateWrapper); /** * 根據(jù) ID 查詢 * * @param id 主鍵ID */ T selectById(Serializable id); /** * 查詢(根據(jù)ID 批量查詢) * * @param idList 主鍵ID列表(不能為 null 以及 empty) */ List<T> selectBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList); /** * 查詢(根據(jù) columnMap 條件) * * @param columnMap 表字段 map 對(duì)象 */ List<T> selectByMap(@Param(Constants.COLUMN_MAP) Map<String, Object> columnMap); /** * 根據(jù) entity 條件,查詢一條記錄 * * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ T selectOne(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) Wrapper 條件,查詢總記錄數(shù) * * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ Integer selectCount(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) entity 條件,查詢?nèi)坑涗?* * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ List<T> selectList(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) Wrapper 條件,查詢?nèi)坑涗?* * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ List<Map<String, Object>> selectMaps(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) Wrapper 條件,查詢?nèi)坑涗?* <p>注意: 只返回第一個(gè)字段的值</p> * * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ List<Object> selectObjs(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) entity 條件,查詢?nèi)坑涗洠ú⒎?yè)) * * @param page 分頁(yè)查詢條件(可以為 RowBounds.DEFAULT) * @param queryWrapper 實(shí)體對(duì)象封裝操作類(可以為 null) */ <E extends IPage<T>> E selectPage(E page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper); /** * 根據(jù) Wrapper 條件,查詢?nèi)坑涗洠ú⒎?yè)) * * @param page 分頁(yè)查詢條件 * @param queryWrapper 實(shí)體對(duì)象封裝操作類 */ <E extends IPage<Map<String, Object>>> E selectMapsPage(E page, @Param(Constants.WRAPPER) Wrapper<T> queryWrapper);} Mybatis plus常用注解# @TableName:用于定義表名 @TableId:用于定義表的主鍵

value:用于定義主鍵字段名type:用于定義主鍵類型(主鍵策略 IdType)IdType.AUTO:主鍵自增,系統(tǒng)分配,不需要手動(dòng)輸入IdType.NODE:未設(shè)置主鍵IdType.INPUT:需要自己輸入主鍵值IdType.ASSIGN_ID:系統(tǒng)分配ID,用于數(shù)值型數(shù)據(jù)(Long,對(duì)應(yīng)mysql中的BIGINT類型)IdType.ASSIGN_UUID:系統(tǒng)分配uuid,用于字符串型數(shù)據(jù)TableField:用于定義表的非主鍵字段value:用于定義非主鍵字段名,用于別名匹配,假如java對(duì)象和數(shù)據(jù)庫(kù)屬性不一樣exist:用于指明是否為數(shù)據(jù)表的字段,true表示是,false為不是fill:用于指定字段填充策略,一般用于填充:創(chuàng)建時(shí)間、修改時(shí)間等字段FieldFill.DEFAULT:默認(rèn)不填充FieldFill.INSERT:插入時(shí)填充FieldFill.UPDATE:更新時(shí)填充FieldFill.INSERT_UPDATE:插入、更新時(shí)填充QueryWrapper/LambdaQueryWrapper#可以封裝sql對(duì)象,包括where條件,order by排序

eq:等于ne:不等于gt:大于ge:大于等于lt:小于le:小于等于or:拼接orbetween:兩個(gè)值中間notBetween:不在兩個(gè)值中間like:模糊匹配notLike:不像likeLeft:左匹配likeRight:右邊匹配isNull:字段為空in:in查詢groupBy:分組orderByAsc:升序orderByDesc:降序having:having查詢分頁(yè)插件#配置類#

package com.ybchen.shopmanager.config;import com.baomidou.mybatisplus.annotation.DbType;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;/** * @Description:分頁(yè)插件配置 * @Author:chenyanbin * @Date:2021/3/5 下午10:32 * @Versiion:1.0 */@Configurationpublic class MybatisPlusPageConfig { /** * 舊版本 */// @Bean// public PaginationInterceptor paginationInterceptor() {// PaginationInterceptor paginationInterceptor = new PaginationInterceptor();// return paginationInterceptor;// } /** * 新的分頁(yè)插件,一級(jí)和二級(jí)緩存遵循mybatis的規(guī)則 * 需要設(shè)置 MybatisConfiguration#useDeprecatedExecutor=false 避免緩存出現(xiàn)問(wèn)題 */ @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor(); mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return mybatisPlusInterceptor; }}

演示類

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

自定義xml的sql腳本

新建xml

<?xml version='1.0' encoding='UTF-8'?><!DOCTYPE mapper PUBLIC '-//mybatis.org//DTD Mapper 3.0//EN' 'http://mybatis.org/dtd/mybatis-3-mapper.dtd'><!--這個(gè)名稱空間是Mapper接口的路徑--><mapper namespace='com.ybchen.shopmanager.mapper.BannerMapper'> <select resultType='com.ybchen.shopmanager.model.BannerDO'> select * from banner </select></mapper>

BannerMapper.java添加方法

package com.ybchen.shopmanager.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;import com.ybchen.shopmanager.model.BannerDO;import java.util.List;/** * @Description:輪播圖Mapper * @Author:chenyanbin * @Date:2021/3/4 下午11:03 * @Versiion:1.0 */public interface BannerMapper extends BaseMapper<BannerDO> { List<BannerDO> getList();}

配置文件告訴mapper.xml路徑

application.properties

# 默認(rèn)配置路徑mybatis-plus.mapper-locations=classpath*:/mapper/*Mapper.xml

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

全局配置文件

注意config-location和configuration不能同時(shí)出現(xiàn)

修改配置文件

application.properties

#配置全局配置文件!!!!mybatis-plus.config-location = classpath:mybatis-config.xml

新建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> <!--控制臺(tái)輸出日志--> <setting name='logImpl' value='STDOUT_LOGGING'/> </settings></configuration>

測(cè)試

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

配置實(shí)體類別名

修改application.properties

# 配置實(shí)體類別名mybatis-plus.type-aliases-package=com.ybchen.shopmanager.model

測(cè)試

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

mybatis plus下劃線轉(zhuǎn)駝峰

默認(rèn)就是true

修改application.properties

# mybatis plus下劃線轉(zhuǎn)駝峰mybatis-plus.configuration.map-underscore-to-camel-case=true

配置全局默認(rèn)主鍵類型

實(shí)體類上就不用加 @TableId(value='id',type=IdType.AUTO)

修改application.properties

# 配置全局默認(rèn)主鍵規(guī)則mybatis-plus.global-config.db-config.id-type=auto

完整application.properties

# 端口號(hào)server.port=9999#===========數(shù)據(jù)庫(kù)相關(guān)=============spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.url=jdbc:mysql://127.0.0.1/shop?useUnicode=true&characterEncoding=utf-8&useSSL=falsespring.datasource.username=rootspring.datasource.password=root# 配置mybatis plus打印sql日志#mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl# 默認(rèn)配置路徑mybatis-plus.mapper-locations=classpath*:/mapper/*Mapper.xml#配置全局配置文件!!!!mybatis-plus.config-location = classpath:mybatis-config.xml# 配置實(shí)體類別名mybatis-plus.type-aliases-package=com.ybchen.shopmanager.model# mybatis plus下劃線轉(zhuǎn)駝峰mybatis-plus.configuration.map-underscore-to-camel-case=true# 配置全局默認(rèn)主鍵規(guī)則mybatis-plus.global-config.db-config.id-type=auto

樂(lè)觀鎖

大多是基于數(shù)據(jù)版本(Version)記錄機(jī)制實(shí)現(xiàn)。即為數(shù)據(jù)增加一個(gè)版本標(biāo)識(shí),在基于數(shù)據(jù)庫(kù)表的版本解決方案中,一般通過(guò)為數(shù)據(jù)庫(kù)表增加一個(gè)“version”字段來(lái)實(shí)現(xiàn)。讀取數(shù)據(jù)時(shí),將此版本號(hào)一同讀出,之后更新時(shí),對(duì)此版本號(hào)加一。此時(shí),將提交數(shù)據(jù)的版本數(shù)據(jù)與數(shù)據(jù),庫(kù)表對(duì)應(yīng)記錄的當(dāng)前版本信息進(jìn)行比較,如果提交的數(shù)據(jù),版本號(hào)大于數(shù)據(jù)庫(kù)表當(dāng)前的版本號(hào),則予以更新,否則認(rèn)為是過(guò)期數(shù)據(jù)。

實(shí)體類增加@version

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

增加樂(lè)觀鎖插件

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

package com.ybchen.shopmanager.config;import com.baomidou.mybatisplus.annotation.DbType;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;/** * @Description:分頁(yè)插件配置 * @Author:chenyanbin * @Date:2021/3/5 下午10:32 * @Versiion:1.0 */@Configurationpublic class MybatisPlusPageConfig { /** * 舊版本 */// @Bean// public PaginationInterceptor paginationInterceptor() {// PaginationInterceptor paginationInterceptor = new PaginationInterceptor();// return paginationInterceptor;// } /** * 新的分頁(yè)插件,一級(jí)和二級(jí)緩存遵循mybatis的規(guī)則 * 需要設(shè)置 MybatisConfiguration#useDeprecatedExecutor=false 避免緩存出現(xiàn)問(wèn)題 */ @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor(); //分頁(yè)插件 mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); //樂(lè)觀鎖插件 mybatisPlusInterceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); return mybatisPlusInterceptor; }}

使用

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

注意 樂(lè)觀鎖數(shù)據(jù)類型支持int、Integer、long、timestamp 僅支持updateById和update方法邏輯刪除

公司在設(shè)計(jì)規(guī)范中都加入了邏輯刪除的強(qiáng)制規(guī)定,運(yùn)營(yíng)人員可以分析和審查數(shù)據(jù),也方便將數(shù)據(jù)沉淀下來(lái)用于商業(yè)分析。

數(shù)據(jù)量過(guò)多,也會(huì)采用數(shù)據(jù)倉(cāng)庫(kù),通過(guò)監(jiān)聽(tīng)?wèi)?yīng)用數(shù)據(jù)庫(kù)的數(shù)據(jù)變化,進(jìn)行遷移到數(shù)據(jù)倉(cāng)庫(kù)。

方式一 數(shù)據(jù)庫(kù)增加deleted字段,0是未刪除,1表示刪除 實(shí)體類增加屬性配置@TableLogic 查詢的時(shí)候會(huì)自動(dòng)拼接上deleted=0的檢索條件

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

方式二

修改application.properties

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

# 邏輯刪除,刪除是1mybatis-plus.global-config.db-config.logic-delete-value=1# 邏輯刪除,未刪除是0mybatis-plus.global-config.db-config.logic-not-delete-value=0# 如果java實(shí)體類沒(méi)加注解@TableLogic,則可以配置這個(gè),推薦這里配置mybatis-plus.global-config.db-config.logic-delete-field=deleted

代碼生成器#添加依賴#

<!-- 代碼自動(dòng)生成依賴 begin --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-generator</artifactId> <version>3.4.1</version> </dependency> <!-- velocity --> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> <version>2.0</version> </dependency> <!-- 代碼自動(dòng)生成依賴 end-->

生成器類#

package com.ybchen.shopmanager;import com.baomidou.mybatisplus.annotation.DbType;import com.baomidou.mybatisplus.annotation.IdType;import com.baomidou.mybatisplus.generator.AutoGenerator;import com.baomidou.mybatisplus.generator.config.DataSourceConfig;import com.baomidou.mybatisplus.generator.config.GlobalConfig;import com.baomidou.mybatisplus.generator.config.PackageConfig;import com.baomidou.mybatisplus.generator.config.StrategyConfig;import com.baomidou.mybatisplus.generator.config.rules.DateType;import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;/** * @Description:代碼生成器 * @Author:chenyanbin * @Date:2021/3/6 下午5:10 * @Versiion:1.0 */public class MyBatisPlusGenerator { public static void main(String[] args) { //1. 全局配置 GlobalConfig config = new GlobalConfig(); // 是否支持AR模式 config.setActiveRecord(true) // 作者 .setAuthor('chenyanbin') // 生成路徑,最好使用絕對(duì)路徑,window路徑是不一樣的 .setOutputDir('/Users/chenyanbin/IdeaProjects/shop-manager') // 文件覆蓋 .setFileOverride(true) // 主鍵策略 .setIdType(IdType.AUTO) .setDateType(DateType.ONLY_DATE) // 設(shè)置生成的service接口的名字的首字母是否為I,默認(rèn)Service是以I開(kāi)頭的 .setServiceName('%sService') //實(shí)體類結(jié)尾名稱 .setEntityName('%sDO') //生成基本的resultMap .setBaseResultMap(true) //不使用AR模式 .setActiveRecord(false) //生成基本的SQL片段 .setBaseColumnList(true); //2. 數(shù)據(jù)源配置 DataSourceConfig dsConfig = new DataSourceConfig(); // 設(shè)置數(shù)據(jù)庫(kù)類型 dsConfig.setDbType(DbType.MYSQL) .setDriverName('com.mysql.cj.jdbc.Driver') .setUrl('jdbc:mysql://127.0.0.1:3306/shop?useSSL=false') .setUsername('root') .setPassword('root'); //3. 策略配置globalConfiguration中 StrategyConfig stConfig = new StrategyConfig(); //全局大寫(xiě)命名 stConfig.setCapitalMode(true) // 數(shù)據(jù)庫(kù)表映射到實(shí)體的命名策略 .setNaming(NamingStrategy.underline_to_camel) //使用lombok .setEntityLombokModel(true) //使用restcontroller注解 .setRestControllerStyle(true) // 生成的表, 支持多表一起生成,以數(shù)組形式填寫(xiě) .setInclude('product','banner','address','coupon','product_order'); //4. 包名策略配置 PackageConfig pkConfig = new PackageConfig(); pkConfig.setParent('net.mybatisplus') .setMapper('mapper') .setService('service') .setController('controller') .setEntity('model') .setXml('mapper'); //5. 整合配置 AutoGenerator ag = new AutoGenerator(); ag.setGlobalConfig(config) .setDataSource(dsConfig) .setStrategy(stConfig) .setPackageInfo(pkConfig); //6. 執(zhí)行操作 ag.execute(); System.out.println('======= 代碼生成完畢 ========'); }}

使用#

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

SpringBoot整合Swagger 3.x添加依賴

<!--springBoot整合swagger3.0--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency>

修改application.properties

添加如下信息

spring.application.name=shop-manager# ===== 自定義swagger配置 ===== #swagger.enable=trueswagger.application-name= ${spring.application.name}swagger.application-version=1.0swagger.application-description=shop api

配置類

package com.ybchen.shopmanager.config;import io.swagger.annotations.ApiOperation;import lombok.Data;import org.springframework.boot.context.properties.ConfigurationProperties;import org.springframework.context.annotation.Bean;import org.springframework.stereotype.Component;import springfox.documentation.builders.ApiInfoBuilder;import springfox.documentation.builders.PathSelectors;import springfox.documentation.builders.RequestHandlerSelectors;import springfox.documentation.oas.annotations.EnableOpenApi;import springfox.documentation.service.ApiInfo;import springfox.documentation.service.Contact;import springfox.documentation.spi.DocumentationType;import springfox.documentation.spring.web.plugins.Docket;/** * @Description:swagger配置類 * @Author:chenyanbin * @Date:2021/3/5 下午10:32 * @Versiion:1.0 */@Component@Data@ConfigurationProperties('swagger')@EnableOpenApipublic class SwaggerConfiguration { /** * 是否開(kāi)啟swagger,生產(chǎn)環(huán)境一般關(guān)閉,所以這里定義一個(gè)變量 */ private Boolean enable; /** * 項(xiàng)目應(yīng)用名 */ private String applicationName; /** * 項(xiàng)目版本信息 */ private String applicationVersion; /** * 項(xiàng)目描述信息 */ private String applicationDescription; @Bean public Docket docket(){ return new Docket(DocumentationType.OAS_30) .pathMapping('/') // 定義是否開(kāi)啟swagger,false為關(guān)閉,可以通過(guò)變量控制,線上關(guān)閉 .enable(enable) //配置api文檔元信息 .apiInfo(apiInfo()) // 選擇哪些接口作為swagger的doc發(fā)布 .select() //apis() 控制哪些接口暴露給swagger, // RequestHandlerSelectors.any() 所有都暴露 // RequestHandlerSelectors.basePackage('net.ybchen.*') 指定包位置 // withMethodAnnotation(ApiOperation.class)標(biāo)記有這個(gè)注解 ApiOperation .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class)) .paths(PathSelectors.any()) .build(); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title(applicationName) .description(applicationDescription) .contact(new Contact('陳彥斌', 'https://www.cnblogs.com/chenyanbin/', '543210188@qq.com')) .version(applicationVersion) .build(); }}

啟動(dòng)測(cè)試

訪問(wèn)地址:http://localhost:9999/swagger-ui/index.html

注意:如果訪問(wèn)不成功,看是否攔截器攔截了相關(guān)資源!!!!!

SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI

常用注解

@Api

用在controller類,描述API接口

@Api(tags = '用戶模塊',value = '用戶UserController') public class UserController { }

@ApiOperation#

接口配置,用在方法上,描述接口方法

@ApiOperation('分頁(yè)用戶列表') @GetMapping('list') public JsonData list(){​ return JsonData.buildSuccess(); }

@ApiParam#

方法參數(shù)配置,用在入?yún)⑸厦妫枋鰠?shù)

@ApiOperation('用戶登錄') @PostMapping('login') public JsonData login( @ApiParam(name = 'phone', value = '手機(jī)號(hào)',example = '13888888888') @RequestParam('phone') String phone,​ @ApiParam(name = 'pwd', value = '密碼',example = '123456') @RequestParam('pwd')String pwd){​ return JsonData.buildSuccess(); }

@Apilgnore#忽略此接口不生成文檔

@ApiIgnore @ApiOperation('刪除用戶') @DeleteMapping('/delete/{id}') public JsonData deleteById(@PathVariable int id) { return JsonData.buildSuccess(); }

@ApiModel#用于類,表示對(duì)類進(jìn)行說(shuō)明,用于參數(shù),用實(shí)體類接收@ApiModelProperty#用于方法,字段;表示對(duì)model屬性的說(shuō)明或者數(shù)據(jù)操作更改value:字段說(shuō)明name:重寫(xiě)屬性名稱dataType:重寫(xiě)屬性類型required:是否必填example:舉例說(shuō)明hidden:隱藏@Data@ApiModel('用戶基本信息')

public class SaveUserRequest {​ private int age;​ private String pwd;​ @ApiModelProperty(value ='【必填】郵箱',required = true) private String email;​ @ApiModelProperty('【必填】手機(jī)號(hào)') private String phone;​ @ApiModelProperty(value='創(chuàng)建時(shí)間') private Date createTime;​}

@ApiResponse#描述接口響應(yīng)

@ApiOperation('用戶登錄') @PostMapping('login') @ApiResponses({ @ApiResponse(responseCode = CodeStatus.SUCCESS, description = '保存成功'), @ApiResponse(responseCode = CodeStatus.FAIL, description = '保存失敗') }) public JsonData login( @ApiParam(name = 'phone', value = '手機(jī)號(hào)',example = '13888888888') @RequestParam('phone') String phone,​ @ApiParam(name = 'pwd', value = '密碼',example = '123456') @RequestParam('pwd')String pwd){​ return JsonData.buildSuccess(); }

項(xiàng)目源碼下載

鏈接: https://pan.baidu.com/s/1OaOG0xK6jl8zDweAMkggAQ 提取碼: ed54

到此這篇關(guān)于SpringBoot 開(kāi)發(fā)提速神器 Lombok+MybatisPlus+SwaggerUI的文章就介紹到這了,更多相關(guān)SpringBoot Lombok+MybatisPlus+SwaggerUI內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 精品美女在线观看视频在线观看 | 99精品视频免费在线观看 | 九九久久影视 | 操操日 | 成人一区视频 | 欧美亚洲国产一区二区三区 | 婷婷久久综合 | 在线免费观看av片 | 精品九九九 | 亚洲高清精品视频 | 欧美一级特黄aaaaaaa色戒 | 精品久久久久国产免费 | 国产视频观看 | 中文字幕66页 | 国产精品久久久久久久久久妇女 | 国产一区二区视频在线观看 | 国内成人免费视频 | 国产高清免费视频 | 亚洲日本中文 | 丝袜 亚洲 另类 欧美 综合 | 久久久一区二区三区 | 欧美日韩亚洲综合 | 在线日韩欧美 | 成年人视频在线观看免费 | 天天干天操 | 97视频在线 | 真人一级毛片 | 欧美久久久久久久久久伊人 | 精品视频一区二区三区 | 免费国产网站 | 福利视频二区 | 色综合天天综合网国产成人网 | 成人在线观看免费视频 | 国产精品污www在线观看 | 精品国产一区二区三区高潮视 | 日韩精品中文字幕在线播放 | 亚洲精品在线免费 | 久久久午夜爽爽一区二区三区三州 | h视频免费观看 | 国产免费av网站 | 一区二区免费播放 | 后人极品翘臀美女在线播放 | 超碰人操| 国产日韩欧美一区二区 | 欧美国产日韩一区 | 精品久久久久久久久久 | 日韩在线视频一区 | 亚洲成人在线视频网站 | 日韩爱爱视频 | 亚洲第一成年免费网站 | 国产真实乱全部视频 | 亚洲乱码国产乱码精品精 | 精品日韩一区二区 | 欧美精品久久久 | 日韩免费在线观看视频 | 毛片网站大全 | 91精品福利 | 亚洲欧美日韩另类精品一区二区三区 | 久久久久亚洲av毛片大全 | 亚洲国产一区二区三区四区 | 亚洲网色 | 成人久久18免费观看 | 中文字幕在线精品 | 国产真实精品久久二三区 | 成人一区二区在线 | 看片国产| 国产美女久久久 | 伊人狠狠干 | 国产一级黄色av | 亚洲国产免费看 | 欧美视频一区二区三区在线观看 | 精品伦精品一区二区三区视频 | 亚洲成人av一区二区 | 欧美精品日韩 | 美女天堂 | 成人精品久久 | 视频二区在线观看 | 中文字幕 亚洲一区 | 久久久精品久久久 | 亚洲视频在线播放 | 亚洲一区在线视频 | 成人av网站在线 | 亚洲免费成人 | 欧美中文在线 | 亚洲成人一区二区 | 欧美精品1区2区3区 国产女无套免费网站 | 日韩成人av在线 | 在线观看免费毛片视频 | 亚洲电影免费 | 久久99久久久久 | 99视频精品 | 麻豆久久精品 | 成人日批视频 | 午夜寂寞少妇aaa片毛片 | 欧美日韩在线一区二区 | 欧美区在线 | 天堂资源最新在线 | 亚洲视频 欧美视频 | 污视频免费网站观看 | 国产精品久久久久久久久免费桃花 | 亚洲成人aaa | 国产精品欧美久久久久一区二区 | 成人精品一区二区三区中文字幕 | 亚洲国产成人久久 | 国产欧美日韩综合精品一 | 亚洲视频区 | 成年人黄色一级片 | 香蕉久久夜色精品国产使用方法 | 伊人久久婷婷 | 成人夜晚看av | 国产一区二区在线视频观看 | 亚洲va欧美va天堂v国产综合 | 亚洲毛片在线观看 | 在线日韩欧美 | 欧美日韩亚洲三区 | 午夜在线观看视频 | 久久国产精品视频 | 欧美国产在线观看 | 日韩欧美在线观看一区 | 久久久免费 | 国内精品视频在线观看 | 成人精品在线视频 | 男女国产视频 | 久久精品无码一区二区日韩av | 欧美成人精品在线观看 | 欧美日韩精品电影 | a欧美| 99精品久久久国产一区二区三 | 亚洲欧美日韩精品久久亚洲区 | 美女午夜影院 | 久久久久久久久国产成人免费 | 欧美激情一区二区三区蜜桃视频 | 欧美福利在线观看 | 国产高清一区二区 | 成人在线免费观看 | 日韩综合在线 | 国产91综合一区在线观看 | 成人亚洲网站 | 麻豆毛片 | 久久成人精品一区二区三区 | 久久精品这里热有精品 | 午夜视频在线观看网站 | 中文字幕三区 | 精品国产乱码一区二区三区a | 国产精品久久久久久久久动漫 | 一区二区三区免费 | 欧美精品一区二区三区手机在线 | 久久久久一区 | 欧洲美女7788成人免费视频 | 久久免费小视频 | 国产精品一区二区三区四区 | 国产精品久久毛片 | 最新av网址大全 | 中字幕视频在线永久在线观看免费 | 久久99精品视频 | 国产精品视频免费观看 | 日韩一级 | 精品无码久久久久国产 | 久在线视频播放免费视频 | 99视频在线免费观看 | 色九九 | 日韩久久一区二区 | 激情婷婷综合 | 国产精品视频一二 | 99视频精品 | 精品视频一区二区 | 91精品国产乱码久久久久久 | 成人天堂666| 日韩中文字幕在线观看 | 欧美日韩国产影院 | 中文精品在线 | 久久久久久亚洲精品 | 日韩精品一区二区三区四区视频 | 99热首页| 国产精品久久久久久久久久久不卡 | 午夜小视频在线观看 | 亚洲视频免费在线观看 | 91se在线 | 视频一区 日韩 | 国产精品99一区二区三区 | 91国内精品久久 | 国产亚洲网站 | 欧美一区二区三区免费观看视频 | 影音先锋国产 | 色综合免费视频 | 久久久999成人| 国产精品成人在线 | 日本a网 | 久久精品成人免费视频 | 99国产精品久久久久久久 | 色婷婷基地 | 成人中文网| 欧美一级网站 | 久久久精品欧美 | 一级a毛片 | 天天拍天天操 | 国产艹 | 明里在线观看 | 亚洲精品一区久久久久久 | 成视频年人免费看黄网站 | 高清国产一区二区三区四区五区 | 91香蕉视频 | 色5月婷婷丁香六月 | 国产婷婷在线观看 | 中文字幕亚洲一区 | 国产成人天天爽高清视频 | 插插插干干干 | 日日干天天操 | 亚洲国产视频网站 | 欧美xxxx网站 | 青青操av| 亚洲成人精品一区 | 国产一区免费 | 日本精品在线播放 | www.色在线 | 久久99精品视频 | 国产精品影院在线观看 | 91成人精品视频 | 国产浪潮av色综合久久超碰 | 999久久久国产精品 欧美成人h版在线观看 | 国产精品亚洲综合 | 亚洲欧美一区二区三区在线 | 91中文字幕在线 | 成人免费淫片aa视频免费 | 亚洲精品国产高清 | 欧美在线视频网 | 国产精品久久毛片 | 婷婷国产 | 香蕉久久久久久 | 99国产视频| 亚洲国产精品久久久久久女王 | 欧美一区二区在线 | 黄色片在线 | 日韩无| 国产精品一区二区三区四区 | 日韩欧美在线播放 | 91色在线观看 | 色呦呦网站在线观看 | 日韩欧美国产网站 | 免费一区二区三区 | 欧美日在线 | 日本成人高清视频 | 日韩城人网站 | 免费看国产片在线观看 | 久久国产亚洲 | 精品久久久久久久人人人人传媒 | 黄色一级免费看 | 国产成人久久 | 91成人免费看片 | 国产成人精品一区二区三区在线 | 国产成人免费视频网站高清观看视频 | 男人的天堂中文字幕 | 山岸逢花在线观看 | 亚洲欧洲一区二区 | 亚洲精品电影在线观看 | 成人免费看黄 | 久久精品毛片 | 欧美成人性生活视频 | 中文字幕一二三 | 久久精品亚洲精品 | 国产精自产拍久久久久久 | 国产成人91 | 爱爱视频网站 | 国产精品久久久久久久久久久免费看 | 激情综合网五月婷婷 | 精品国产精品三级精品av网址 | 精品成人免费一区二区在线播放 | 国产精品一区二区免费 | 欧美一区二区三区在线看 | 99久久精品一区二区成人 | 中文字幕在线视频网站 | 欧美成人高清视频 | 人人澡人人射 | 亚洲国产免费 | 欧美日韩不卡视频 | 精品亚洲视频在线观看 | 青青草网站| 天天操天天色天天 | 五月婷婷在线观看视频 | 欧美精品在线观看 | 午夜成人在线视频 | 欧洲亚洲视频 | 91在线一区二区 | 日韩一二区视频 | 不用播放器的免费av | 91精品久久久久久久91蜜桃 | 亚洲免费观看视频 | 日韩精品视频三区 | 日日夜夜精品网站 | 四虎首页| 午夜激情视频在线观看 | 亚洲国产欧美日韩 | 成人在线观 | 免费国产wwwwwww网站 | 中文字幕在线第二页 | 日韩精品久久久久久 | 欧美精品一级二级 | 日韩中文在线 | 欧美成人免费观看 | 台湾av片 | 成人欧美一区二区三区 | 日韩欧美一级精品久久 | 久久99精品国产麻豆婷婷洗澡 | 天久久 | 四虎久久| 午夜欧美一区二区三区在线播放 | 国产欧美日韩综合精品 | 91国偷自产一区二区三区亲奶 | 日韩超级大片免费看国产国产播放器 | 成人国产在线 | 国产成人精品无人区一区 | 国户精品久久久久久久久久久不卡 | 精品久久久久香蕉网 | 成人午夜毛片 | 精品久久久久香蕉网 | 色婷婷欧美| 亚洲成人av在线 | 中文字幕在线视频网站 | 欧美精品91 | 夜夜春精品视频高清69式 | 国产一区二区在线播放 | 亚洲精品久久久一区二区三区 | 中文字幕天天操 | 免看一级一片 | 91福利影院在线观看 | 国产欧美精品 | 精品国产一区二区三区免费 | 成人精品在线观看 | 欧美性福 | 日本精品免费在线观看 | 亚洲九九 | www.国产视频 | 国产精品中文字幕在线观看 | 欧美福利视频 | 日本欧美国产 | 你懂的免费在线观看 | 国产精品一区二区久久 | 欧美性影院 | 欧美日韩在线免费观看 | 黄色片免费观看网站 | 91免费版在线观看 | 久久精品亚洲 | www.蜜桃av.com| 成人久久久精品乱码一区二区三区 | 精品一区二区视频 | 国产羞羞视频 | 久久精品1区 | 热久久久久 | 成人免费在线电影 | 欧美日韩国产精品一区二区 | 午夜精品久久久久久久久久久久 | 激情99| 婷婷国产精品 | 日韩av一区二区在线观看 | 亚洲 自拍 另类 欧美 丝袜 | 国产精品久久久久久久久久久久久久久久 | 国产精品视频导航 | 久久久久久久久久久久91 | 日韩手机在线观看 | 成人h动漫精品一区二区器材 | 自拍偷拍小视频 | 黄色一级大片在线免费看产 | 国内精品视频一区二区三区 | 日韩欧美国产网站 | 精品视频久久 | 日韩小视频网站 | 日本三级中文在线电影 | 国产精品国产精品国产专区不卡 | av大片 | 九九亚洲 | 欧美午夜一区 | 国产精品美女久久久久aⅴ国产馆 | 午夜午夜精品一区二区三区文 | 亚洲福利一区 | 亚洲精品国产第一综合99久久 | 成人av网页 | 美女视频一区二区三区 | 亚洲国产精品人人爽夜夜爽 | 大香伊在人线免97 | a在线观看| 亚洲一级淫片 | 国产亚洲精品成人av久久影院 | 精品国产欧美一区二区三区不卡 | 福利片一区二区 | 作爱视频免费看 | 国产成人免费 | 久久99深爱久久99精品 | 久久亚洲一区二区三区四区 | 国产高清一区 | 欧美日韩一区二区在线 | 欧美精品成人一区二区三区四区 | 欧美成人中文字幕 | 久久av资源网 | 超碰人人爱 | 国产精品久久久久久久久久东京 | 黄色毛片在线观看 | 亚洲aⅴ网站 | 成人黄视频在线观看 | 1区2区免费视频 | 亚洲精品乱码久久久久久蜜糖图片 | 欧美永久精品 | 中文字幕亚洲在线 | 精品视频在线免费观看 | 久久国产精品一区 | 精品国产一区二区三区性色av | 情五月 | 欧美日韩国产在线 | www.成人| 国产精品久久久久无码av | 国内久久精品 | 综合久久综合 | 国产女人爽到高潮免费视频 | 色com| 日韩视频精品 | 日本狠狠色 | 91av在线不卡 | www.788.com色淫免费 | 国产高清自拍 | 福利二区视频 | 亚洲国产精品综合久久久 | 一区二区在线电影 | 免费看的av | 国产精品久久久久久久一区探花 | 午夜免费 | 一区二区三区四区精品 | 激情久久av一区av二区av三区 | 久久久久久亚洲 | 午夜在线 | 国产成人看片 | a在线免费观看 | 国产精品欧美一区二区三区不卡 | 少妇黄色| 精品99久久久久久 | 91成人免费在线观看 | 久久久久久久久国产 | 91精品国产欧美一区二区 | 国产激情一区二区三区 | 国产超碰人人爽人人做人人爱 | 黄在线免费观看 | 超碰人人艹 | 亚洲欧美一区二区三区视频 | 九九综合九九 | 国产福利免费视频 | 日产久久| 国产精品乱码一二三区的特点 | 特级理论片 | 日韩福利视频网 | 久久久久中文 | 欧美成人资源 | 久久91精品 | 欧美一级高潮片免费的 | 欧美精品导航 | 日韩av一区二区三区在线观看 | 久久国产精品久久久久久 | 亚洲成人av一区二区三区 | 日韩91| 久久久久久综合 | 一区国产视频 | 亚洲一区二区中文 | 伊人免费在线观看高清版 | 日韩蜜桃 | av网站在线免费观看 | 亚洲一区二区三区在线免费观看 | 国产a级毛片 | 中文字幕一区二区三区四区不卡 | 国产精品夜间视频香蕉 | 欧美成人精品在线 | 国产一区二区三区久久 | 日本一区二区不卡 | 亚洲一区中文字幕永久在线 | 蜜桃精品视频在线 | 国产中文字幕亚洲 | 中文字幕在线观看亚洲 | 久久久精品国产 | 亚洲成人动漫在线观看 | 久久久99精品免费观看 | 中文字幕视频在线 | 欧美性网 | 免费成人一级片 | 日日做夜夜爱 | 亚洲高清免费 | 91精品福利 | 国产福利电影一区 | 亚洲免费人成在线视频观看 | 91在线看片 | 欧美精品亚洲精品 | 一区二区三区四区在线 | 国产成人在线一区二区 | www久久精品 | 亚洲国产日韩在线 | 日韩三区在线 | 伊人狠狠干| 亚洲第一免费看片 | 成人精品久久 | www.日韩 | 狠狠色综合色综合网络 | 久久国产精彩视频 | 精品视频在线观看 | 日韩免费精品视频 | 午夜爽| 91原创国产 | 国产真实精品久久二三区 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 亚洲一区二区三区爽爽爽爽爽 | 欧美成年黄网站色视频 | 午夜免费观看网站 | 日韩av高清在线 | 精品亚洲一区二区三区四区五区 | 日本一区二区三区中文字幕 | 91嫩草在线 | 日本三级在线观看中文字 | 黄视频在线播放 | av不卡电影在线观看 | 亚洲一区二区免费看 | 伊人久久国产 | 亚洲精品乱码久久久久久蜜桃图片 | 色婷婷在线播放 | 日韩色在线 | 99久久久久久久久 | av免费网站在线观看 | 久久久久久成人 | 天天操天天干天天爽 | 九九久久久 | 亚洲一区综合 | 伊人欧美视频 | 久久9久久| 欧美精品a∨在线观看不卡 欧美日韩中文字幕在线播放 | 久久久久久久久国产 | 精品国产黄色片 | 欧美福利视频 | 在线观看免费成人av | 一本一道久久a久久精品综合蜜臀 | 成人免费在线网址 | 久久骚| aaaaaaa片毛片免费观看 | 国产高清毛片 | 国产一区二区三区免费 | 久久亚洲一区 | 国产亚洲久久 | 九九热欧美 | 欧美日韩精品一区二区在线播放 | 91电影在线看 | 日韩av不卡在线 | 午夜成人免费电影 | 亚洲综合色自拍一区 | 国产精品一区av | 久久这里只有精品首页 | 国产一区二区三区在线 | 久久久精彩视频 | 日韩精品久久 | 久久av一区二区三区 | 亚洲高清视频在线 | 日韩欧美在线观看视频 | 亚洲成人网一区 | 91在线视频 | 日韩污视频在线观看 | 91免费在线看 | 99精品久久久国产一区二区三 | 我要看a级毛片 | 天天草狠狠干 | 成人综合在线观看 | 午夜久久久久 | 成人欧美一区二区三区黑人孕妇 | 日韩欧美一级精品久久 | 午夜私人影院在线观看 | 国产一区二区三区久久 | 精品在线播放 | 色偷偷噜噜噜亚洲男人 | 精品自拍网 | 欧美中文在线 | www成人精品 | 午夜精品久久久久久久久 | 高清av网站 | 不卡在线一区 | 国产人成精品一区二区三 | 久久久.com | 亚洲 欧美 日韩 精品 | 特级毛片在线大全免费播放 | 国产日韩欧美一区二区 | 成人在线一区二区 | 精品视频一区二区三区 | 先锋资源在线观看 | 精品一区av | 欧美日韩精品电影 | 精品一区国产 | 大陆一级毛片免费视频观看 | 亚洲特级| 久久久久久久国产精品 | 天堂综合网久久 | 色综合天天 | 精品无码久久久久久国产 | 日韩中字在线观看 | 99热首页 | 91色在线观看 | 久久免费小视频 | 日本免费在线 | 91精品国产九九九久久久亚洲 | 一区二区三区免费在线观看 | 亚洲一区 中文字幕 | av天天网| 狠狠操电影 | 久久久夜 | 国产午夜视频 | 一区毛片 | 成人1区2区 | av久久| 欧美一区二区三区在线 | 国产精品99久久久久久www | 天天操天天干视频 | 一区二区精品 | 亚洲欧美另类久久久精品2019 | 成人激情视频免费观看 | 日本精品视频网站 | 国产日韩精品视频 | 99久久99|