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

您的位置:首頁技術文章
文章詳情頁

Spring Boot整合swagger使用教程詳解

瀏覽:62日期:2023-08-27 13:35:36

Swagger的介紹

🔶你可能嘗試過寫完一個接口后,自己去創建接口文檔,或者修改接口后修改接口文檔。多了之后,你肯定會發生一個操作,那就是忘記了修改文檔或者創建文檔(除非你們公司把接口文檔和寫接口要求得很緊密😓忘記寫文檔就扣工資?,否則兩個分離的工作總是有可能遺漏的)。而swagger就是一個在你寫接口的時候自動幫你生成接口文檔的東西,只要你遵循它的規范并寫一些接口的說明注解即可。

優點與缺點

🔶優點:

自動生成文檔,只需要在接口中使用注解進行標注,就能生成對應的接口文檔。 自動更新文檔,由于是動態生成的,所以如果你修改了接口,文檔也會自動對應修改(如果你也更新了注解的話)。這樣就不會發送我修改了接口,卻忘記更新接口文檔的情況。 支持在線調試,swagger提供了在線調用接口的功能。

🔶缺點:

不能創建測試用例,所以他暫時不能幫你處理完所有的事情。他只能提供一個簡單的在線調試,如果你想存儲你的測試用例,可以使用Postman或者YAPI這樣支持創建測試用戶的功能。 要遵循一些規范,它不是任意規范的。比如說,你可能會返回一個json數據,而這個數據可能是一個Map格式的,那么我們此時不能標注這個Map格式的返回數據的每個字段的說明,而如果它是一個實體類的話,我們可以通過標注類的屬性來給返回字段加說明。也比如說,對于swagger,不推薦在使用GET方式提交數據的時候還使用Body,僅推薦使用query參數、header參數或者路徑參數,當然了這個限制只適用于在線調試。 沒有接口文檔更新管理,雖然一個接口更新之后,可能不會關心舊版的接口信息,但你“可能”想看看舊版的接口信息,例如有些灰度更新發布的時候可能還會關心舊版的接口。那么此時只能由后端去看看有沒有注釋留下了,所以可以考慮接口文檔大更新的時候注釋舊版的,然后寫下新版的。【當然這個問題可以通過導出接口文檔來對比。】 雖然現在Java的實體類中有不少模型,po,dto,vo等,模型的區分是為了屏蔽一些多余參數,比如一個用戶登錄的時候只需要username,password,但查權限的時候需要連接上權限表的信息,而如果上述兩個操作都是使用了User這個實體的話,在文檔中就會自動生成了多余的信息,這就要求了你基于模型來創建多個實體類,比如登錄的時候一個LoginForm,需要用戶-權限等信息的時候才使用User類。(當然了,這個問題等你會swagger之后你就大概就會怎么規避這個問題了。)

😓上面的缺點好像寫的有點多,你可能會覺得swagger這個坑有點大。但其實主要是規范問題,而規范問題有時候又會提高你的代碼規范性,這個就見仁見智了,你以前可能什么接口的參數都使用一個類,而現在swagger要求你分開后,某種層次上提高了你的代碼規范性。

🔶注:以下代碼示例基于Spring Boot。完整代碼可以參考:swagger-demo

添加swagger

💡這里先講添加swagger,也就是先整合進來,至于怎么使用,下面的“場景”中再講解。

1.添加依賴包:

❗注意,這里的前提是已經導入了spring boot的web包。

<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency>

2.配置Swagger:

要使用swagger,我們必須對swagger進行配置,我們需要創建一個swagger的配置類,比如可以命名為SwaggerConfig.java

package com.example.config;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import springfox.documentation.builders.ApiInfoBuilder;import springfox.documentation.builders.PathSelectors;import springfox.documentation.builders.RequestHandlerSelectors;import springfox.documentation.service.ApiInfo;import springfox.documentation.spi.DocumentationType;import springfox.documentation.spring.web.plugins.Docket;import springfox.documentation.swagger2.annotations.EnableSwagger2;@Configuration // 標明是配置類@EnableSwagger2 //開啟swagger功能public class SwaggerConfig { @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2) // DocumentationType.SWAGGER_2 固定的,代表swagger2// .groupName('分布式任務系統') // 如果配置多個文檔的時候,那么需要配置groupName來分組標識 .apiInfo(apiInfo()) // 用于生成API信息 .select() // select()函數返回一個ApiSelectorBuilder實例,用來控制接口被swagger做成文檔 .apis(RequestHandlerSelectors.basePackage('com.example.controller')) // 用于指定掃描哪個包下的接口 .paths(PathSelectors.any())// 選擇所有的API,如果你想只為部分API生成文檔,可以配置這里 .build(); } /** * 用于定義API主界面的信息,比如可以聲明所有的API的總標題、描述、版本 * @return */ private ApiInfo apiInfo() { return new ApiInfoBuilder() .title('XX項目API') // 可以用來自定義API的主標題 .description('XX項目SwaggerAPI管理') // 可以用來描述整體的API .termsOfServiceUrl('') // 用于定義服務的域名 .version('1.0') // 可以用來定義版本。 .build(); // }}

3.測試

運行我們的Spring Boot項目,(我默認是8080端口,如果你不一樣,請注意修改后續的url),訪問http://localhost:8080/swagger-ui.html然后你就可以看到一個如下的界面,由于我們暫時沒有配置接口數據,所以下面顯示No operations defined in spec!

Spring Boot整合swagger使用教程詳解

💡下面我們將介紹如何定義接口,以及在swagger UI界面中的內容。

場景:

定義接口組

接口有時候應該是分組的,而且大部分都是在一個controller中的,比如用戶管理相關的接口應該都在UserController中,那么不同的業務的時候,應該定義/劃分不同的接口組。接口組可以使用@Api來劃分。比如:

@Api(tags = '角色管理') // tags:你可以當作是這個組的名字。@RestControllerpublic class RoleController {}

@Api(tags = '用戶管理') // tags:你可以當作是這個組的名字。@RestControllerpublic class UserController {}

🔵你也可以理解成基于tags來分組,就好像一些文章里面的標簽一樣,使用標簽來分類。🔵如果這個Controller下(接口組)下面沒有接口,那么在swagger ui中是不會顯示的,如果有的話就會這樣顯示:

Spring Boot整合swagger使用教程詳解

定義接口

使用了@Api來標注一個Controller之后,如果下面有接口,那么就會默認生成文檔,但沒有我們自定義的說明:

@Api(tags = '用戶管理')@RestControllerpublic class UserController { // 注意,對于swagger,不要使用@RequestMapping, // 因為@RequestMapping支持任意請求方式,swagger會為這個接口生成7種請求方式的接口文檔 @GetMapping('/info') public String info(String id){ return 'aaa'; }}

Spring Boot整合swagger使用教程詳解

Spring Boot整合swagger使用教程詳解

我們可以使用@ApiOperation來描述接口,比如:

@ApiOperation(value = '用戶測試',notes = '用戶測試notes') @GetMapping('/test') public String test(String id){ return 'test'; }

Spring Boot整合swagger使用教程詳解

常用配置項:

value:可以當作是接口的簡稱notes:接口的描述 tags:可以額外定義接口組,比如這個接口外層已經有@Api(tags = '用戶管理'),將接口劃分到了“用戶管理”中,但你可以額外的使用 tags,例如tags = '角色管理'讓角色管理中也有這個接口文檔。

定義接口請求參數

上面使用了@ApiOperation來了描述接口,但其實還缺少接口請求參數的說明,下面我們分場景來講。🔵注意一下,對于GET方式,swagger不推薦使用body方式來傳遞數據,也就是不希望在GET方式時使用json、form-data等方式來傳遞,這時候最好使用路徑參數或者url參數。(😓雖然POSTMAN等是支持的),所以如果接口傳遞的數據是json或者form-data方式的,還是使用POST方式好。

場景一:請求參數是實體類。

此時我們需要使用@ApiModel來標注實體類,然后在接口中定義入參為實體類即可:

@ApiModel:用來標類

常用配置項:

value:實體類簡稱

description:實體類說明

@ApiModelProperty:用來描述類的字段的意義。

常用配置項:

value:字段說明

example:設置請求示例(Example Value)的默認值,如果不配置,當字段為string的時候,此時請求示例中默認值為''.name:用新的字段名來替代舊的字段名。

allowableValues:限制值得范圍,例如{1,2,3}代表只能取這三個值;[1,5]代表取1到5的值;(1,5)代表1到5的值,不包括1和5;還可以使用infinity或-infinity來無限值,比如[1, infinity]代表最小值為1,最大值無窮大。

required:標記字段是否必填,默認是false,

hidden:用來隱藏字段,默認是false,如果要隱藏需要使用true,因為字段默認都會顯示,就算沒有@ApiModelProperty。

// 先使用@ApiModel來標注類@ApiModel(value='用戶登錄表單對象',description='用戶登錄表單對象')public class LoginForm { // 使用ApiModelProperty來標注字段屬性。 @ApiModelProperty(value = '用戶名',required = true,example = 'root') private String username; @ApiModelProperty(value = '密碼',required = true,example = '123456') private String password; // 此處省略入參賦值時需要的getter,setter,swagger也需要這個}

定義成入參:

@ApiOperation(value = '登錄接口',notes = '登錄接口的說明') @PostMapping('/login') public LoginForm login(@RequestBody LoginForm loginForm){ return loginForm; }

效果:

Spring Boot整合swagger使用教程詳解

場景二:請求參數是非實體類。

(再說一次:對于GET方式,swagger不推薦使用body方式來傳遞數據,所以雖然Spring MVC可以自動封裝參數,但對于GET請求還是不要使用form-data,json等方式傳遞參數,除非你使用Postman來測試接口,swagger在線測試是不支持這個操作的)

對于非實體類參數,可以使用@ApiImplicitParams和@ApiImplicitParam來聲明請求參數。@ApiImplicitParams用在方法頭上,@ApiImplicitParam定義在@ApiImplicitParams里面,一個@ApiImplicitParam對應一個參數。@ApiImplicitParam常用配置項:

name:用來定義參數的名字,也就是字段的名字,可以與接口的入參名對應。如果不對應,也會生成,所以可以用來定義額外參數! value:用來描述參數 required:用來標注參數是否必填 paramType有path,query,body,form,header等方式,但對于對于非實體類參數的時候,常用的只有path,query,header;body和form是不常用的。body不適用于多個零散參數的情況,只適用于json對象等情況。【如果你的接口是form-data,x-www-form-urlencoded的時候可能不能使用swagger頁面API調試,但可以在后面講到基于BootstrapUI的swagger增強中調試,基于BootstrapUI的swagger支持指定form-data或x-www-form-urlencoded】

示例一:聲明入參是URL參數

// 使用URL query參數 @ApiOperation(value = '登錄接口2',notes = '登錄接口的說明2') @ApiImplicitParams({ @ApiImplicitParam(name = 'username',//參數名字 value = '用戶名',//參數的描述 required = true,//是否必須傳入 //paramType定義參數傳遞類型:有path,query,body,form,header paramType = 'query' ) , @ApiImplicitParam(name = 'password',//參數名字 value = '密碼',//參數的描述 required = true,//是否必須傳入 paramType = 'query' ) }) @PostMapping(value = '/login2') public LoginForm login2(String username,String password){ System.out.println(username+':'+password); LoginForm loginForm = new LoginForm(); loginForm.setUsername(username); loginForm.setPassword(password); return loginForm; }

示例二:聲明入參是URL路徑參數

// 使用路徑參數 @PostMapping('/login3/{id1}/{id2}') @ApiOperation(value = '登錄接口3',notes = '登錄接口的說明3') @ApiImplicitParams({ @ApiImplicitParam(name = 'id1',//參數名字 value = '用戶名',//參數的描述 required = true,//是否必須傳入 //paramType定義參數傳遞類型:有path,query,body,form,header paramType = 'path' ) , @ApiImplicitParam(name = 'id2',//參數名字 value = '密碼',//參數的描述 required = true,//是否必須傳入 paramType = 'path' ) }) public String login3(@PathVariable Integer id1,@PathVariable Integer id2){ return id1+':'+id2; }

示例三:聲明入參是header參數

// 用header傳遞參數 @PostMapping('/login4') @ApiOperation(value = '登錄接口4',notes = '登錄接口的說明4') @ApiImplicitParams({ @ApiImplicitParam(name = 'username',//參數名字 value = '用戶名',//參數的描述 required = true,//是否必須傳入 //paramType定義參數傳遞類型:有path,query,body,form,header paramType = 'header' ) , @ApiImplicitParam(name = 'password',//參數名字 value = '密碼',//參數的描述 required = true,//是否必須傳入 paramType = 'header' ) }) public String login4( @RequestHeader String username, @RequestHeader String password){ return username+':'+password; }

示例四:聲明文件上傳參數

// 有文件上傳時要用@ApiParam,用法基本與@ApiImplicitParam一樣,不過@ApiParam用在參數上 // 或者你也可以不注解,swagger會自動生成說明 @ApiOperation(value = '上傳文件',notes = '上傳文件') @PostMapping(value = '/upload') public String upload(@ApiParam(value = '圖片文件', required = true)MultipartFile uploadFile){ String originalFilename = uploadFile.getOriginalFilename(); return originalFilename; } // 多個文件上傳時,**swagger只能測試單文件上傳** @ApiOperation(value = '上傳多個文件',notes = '上傳多個文件') @PostMapping(value = '/upload2',consumes = 'multipart/*', headers = 'content-type=multipart/form-data') public String upload2(@ApiParam(value = '圖片文件', required = true,allowMultiple = true)MultipartFile[] uploadFile){ StringBuffer sb = new StringBuffer(); for (int i = 0; i < uploadFile.length; i++) { System.out.println(uploadFile[i].getOriginalFilename()); sb.append(uploadFile[i].getOriginalFilename()); sb.append(','); } return sb.toString(); } // 既有文件,又有參數 @ApiOperation(value = '既有文件,又有參數',notes = '既有文件,又有參數') @PostMapping(value = '/upload3') @ApiImplicitParams({ @ApiImplicitParam(name = 'name', value = '圖片新名字', required = true ) }) public String upload3(@ApiParam(value = '圖片文件', required = true)MultipartFile uploadFile, String name){ String originalFilename = uploadFile.getOriginalFilename(); return originalFilename+':'+name; }

定義接口響應

定義接口響應,是方便查看接口文檔的人能夠知道接口返回的數據的意義。

響應是實體類:

前面在定義接口請求參數的時候有提到使用@ApiModel來標注類,如果接口返回了這個類,那么這個類上的說明也會作為響應的說明:

// 返回被@ApiModel標注的類對象 @ApiOperation(value = '實體類響應',notes = '返回數據為實體類的接口') @PostMapping('/role1') public LoginForm role1(@RequestBody LoginForm loginForm){ return loginForm; }

Spring Boot整合swagger使用教程詳解

響應是非實體類:

swagger無法對非實體類的響應進行詳細說明,只能標注響應碼等信息。是通過@ApiResponses和@ApiResponse來實現的。@ApiResponses和@ApiResponse可以與@ApiModel一起使用。

// 其他類型的,此時不能增加字段注釋,所以其實swagger推薦使用實體類 @ApiOperation(value = '非實體類',notes = '非實體類') @ApiResponses({ @ApiResponse(code=200,message = '調用成功'), @ApiResponse(code=401,message = '無權限' ) } ) @PostMapping('/role2') public String role2(){ return ' {n' + ' name:'廣東',n' + ' citys:{n' + ' city:['廣州','深圳','珠海']n' + ' }n' + ' }'; }

Spring Boot整合swagger使用教程詳解

Swagger UI增強

你可能會覺得現在這個UI不是很好看,現在有一些第三方提供了一些Swagger UI增強,比較流行的是swagger-bootstrap-ui,我們這里以swagger-bootstrap-ui為例。

UI對比:

Spring Boot整合swagger使用教程詳解

Spring Boot整合swagger使用教程詳解

使用

1.添加依賴包:

<!--引入swagger--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.9.2</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.9.2</version> </dependency> <!-- 引入swagger-bootstrap-ui依賴包--> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>swagger-bootstrap-ui</artifactId> <version>1.8.7</version> </dependency>

2.在swagger配置類中增加注解@EnableSwaggerBootstrapUI:

@Configuration // 標明是配置類@EnableSwagger2 //開啟swagger功能@EnableSwaggerBootstrapUI // 開啟SwaggerBootstrapUIpublic class SwaggerConfig { // 省略配置內容}

3.訪問API:http://localhost:8080/doc.html,即可預覽到基于bootstarp的Swagger UI界面。

優點

1.🤔界面好看了一點

2.上面說過了,基于BootstrapUI的swagger支持指定form-data或x-www-form-urlencoded:

Spring Boot整合swagger使用教程詳解

3.支持復制單個API文檔和導出全部API文檔:

Spring Boot整合swagger使用教程詳解

Spring Boot整合swagger使用教程詳解

整合Spring Security注意

在Spring Boot整合Spring Security和Swagger的時候,需要配置攔截的路徑和放行的路徑,注意是放行以下幾個路徑。

.antMatchers('/swagger**/**').permitAll().antMatchers('/webjars/**').permitAll().antMatchers('/v2/**').permitAll().antMatchers('/doc.html').permitAll() // 如果你用了bootstarp的Swagger UI界面,加一個這個。

對于token的處理

在swagger中只支持了簡單的調試,但對于一些接口,我們測試的時候可能需要把token信息寫到header中,目前好像沒看到可以自定義加請求頭的地方?💡方法一:如果你使用了Swagger BootstrapUI,那么你可以在“文檔管理”中增加全局參數,這包括了添加header參數。

💡方法二:在swagger配置類中增加全局參數配置:

//如果有額外的全局參數,比如說請求頭參數,可以這樣添加 ParameterBuilder parameterBuilder = new ParameterBuilder(); List<Parameter> parameters = new ArrayList<Parameter>(); parameterBuilder.name('authorization').description('令牌') .modelRef(new ModelRef('string')).parameterType('header').required(false).build(); parameters.add(parameterBuilder.build()); return new Docket(DocumentationType.SWAGGER_2) // DocumentationType.SWAGGER_2 固定的,代表swagger2 .apiInfo(apiInfo()) // 用于生成API信息 .select() // select()函數返回一個ApiSelectorBuilder實例,用來控制接口被swagger做成文檔 .apis(RequestHandlerSelectors.basePackage('com.example.controller')) // 用于指定掃描哪個包下的接口 .paths(PathSelectors.any())// 選擇所有的API,如果你想只為部分API生成文檔,可以配置這里 .build().globalOperationParameters(parameters);

💡方法三:使用@ApiImplicitParams來額外標注一個請求頭參數,例如:

// 如果需要額外的參數,非本方法用到,但過濾器要用,類似于權限token @PostMapping('/login6') @ApiOperation(value = '帶token的接口',notes = '帶token的接口') @ApiImplicitParams({ @ApiImplicitParam(name = 'authorization',//參數名字 value = '授權token',//參數的描述 required = true,//是否必須傳入 paramType = 'header' ) , @ApiImplicitParam(name = 'username',//參數名字 value = '用戶名',//參數的描述 required = true,//是否必須傳入 paramType = 'query' ) }) public String login6(String username){ return username; }

Swagger的安全管理

1.如果你整合了權限管理,可以給swagger加上權限管理,要求訪問swagger頁面輸入用戶名和密碼,這些是spring security和shiro的事了,這里不講。

2.如果你僅僅是不想在正式環境中可以訪問,可以在正式環境中關閉Swagger自動配置,這就不會有swagger頁面了。使用@Profile({'dev','test'})注解來限制只在dev或者test下啟用Swagger自動配置。然后在Spring Boot配置文件中修改當前profilespring.profiles.active=release,重啟之后,此時無法訪問http://localhost:8080/swagger-ui.html

到此這篇關于Spring Boot整合swagger使用教程的文章就介紹到這了,更多相關Spring Boot整合swagger內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 韩国电影久久 | 国产一级淫免费播放m | 日韩视频免费在线 | 天天干狠狠 | 黄色毛片在线看 | 亚洲国产成人久久综合一区,久久久国产99 | 久久久久网站 | 中文字幕在线网址 | 黑色丝袜脚足j国产在线看68 | 999精品网 | 久久精品免费视频播放 | 国产自在现线2019 | 成人av观看 | 91精品国产91久久久久游泳池 | 午夜日韩| 超碰在线人人 | 国产毛片毛片 | 国产午夜精品美女视频明星a级 | 久久国产一区二区三区 | 国产精品国产三级国产aⅴ无密码 | 欧美国产精品一区二区 | 亚洲国产精品99久久久久久久久 | 2020天天操 | 欧美日韩中文在线观看 | 国产一级免费视频 | 99国产精品久久久 | 一级毛片视频 | 欧美日本一区 | 欧美日韩在线第一页 | 国产精品久久久久久久久久久久久久 | 自拍偷拍亚洲欧洲 | 久久国内免费视频 | www.日韩av.com | 成人午夜精品久久久久久久3d | 国产精品国产三级国产aⅴ中文 | 日韩电影专区 | 亚洲精品国产综合 | 亚洲一区二区av | 操操操操操操操操操操操操操操 | 中国黄色在线视频 | 国产伦精品一区二区 | 欧美99| 国产一级纯肉体一级毛片 | 欧美久久一区二区三区 | 精品免费一区二区 | 日韩欧美视频 | 国产黄色av | 国产一区二区三区久久 | 91精品国产福利在线观看 | 国产欧美综合一区二区三区 | 久在线观看| 中文字幕在线电影 | 色婷婷av一区二区三区软件 | 天天干天天看天天操 | 国产午夜久久久久 | 欧美一极片 | 亚洲一区二区在线播放 | 国产日日夜夜操 | 中文字幕av一区二区 | 国产欧美日韩综合精品一区二区 | 激情综合在线 | 欧洲成人一区 | 久久一区国产 | 在线看一区二区 | 91麻豆精品国产91久久久久久 | 男女网站视频 | 精品成人免费一区二区在线播放 | 欧美午夜精品久久久久久人妖 | 午夜免费小视频 | 国产精品九九九 | 久久精品小视频 | 欧美激情欧美激情在线五月 | 日韩视频中文字幕 | 四虎最新网站 | 天天干干干干 | 午夜精品一区二区三区在线视频 | 久久精品一区二区三区四区 | 亚洲日韩成人 | 精品国产一区二区三区久久久蜜月 | 男人天堂视频网 | 欧美亚洲三级 | 亚洲欧洲综合 | 久久一道本 | 国产精品成人国产乱一区 | 国产精品福利在线 | 久免费视频 | 超碰中文字幕 | 国产在视频一区二区三区吞精 | 久久99精品视频 | 久久国产精品免费一区二区三区 | 国产精品久久久久久久久久ktv | 九九综合| 蜜桃视频成人m3u8 | 日韩精品99久久久久中文字幕 | 国产偷录视频叫床高潮对白 | 国产精品久久久久久久久久久免费看 | 久久99精品国产自在现线 | 午夜色视频在线观看 | 欧美精品久久久久久久久 | 精品96久久久久久中文字幕无 | 欧美电影一区二区三区 | 91高清在线 | 一级片 | 成人一区二区三区在线观看 | 国产浪潮av色综合久久超碰 | 国产www在线 | 精品第一页 | 一本一道久久a久久精品综合蜜臀 | 国产精品久久久久久久久久 | 国产精品天天干 | 青青99| 国产欧美综合一区二区三区 | 国产一区a | 久久99精品久久久久婷婷暖91 | 欧美视频一二三区 | 亚洲黄色免费观看 | 国产在线第一页 | 男女免费在线观看 | 免费观看欧美一级 | 亚洲精品一区二区三区四区高清 | 岛国免费 | 成人av观看| 91 久久| 久草一区 | 久久综合久久综合久久综合 | 日韩成人 | 亚洲精品久久久久国产 | 中文字幕免费视频观看 | 99亚洲 | 日本黄色电影网站 | 在线欧美亚洲 | 亚洲精品一区二区三区 | 欧美日韩欧美日韩 | 青青草久久| 日韩在线观看 | 久久天堂| 欧美久久精品 | 天天草天天干 | 亚洲国产精品一区 | 一区二区三区国产 | 日本久久综合 | 国产一区二区精品在线 | 日韩国产 | 久视频在线观看 | 99精品网站 | 亚洲精品一区二区三区在线播放 | 国产欧美精品一区二区色综合 | 在线免费中文字幕 | 国产99久久久国产精品 | 亚洲精品午夜国产va久久成人 | 999精品视频| 亚洲一区二区三区免费在线 | 91九色视频在线 | 欧美精品一区二区三区四区在线 | 久久久久久网站 | 欧美精品久久久 | 日本一级中文字幕久久久久久 | 亚洲国产精品一区二区久久 | 中文字幕一区二区三区在线视频 | 在线观看亚洲一区二区 | 精品少妇一区二区三区在线播放 | 中文字幕久久久 | 91蜜桃视频 | 精品美女久久久 | 日韩欧美中文 | 亚洲天堂一区 | 久久精品欧美一区二区三区不卡 | 欧美日韩综合视频 | 亚洲91精品| 日韩一区二区在线免费 | 成人欧美一区二区 | 日本特黄特色aaa大片免费 | 久久精品综合 | 亚洲成人精品在线观看 | 狠狠伊人 | 伊人手机在线视频 | 国产黄色在线观看 | 欧美一区二区三区xxxx监狱 | 毛片在线视频 | 在线看片成人 | 免费观看黄视频 | 久久成人精品视频 | 欧洲成人午夜免费大片 | 成年人免费看 | 黄色大片网站在线观看 | 91色视频在线观看 | 中文字幕欧美日韩一区 | 国产精品一区在线观看 | 久草.com| 国产精品毛片久久久久久久 | 亚洲欧美高清 | 国产真实乱全部视频 | 国产欧美一区二区精品性色 | 精品国产一区二区三区在线观看 | 日韩在线视频观看 | 日日夜夜狠狠 | 亚洲一区二区日韩 | 亚洲国产精品99久久久久久久久 | 国产精品福利网站 | 亚洲一区二区三区四区五区中文 | 午夜a级理论片915影院 | 黄色国产一级片 | 久久男人的天堂 | 亚洲视频免费观看 | 色噜噜视频在线观看 | 日韩欧美精品一区 | 一区二区三区在线视频播放 | 福利二区| 久久国产综合 | 日韩欧美在线看 | 国内av网站 | 五月天在线婷婷 | 91麻豆精品国产91久久久资源速度 | 免费观看一区二区三区毛片 | 欧美日本亚洲 | 在线观看免费av的网址 | 日本一区二区三区视频免费看 | 日本好好热视频 | 精品久久久久久久久久久久久久 | 欧美精品一区二区三区中文字幕 | 亚洲欧洲成人 | 一区二区色 | 一区二区三区高清不卡 | 日韩欧美一区二区三区 | 久久国产亚洲 | 九九热精品免费视频 | 夜夜夜久久 | 国精产品一区二区三区 | 在线视频a | 国产99久久久久久免费看农村 | 精品三级在线观看 | 国产高清视频一区二区 | 天天精品在线 | 在线99热 | 亚洲36d大奶网 | 精品香蕉一区二区三区 | 国产主播福利 | 日韩一区二区在线视频 | 精品在线一区 | 国产三级在线 | 欧美一级片免费播放 | 亚洲大尺度视频 | 亚洲视频自拍 | 成人黄色一区 | 久久国产亚洲精品 | 日本中文字幕一区 | 亚洲视频免费网站 | 伊人影视 | 国产精品久久久久久二区 | 久草视频在线播放 | av一二三区 | a欧美 | 一级片视频在线观看 | 91久色 | 天天色天天色 | а天堂中文最新一区二区三区 | 精品国产91乱码一区二区三区 | 久久久www| 精品亚洲一区二区三区 | www.色在线 | aaaa网站 | 久久久精品一区 | 欧美激情视频久久 | 久久久久久久香蕉 | 激情91 | 国产乱码一区二区三区在线观看 | 欧美一级免费 | 色婷婷在线视频 | 亚洲综合在线网 | www.男人天堂 | 一区二区三区不卡视频 | 日韩性猛交| 最新天堂中文在线 | 亚洲三级不卡 | 国产精品久久久久精 | 欧美久久久久久久 | 欧美午夜精品久久久久久人妖 | 在线播放国产精品 | 日日综合 | 欧美日韩视频在线观看一区 | 亚洲最大成人 | 国产精品成人一区二区三区 | 日韩精品一区二区三区 | 日韩久久一区二区 | 亚洲三级视频 | 日韩视频一区二区三区 | 色先锋av资源中文字幕 | 日韩欧美高清dvd碟片 | 欧美性猛交一区二区三区精品 | 伊人网国产 | 日韩三级网 | 龙珠z普通话国语版在线观看 | 精品国产乱码久久久久久88av | 中文字幕亚洲欧美精品一区四区 | 97久久久 | 99精品欧美一区二区三区综合在线 | 视频一区二区国产 | 日本中文在线 | 久久www免费人成看片高清 | 免费日韩视频 | 国产精品福利在线观看 | 亚洲成人久久久 | 日韩在线免费 | 性高湖久久久久久久久aaaaa | 亚洲毛片网站 | 麻豆freexxxx性91精品 | 人人射人人干 | 日本久久久久久 | 国产精品久久久久久久久久久不卡 | 日韩一二三区在线观看 | 亚洲视频1区 | 成人精品久久久 | 色综久久 | 国产精品无 | 欧美a在线看| 蜜桃免费一区二区三区 | 99re视频 | 草比网站| 日韩一片 | 91香蕉视频 | av高清在线看 | 国产成人精品免高潮在线观看 | 亚洲日本二区 | 99热热热| 99在线精品视频 | 欧美成人免费视频 | 国产视频2021 | 精品影院| 欧美在线观看黄 | 日韩不卡一区二区三区 | 成人午夜啪啪好大 | 97久久久国产精品 | 国产精品久久一区二区三区 | av午夜电影 | 不卡在线| 成人一区二区在线观看 | 亚洲一区成人在线观看 | 一区二区在线免费观看 | 99久久免费观看 | 欧洲精品一区 | 日韩久久久久久久久久久 | 欧美激情第1页 | 午夜一级黄色片 | 精品久久久久久久久久久 | 一级毛片免费播放 | 亚洲精品国产setv | 在线观看国产精品一区二区 | 亚洲国产高清在线 | 在线观看国产视频 | 精品欧美黑人一区二区三区 | 午夜精品久久久久久久久久久久 | 黄色激情网站 | 国产精品婷婷久久久久 | 国产精品成av人在线视午夜片 | 久久久国产一区二区三区 | 中文字幕八区 | 毛片a片| 亚洲v日韩v综合v精品v | 成年免费视频 | 亚州激情 | 国产在线精品一区 | 麻豆一区二区三区 | 欧美一区二区三区男人的天堂 | 999国内精品永久免费视频 | 国产高清视频一区 | 91精品国产综合久久久久久 | 亚洲欧美视频一区 | 欧美激情高清 | 午夜亚洲福利 | 天天摸天天摸 | 国产精品3区 | 国产日韩在线播放 | 九色91九色porny永久 | 久草免费在线视频 | 久久成人一区 | 日韩视频一区二区三区 | 免费观看一级特黄欧美大片 | 国产在线不卡 | av观看在线| 亚洲一区二区在线 | 欧美精品一二三区 | 亚洲风情在线观看 | 欧美日韩中文字幕 | 91精品电影| 国产精品久久久久久久久久久久久久 | 黄色地址 | 波多野结衣福利电影 | 国产亚洲精品美女久久久久久久久久 | 视频一区二区三区中文字幕 | 中文字幕一区二区三区在线视频 | 日本视频中文字幕 | 91中文在线观看 | 日韩草比 | 欧美国产日韩在线 | 成年人网站国产 | 亚洲午夜精品一区二区三区他趣 | 男女激情网址 | 国产精品亚洲一区二区三区在线 | 太平公主一级艳史播放高清 | 极品白嫩少妇无套内谢 | 一区二区三区在线播放 | 另类国产ts人妖高潮系列视频 | 成人深夜免费视频 | youjizz欧美 | 国产在线一| 亚洲精品日韩综合观看成人91 | 中文字幕 在线观看 | 午夜精品久久久久 | 久久久在线 | 中文字幕天堂在线 | 一级片av| 亚洲精品视频在线播放 | 视色网站 | 欧美三级电影在线播放 | 久久久久久久av | 国产精品久久久久9999赢消 | 久久久xxxx| 国产精品久久久久久一区二区三区 | 激情一区二区三区 | 亚洲综合色自拍一区 | 欧美日韩国产综合视频 | www一区二区 | 精品毛片 | 51ⅴ精品国产91久久久久久 | 国产日韩欧美视频 | 男女羞羞视频网站18 | 国产男女爽爽爽免费视频 | 男女全黄一级一级高潮免费看 | 国产天天操 | 免费国产黄网站在线观看视频 | 欧美五月婷婷 | 免费国产视频 | 亚洲伊人中文字幕 | 精品中文在线 | 青草久操| 亚洲欧洲tv | 欧美激情自拍偷拍 | 韩国xxxx性hd极品 | 国产三级在线 | 欧美精品99 | 日韩一区二区中文字幕 | 精品影院 | 一级a毛片| 国产区日韩区欧美区 | 亚洲国产精品一区 | 日本在线视频观看 | 精品三区在线观看 | 国产黄色精品 | 国产精品久久久 | 国产精品三级久久久久久电影 | 欧美成人黄激情免费视频 | 日日摸夜夜添夜夜添亚洲女人 | 久久毛片 | 精品国产第一国产综合精品 | 人人av在线 | 国产噜噜噜噜噜久久久久久久久 | 国产一区二区精品 | www久久精品 | 日韩一区不卡 | 日韩精品在线一区 | 国产97色在线 | 亚洲 | 国产精品久久国产精麻豆99网站 | 国产精品久久久久国产a级 99精品欧美一区二区三区综合在线 | 国产精品一区二区久久久久 | 在线免费观看av片 | 国产精品一区二区久久久 | av资源中文在线 | 黄色一级大片在线免费看产 | 国产免费拔擦拔擦8x高清在线人 | 欧美成人综合在线 | 色爱综合网 | 毛片一区二区 | 免费在线h | 一区二区三区国产好 | 草草影院ccyycom | 国产精品成av人在线视午夜片 | 久久男人天堂 | 亚洲在线| 久久久久久久久一区 | 九九热精品视频 | av午夜| 国产一区二区资源 | 欧美二区三区视频 | 99久久久久国产精品免费 | 午夜少妇av | 成人不卡视频 | 亚洲大片69999 | 中文字幕亚洲一区二区va在线 | 日日久 | 91高清视频在线观看 | 九九热视频在线 | 国产成人久久精品一区二区三区 | 精品一二区 | 久久成人精品一区二区三区 | 日韩性视频 | 亚州精品天堂中文字幕 | 亚洲精品久久久久久久久久久 | 国产婷婷在线观看 | 国产精品一区二区三区免费 | 日韩精品一二三区 | 日本欧美在线观看 | 国产精品有限公司 | 欧美日韩一区二区三区视频 | 精品国产精品国产偷麻豆 | 欧美精品一区三区 | 欧美精品乱码久久久久久按摩 | 久久免费小视频 | 精品无码久久久久久国产 | 高清国产午夜精品久久久久久 | 久久成人一区 | 精品一区二区三区免费毛片 | av在线一区二区三区 | 国产精品久久久久久久久动漫 | 亚洲欧美一区二区在线观看 | 国产欧美一区二区精品性色 | 一区二区三区在线播放视频 | 7777视频 | 亚洲香蕉在线观看 | 国产成人av在线播放 | 色999国产| 欧美激情视频一区二区三区 | 日韩欧在线 | 神马午夜 | 国产午夜视频 | 午夜精品一区二区三区免费视频 | 99精品欧美一区二区三区综合在线 | 精品影视 | 欧美成人精品一区二区三区 | 精品少妇一区二区三区日产乱码 | 亚洲九九 | 91精品久久久久久久久久久 | 天天操导航 | 日韩一级视频 | 国产亚洲一区二区三区在线观看 | 国产亚洲精品美女久久久久久久久久 | 国产精品免费一区 | 插插插干干干 | 精品视频久久 | 欧美一区二区视频 | 日本成年人免费网站 | 狠狠爱网站 | 二区三区 | 欧美日韩91 | 精品一区二区三区在线观看 | 日本一区二区不卡视频 | 香蕉国产精品 | 91精品国产91久久久久久最新 | www久久国产| 超碰999| 天天综合网91 | 亚洲欧美在线综合 | 可以免费看黄视频的网站 | 欧美日韩视频在线第一区 | 国产欧美久久一区二区三区 | 亚洲一区二区在线播放 | 高清av一区| 国产h在线 | 国产一区二区视频在线播放 | 国产欧美日韩综合精品一 | 亚洲精品乱码久久久久久按摩观 | 国产精品视频网 | 日韩福利视频导航 | 一区二区三区成人久久爱 | 91在线| 日日操狠狠操 | 九九免费视频 | 成人做爰www免费看视频网站 | 极品女神高潮呻吟av久久 | 精品视频免费在线 | 一级毛片免费完整视频 | 欧美全黄 | 亚洲欧美日韩精品久久亚洲区 | 视频一区 中文字幕 | 日本视频二区 | 日韩欧美视频 | 久久兔费看a级 | 久久综合网址 | 成人激情视频免费观看 | 久久91 | 午夜精品在线观看 | 一道本一区二区三区 | 久久欧美精品 | 欧美亚洲国产一区 | 午夜视频在线观看网站 | 日韩小视频在线播放 | 99精品欧美一区二区蜜桃免费 | 日韩视频在线观看一区 | 99热在线播放 | 91视频网址 | 精品日韩一区二区 | 中文字幕一区二区三区精彩视频 | 99久久99| 国产精品成人品 | 国产麻豆乱码精品一区二区三区 | 欧美另类一二三四 | 欧美高清一区 | 成全视频免费观看在线看黑人 | 综合中文字幕 | 99视频在线免费观看 | 免费v片在线观看 | 美女久久一区 | 毛片av在线 | 日韩欧美在线观看一区二区三区 | 不用播放器的免费av | 九九九久久久 | 亚洲欧美精品 | 欧美一级欧美三级在线观看 | 永久免费网站 | 亚洲欧美综合乱码精品成人网 | 综合网日韩| 成人免费视频网站在线观看 | 91精品视频在线 | 男女免费在线观看视频 | 成人精品视频免费 | 成人在线免费观看 |