国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

SpringBoot接收接口入參的方式小結

 更新時間:2024年01月10日 10:01:15   作者:象牙酥  
這篇文章主要給大家介紹了SpringBoot接收接口入參的幾種方式,我們從調用方的視角去看待這個問題,對調用方來說,它在調用接口時有好幾種傳參方式,下面,將會依次對這幾種參數方式進行講解和代碼示例,需要的朋友可以參考下

引言

我們從調用方的視角去看待這個問題,對調用方來說,它在調用接口時有如下的幾種傳參方式:

Query參數。表現形式是調用方在調用接口時,入參是拼接在接口的URI后面的,如/test_get/requestparam_1?name=wangwu&age=18。這種方式在入參個數比較少GET請求方式中比較常用。

Path參數。這是REST風格的路徑參數,入參直接拼接在接口的URI里面,如/test_pathvar/test1/zhangsan/1,其中的zhangsan1就是就是參數。這種方式在REST風格的接口中比較常用。

Body參數。這種方式是把入參放在了請求體當中!它跟前兩種入參方式的最大區(qū)別,就是:

1)前兩種入參方式它們的入參都是直接體現在了調用接口時候的URI

2)而當前的這種Body參數方式,它的入參是放在了Body請求體

而且,Body參數又可以細分成如下的幾種方式:

application/json 前后端分離項目中常用的傳參方式

x-www-form-urlencoded 上傳表單數據

form-data 上傳表單數據

raw

binary

另外需要強調的是,無論是GET、POST、PUT還是DELETE請求方式,從技術上來說,它們是都支持上面提到的幾種傳參方式的!只不過在日常的開發(fā)中,我們可能習慣了GET+Query參數或者POST+Body參數(application/json)這樣的搭配使用方式

下面,將會依次對這幾種參數方式進行講解和代碼示例。

重要說明

項目的pom依賴

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.9.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--Hutool是一個小而全的Java工具類庫-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.6.3</version>
        </dependency>
        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.30</version>
        </dependency>
        <!--fastjson-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.6</version>
        </dependency>
    </dependencies>

代碼的說明

  • 下面所有接口的定義,使用的都是@RequestMapping,且都沒有指定具體的請求類型——如此故意為之就是為了使得接口從技術上支持各種請求方式(GET POST PUT DELETE等),好方便測試在不同的請求方式下,是否支持各種不同的傳參方式。但是大家在平日的業(yè)務代碼開發(fā)中,最好是在接口定義時指定特定的請求方式。
  • 在下面所有的代碼中,我都在方法定義的形參中加上了HttpServletRequest,是因為我要從HttpServletRequest中獲取請求的方法類型(request.getMethod())和URI( request.getRequestURI()),從而在接口的返回結果在顯現出來,以方便調試。
  • 大家在自己實際的業(yè)務代碼中可以根據自身需求決定是否加上這個。不加也不影響入參的接收!
  • 下面所以接口的定義中,方法返回類型都是string類型,如:
method: [DELETE], uri: [/test_query/requestparam_1], param type: [Query]  ---> SUCCESS! requestParam1 name = wangwu-delete, age = 18

但是看后面調用方調用接口的返回結果,卻是如下所示的json串:

{
    "code": 0,
    "data": "method: [DELETE], uri: [/test_query/requestparam_1], param type: [Query]  ---> SUCCESS! requestParam1 name = wangwu-delete, age = 18",
    "msg": "操作成功",
    "timestamp": 1704766444205
}

可以看到方法返回的String內容則是在json串的data這個key當中。
這是因為在我的項目中,我結合@RestControllerAdviceResponseBodyAdvice,對接口返回結果進行了統(tǒng)一的處理。(核心的處理邏輯是:如果接口返回結果類型已經是指定的ResultVO,直接返回;否則將接口返回結果封裝到ResultVO對象的data字段中,再返回。)

4. 本文旨在展示在各種請求方式下對不同傳參方式的支持情況,因此下面代碼中,都沒有對接口入參進行任何的校驗——即:校驗不是本文的重點,關于接口入參的校驗,可以去看我的另一篇博客。

1.Query參數

Query參數,表現形式是調用方在調用接口時,入參是拼接在接口的URI后面的,如/test_query/requestparam_1?name=wangwu&age=18。

1.1接口定義方式1:在方法形參的位置,把每個參數都平鋪開來

  • 定義方式: 在方法形參的位置,把每個參數都平鋪開來
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:雖然這種傳參方式,從技術上來說可用于GET POST PUT DELETE等請求方式,但是在日常開發(fā)中一般偏向于應用在入參個數少(一般少于5個)GET請求方式中
  • 優(yōu)點:方便簡單
  • 缺點:
    • 調用時入參直接顯示在uri中,不太安全
    • 方法定義時參數個數如果過多,方法體結構會顯得很臃腫
    • 沒有入參校驗

代碼

package com.su.demo.controller.param_type;

import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Date;


@RestController
@RequestMapping(value = "/param_type/query")
public class TestQueryController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:Query參數
     *     <li><b>定義方式</b>: 在方法形參的位置,把每個參數都平鋪開來</li>
     *     <li><b>調用方式</b>: 入參拼接在接口的uri后面,如 /test_get/requestparam_1?name=wangwu&age=18</li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:雖然這種傳參方式,適用于GET POST PUT DELETE等請求方式,但是一般偏向于應用在 入參個數少(一般少于5個)的<b>GET</b>請求方式中</li>
     *     <li><b>優(yōu)點</b>:方便簡單</li>
     *     <li><b>缺點</b>:1) 入參直接顯示在uri中,不太安全 2)參數個數如果過多,方法體結構會顯得很臃腫; 3)沒有入參校驗</li>
     * </ul>
     * <p><b>注意</b>:根據自己的需求決定是否在形參中加上HttpServletRequest,我這里是為了從request中獲取method,所以加上了</p>
     */
    @RequestMapping(value = "/test1")
    public String test1(String name, Integer age, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age;
    }

}

調用case

注意看上面這個/param_type/query/test1接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以GET 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

發(fā)起請求:

在這里插入圖片描述

接口返回結果:

在這里插入圖片描述

1.2接口定義方式2:在方法形參的位置,結合@RequestParam把每個參數都平鋪開來

  • 定義方式: 在方法形參的位置,結合@RequestParam把每個參數都平鋪開來
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:雖然這種傳參方式,從技術上來說可用于GET POST PUT DELETE等請求方式,但是在日常開發(fā)中一般偏向于應用在入參個數少(一般少于5個)GET請求方式中
  • 優(yōu)點:方便簡單,且結合@RequestParam,可實現入參的必填校驗/重命名/默認值等簡單的校驗功能
  • 缺點:
    • 調用時入參直接顯示在uri中,不太安全
    • 方法定義時如果參數個數如果過多,方法體結構會顯得很臃腫
    • @RequestParam能支持的校驗相對來說還是比較簡單

代碼

package com.su.demo.controller.param_type;

import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Date;

@RestController
@RequestMapping(value = "/param_type/query")
public class TestQueryController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:Query參數
     *     <li><b>定義方式</b>: 在方法形參的位置,把每個參數都平鋪開來.并且相較于前一種定義方式,這種方式使用 {@link RequestParam}綁定請求參數到方法形參, 且需要注意該注解中的各個屬性的作用!</li>
     *     <li><b>調用方式</b>: 入參拼接在接口的uri后面,如 /test_get/requestparam_1?name=wangwu&age=18</li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:雖然這種傳參方式,適用于GET POST PUT DELETE等請求方式,但是一般偏向于應用在 入參個數少(一般少于5個)的<b>GET</b>請求方式中</li>
     *     <li><b>優(yōu)點</b>:方便簡單;且結合{@link RequestParam},可實現入參的必填校驗/重命名/默認值等簡單的功能</li>
     *     <li><b>缺點</b>:1) 入參直接顯示在uri中,不太安全
     *                    2)參數個數如果過多,方法體結構會顯得很臃腫(當前這個方法有4個入參,其實就已經有點臃腫了)
     *                    3){@link RequestParam}能支持的校驗相對來說還是比較簡單</li>
     * </ul>
     */
    @RequestMapping(value = "/test2_requestparam")
    public String test2(@RequestParam String name,
                                @RequestParam(name = "newAge") Integer age,
                                @RequestParam(name = "birth", required = false) @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") Date birth,
                                @RequestParam(defaultValue = "true") Boolean enable,
                                HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age + ", birth = " + birth + ", enable = " + enable;
    }

}

調用case

注意看上面這個/param_type/query/test2_requestparam接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以GET 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

1.3接口定義方式3:把入參封裝到一個實體中

  • 定義方式: 把入參封裝到一個實體中
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:雖然這種傳參方式,從技術上來說可用于GET POST PUT DELETE等請求方式,但是在日常開發(fā)中一般偏向于應用在入參個數多(一般大于5個)GET請求方式中
  • 優(yōu)點:因為參數都封裝在實體對象當中了,所以對參數的個數就沒有什么的限制了,接口定義的時候方便多了
  • 缺點:對于這種入參的定義方式來說,它是沒有什么缺點的,硬要說缺點的話,其實是針對Query這種傳參方式來說的,即:當參數個數一多的時候,參數都放在請求uri中了,一個是不太安全,另外也容易造成uri的長度過過長 (雖然http協(xié)議中未明確對url進行長度限制,但在真正實現中,url的長度還是受到限制的,一是服務器端的限制,二就是游覽器端的限制)

注:再次申明,在下面代碼中,我在方法定義的形參中加上了HttpServletRequest,是因為我要從HttpServletRequest中獲取請求的方法類型(request.getMethod())和URI( request.getRequestURI()),從而在接口的返回結果在顯現出來,以方便調試。
大家在自己實際的業(yè)務代碼中可以根據自身需求決定是否加上這個。不加也不影響入參的接收!

代碼

package com.su.demo.controller.param_type;

import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Date;

@RestController
@RequestMapping(value = "/param_type/query")
public class TestQueryController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:Query參數
     *     <li><b>定義方式</b>: 把入參封裝到一個實體中(入參個數多于5個時一般用這種方式)
     *     <li><b>調用方式</b>: 入參拼接在接口的uri后面,如 /test_get/requestparam_1?name=wangwu&age=18</li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說這種傳參方式,同時適用于GET POST PUT DELETE等多種請求方式,但是一般我個從偏向于在入參個數大于5個的<b>GET</b>請求方式中使用</li>
     *     <li><b>優(yōu)點</b>:因為參數都封裝在實體bean當中了,所以對參數的個數就沒有什么的限制了,接口定義的時候方便多了
     *     <li><b>缺點</b>:對于這種入參的[定義方式]來說,它是沒有什么缺點的.硬要說缺點的話,其實是針對Query這種傳參方式來說的,即當參數個數一多的時候,參數都放在請求uri中容易造成uri的長度過過長
     *     (雖然http協(xié)議中未明確對url進行長度限制,但在真正實現中,url的長度還是受到限制的,一是服務器端的限制,二就是游覽器端的限制)</li>
     * </ul>
     */
    @RequestMapping(value = "/test3_entity")
    public String test3(UserDTO userDTO, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! userDTO = " + userDTO;
    }

}

其中UserDTO 的代碼如下:

package com.su.demo.bean.dto;

import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;
import java.util.Date;

@Data
public class UserDTO {
    /**
     * 主鍵ID
     */
    private Long id;

    /**
     * 用戶姓名
     */
    private String name;

    /**
     * 用戶狀態(tài) true:啟用;false:禁用
     */
    private Boolean enable;

    /**
     * 用戶生日
     */
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date birth;
}

調用case

注意看上面這個/param_type/query/test3_entity接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以POST 請求方式的調用結果為例,看是否可以在controller代碼中獲到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

1.4接口定義方式4:用原生的HttpServletRequest接收參數

  • 定義方式: 在方式形參的位置,用原生的HttpServletRequest接收
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:現在很少用這種方式去接收入參了。
  • 優(yōu)點:HttpServletRequest是整個請求,可以獲取到所有的數據.且HttpServletRequest、HttpServletResponse都是內置對象,可以使用
  • 缺點:代碼中再去從request中拿到參數,比較麻煩

代碼

package com.su.demo.controller.param_type;

import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Date;

@RestController
@RequestMapping(value = "/param_type/query")
public class TestQueryController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:Query參數
     *     <li><b>定義方式</b>: 在方式形參的位置,用原生的{@link HttpServletRequest}接收
     *     <li><b>調用方式</b>: 入參拼接在接口的uri后面,如 /test_get/requestparam_1?name=wangwu&age=18</li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下比較少用這種方式來獲取參數了</li>
     *     <li><b>優(yōu)點</b>:{@link HttpServletRequest}是整個請求,可以獲取到所有的數據.且HttpServletRequest、HttpServletResponse都是內置對象,可以使用</li>
     *     <li><b>缺點</b>:代碼中再去從request中拿到參數,比較麻煩</li>
     * </ul>
     * <p> 注意,這種方式其實也可以獲取body請求體里面的數據,參考https://blog.csdn.net/qq_24850045/article/details/121927722
     */
    @RequestMapping(value = "/test4_request")
    public String test4(HttpServletRequest request) throws IOException {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        String name = request.getParameter("name");
        Integer age = Integer.parseInt(request.getParameter("age")); // 需要進行類型轉換

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = "  + age;
    }

}

調用case

注意看上面這個/param_type/query/test4_request接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以PUT 請求方式的調用結果為例,看是否可以在controller代碼中獲到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

1.5接口定義方式5:用Map結合RequestParam接收參數

  • 定義方式: 在方式形參的位置,用Map結合RequestParam接收參數
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:適用于參數個數較多,但是自己又想偷懶不想專門定義一個實體來接收入參的場景。一般不推薦使用這種方式。
  • 優(yōu)點:簡單方便,偷懶很開心
  • 缺點:1)需要在代碼中通過指定特定的key的方式去獲取入參,比較麻煩;2)利用map去get到入參之后,還需要手動的去做非空判斷+數據類型轉換等,很麻煩;3)而且這種接收入參的方式,沒有辦法結合org.springframework.validation.annotation.Validated來做入參校驗!

代碼

package com.su.demo.controller.param_type;

import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Date;

@RestController
@RequestMapping(value = "/param_type/query")
public class TestQueryController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:Query參數
     *     <li><b>定義方式</b>: 在方式形參的位置,結合{@link RequestParam}用Map接收
     *     <li><b>調用方式</b>: 入參拼接在接口的uri后面,如 /test_get/requestparam_1?name=wangwu&age=18</li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:適用于參數個數較多,但是自己又想偷懶不想專門定義一個實體來接收入參的場景。一般不推薦使用這種方式。</li>
     *     <li><b>優(yōu)點</b>:簡單方便</li>
     *     <li><b>缺點</b>:需要在代碼中通過指定特定的key的方式去獲取入參,比較麻煩;而且這種接收入參的方式,沒有辦法結合{@link org.springframework.validation.annotation.Validated}來做入參校驗</li>
     * </ul>
     */
    @RequestMapping(value = "/test5_map")
    public String test5(@RequestParam Map<String, String> paramMap, HttpServletRequest request) throws IOException {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        String name = paramMap.get("name");
        // 判斷:如果paramMap.get("age")為null,則age賦默認值0;否則進行入參類型的轉換
        Integer age = null == paramMap.get("age") ? 0: Integer.parseInt(paramMap.get("age"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = "  + age;
    }

}

調用case

注意看上面這個/param_type/query/test5_map接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以DELETE 請求方式的調用結果為例,看是否可以在controller代碼中獲到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

2.Path參數

Path參數,表現形式是入參直接拼接在接口的URI里面,如/test_pathvar/test1/zhangsan/1,其中的zhangsan1就是就是參數。這種方式在REST風格的接口中比較常用。

REST(英文:Representational State Transfer,簡稱REST,意思:表述性狀態(tài)轉換,描述了一個架構樣式的網絡系統(tǒng),比如web應用),一定要記住==它是一種軟件架構風格!而不是標準!==它只是提供了一組設計原則和約束條件。它主要用于客戶端和服務器交互類的軟件?;谶@個風格設計的軟件可以更簡潔,更有層次,更易于實現緩存等機制。
REST指的是一組架構(約束條件)和原則。滿足這些(約束條件)和(原則)的應用程序或設計就是 Restful。

2.1接口定義方式:用占位符的方式把入參封裝到請求路徑中

  • 定義方式: 用占位符的方式把入參封裝到請求路徑中,然后再通過@PathVariable注解可以將URL中的占位符參數綁定到控制器(controller)處理方法的形參中
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等多種請求方式。 但是一般入參個數較少,且你開發(fā)的是REST風格的接口,那可以考慮用這種方式
  • 優(yōu)點和缺點:優(yōu)點和缺點,其實就是REST風格的接口的優(yōu)點和缺點了,大家可以自行去查閱

代碼

package com.su.demo.controller.param_type;

import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest;

@RestController
@RequestMapping(value = "/param_type/path_variable")
public class TestPathVarController {


    /**
     * <ul>
     *     <li><b>入參類別</b>:PathVariable路徑參數方式
     *     <li><b>定義方式</b>: 用占位符的方式把入參封裝到請求路徑中,然后再通過@PathVariable注解可以將URL中的占位符參數綁定到控制器(controller)處理方法的形參中. </li>
     *     <li><b>調用方式</b>: REST風格路徑參數,入參拼接在接口的URI里面,如/test_pathvar/test1/zhangsan/1 </li>
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等多種請求方式.
     *         但是一般入參個數小于5個,且你開發(fā)的是REST風格的接口,那可以考慮用這種方式
     *         </li>
     * </ul>
     * <p>REST(英文:Representational State Transfer,簡稱REST,意思:表述性狀態(tài)轉換,描述了一個架構樣式的網絡系統(tǒng),比如web應用),是一種軟件架構風格不是標準哦!
     * 只是提供了一組設計原則和約束條件。它主要用于客戶端和服務器交互類的軟件?;谶@個風格設計的軟件可以更簡潔,更有層次,更易于實現緩存等機制。
     * REST 指的是一組架構(約束條件)和原則。滿足這些(約束條件)和(原則)的應用程序或設計就是 Restful。</p>
     */
    @RequestMapping(value = "/test1/{name}/{age}")
    public String test1(@PathVariable("name") String name, @PathVariable("age") Integer myage, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));
        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", myage = "  + myage;
    }
}

調用case

注意看上面這個/param_type/path_variable/test1/{name}/{age}接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以GET 請求方式的調用結果為例,看是否可以在controller代碼中獲到調用方傳過來的實參。

可以看到,參數都獲取到了。

3.Body參數

Body參數,這種方式是把入參放在了請求體當中!它跟前兩種入參方式的最大區(qū)別,就是:

  1. 前兩種入參方式它們的入參都是直接體現在了調用接口時候的URI
  2. 而當前的這種Body參數方式,它的入參是放在了http請求的請求體
    而且,Body參數又可以細分成如下的幾種方式:
    • application/json 前后端分離項目中常用的傳參方式
    • form-data
    • x-www-form-urlencoded
    • raw
    • binary

下面分別進行說明

3.1 application/json

這種入參方式,入參放在http請求的請求體當中,并且Content-Type=application/json

3.1.1 接口定義方式1:在方式形參的位置,用原生的HttpServletRequest接收

  • 定義方式: 在方式形參的位置,用原生的HttpServletRequest接收
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下比較少用這種方式來獲取Content-Type=application/json的body參數了
  • 優(yōu)點:HttpServletRequest是整個請求,可以獲取到所有的數據。且HttpServletRequest、HttpServletResponse都是內置對象,可以使用
  • 缺點:碼中再去從request中拿到參數,老麻煩了,可以看下面的代碼

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.alibaba.fastjson.JSON;
import com.su.demo.bean.dto.UserDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@RestController
@RequestMapping(value = "/param_type/body_json")
public class TestBodyController {


    /**
     * <ul>
     *     <li><b>入參類別</b>:body參數方式
     *     <li><b>定義方式</b>: 在方式形參的位置,用原生的{@link HttpServletRequest}接收
     *     <li><b>調用方式</b>: 參數放在請求體 body 當中
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下比較少用這種方式來獲取body參數了</li>
     *     <li><b>優(yōu)點</b>:{@link HttpServletRequest}是整個請求,可以獲取到所有的數據.且HttpServletRequest、HttpServletResponse都是內置對象,可以使用</li>
     *     <li><b>缺點</b>:代碼中再去從request中拿到參數,老麻煩,可以看下面的代碼</li>
     * </ul>
     * <p> 注意,這種方式其實也可以獲取body請求體里面的數據,參考https://blog.csdn.net/qq_24850045/article/details/121927722
     */
    @RequestMapping(value = "/test1_request")
    public String test1(HttpServletRequest request) throws IOException {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        ServletInputStream inputStream = request.getInputStream();
        // 用hutool工具包的read方式,將inputStream讀取成string
        String body = IoUtil.read(inputStream, "UTF-8");
        System.out.println("body = " + body);
        // 用fastjson將json字符串轉換成bean
        UserDTO userDTO = JSON.parseObject(body, UserDTO.class);

        return requestMetaInfo + " ---> SUCCESS! userDTO = " + userDTO;
    }
}

其中UserDTO的代碼如下:

package com.su.demo.bean.dto;

import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.util.Date;

@Data
public class UserDTO {
    /**
     * 主鍵ID
     */
    private Long id;

    /**
     * 用戶姓名
     */
    private String name;

    /**
     * 用戶狀態(tài) true:啟用;false:禁用
     */
    private Boolean enable;

    /**
     * 用戶生日
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private Date birth;
}

調用case

注意看上面這個/param_type/body_json/test1_request接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以POST 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.1.2 接口定義方式2:在方式形參的位置,用RequestBody接收

  • 定義方式: 在在方式形參的位置,用RequestBody接收
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下一般用在POST或 PUT 請求中
  • 優(yōu)點:
    • 方法形參的定義非常簡潔;
    • 調用的時候參數放在body中,參數體可以很大,不像Query入參方式在當參數過多的時候容易觸發(fā)服務器端Request header is too large的報錯
  • 缺點:用String類型來接收參數,接收之后再轉換成bean實體,還是稍微顯得有點麻煩

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.alibaba.fastjson.JSON;
import com.su.demo.bean.dto.UserDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@RestController
@RequestMapping(value = "/param_type/body_json")
public class TestBodyController {

   /**
     * <ul>
     *     <li><b>入參類別</b>:body參數方式
     *     <li><b>定義方式</b>: 在方式形參的位置,用{@link RequestBody}接收
     *     <li><b>調用方式</b>: 參數放在請求體 body 當中
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下一般用在POST或PUT請求中</li>
     *     <li><b>優(yōu)點</b>:1)方法形參的定義非常簡潔;
     *                  2)調用的時候參數放在body中,參數體可以很大,不像Query入參方式在當參數過多的時候容易觸發(fā)服務器端"Request header is too large"的報錯
     *         </li>
     *     <li><b>缺點</b>:用String類型來接收參數,接收之后再轉換成bean實體,還是稍微顯得有點麻煩</li>
     * </ul>
     */
    @RequestMapping(value = "/test2_requestbody_string")
    public String test2(@RequestBody String body, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        System.out.println("body = " + body);
        // 用fastjson將json字符串轉換成bean
        UserDTO userDTO = JSON.parseObject(body, UserDTO.class);

        return requestMetaInfo + " ---> SUCCESS! userDTO = " + userDTO;
    }

}

調用case

注意看上面這個/param_type/body_json/test2_requestbody_string接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以PUT 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.1.3 接口定義方式3:用一個實例來接收RequestBody入參

  • 定義方式: 在方式形參的位置,用RequestBody接收,而且是直接用一個實例類來接收了(spring自動調用相應的org.springframework.http.converter.HttpMessageConverter去做了入參的轉換)
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下一般用在POST或 PUT 請求中
  • 優(yōu)點:
    • 方法形參的定義非常簡潔;
    • 調用的時候參數放在body中,參數體可以很大,不像Query入參方式在當參數過多的時候容易觸發(fā)服務器端Request header is too large的報錯
  • 缺點:好像沒啥缺點

工作中前后端分離項目一般用這用方式比較多

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.alibaba.fastjson.JSON;
import com.su.demo.bean.dto.UserDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@RestController
@RequestMapping(value = "/param_type/body_json")
public class TestBodyController {

    /**
     * <ul>
     *     <li><b>入參類別</b>:body參數方式
     *     <li><b>定義方式</b>: 在方式形參的位置,用{@link RequestBody}接收,
     *         而且是直接用一個實例類來接收了(spring自動調用相應的{@link org.springframework.http.converter.HttpMessageConverter}去做轉換)
     *         </li>
     *     <li><b>調用方式</b>: 參數放在請求體 body 當中
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,但是正常情況下一般用在POST或PUT請求中</li>
     *     <li><b>優(yōu)點</b>:1)方法形參的定義非常簡潔;
     *                  2)調用的時候參數放在body中,參數體可以很大,不像Query入參方式在當參數過多的時候容易觸發(fā)服務器端"Request header is too large"的報錯
     *         </li>
     *     <li><b>缺點</b>:好像沒啥缺點</li>
     * </ul>
     */
    @RequestMapping(value = "/test3_requestbody_entity")
    public String test3(@RequestBody UserDTO userDTO, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! userDTO = " + userDTO;
    }

}

調用case

注意看上面這個/param_type/body_json/test3_requestbody_entity接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以DELETE 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.1.4 接口定義方式4:用Map來接收RequestBody入參

  • 定義方式: 在方式形參的位置,用RequestBody接收,而且是直接用一個Map的實例類來接收了
  • 兼容的請求方式GET POST PUT DELETE
  • 適用場景:適用于參數個數較多,但是自己又想偷懶不想專門定義一個實體來接收入參的場景。一般不推薦使用這種方式
  • 優(yōu)點:簡單方便,偷懶很開心
  • 缺點:1)需要在代碼中通過指定特定的key的方式去獲取入參,比較麻煩;2)利用map去get到入參之后,還需要手動的去做非空判斷+數據類型轉換等,很麻煩;3)而且這種接收入參的方式,沒有辦法結合org.springframework.validation.annotation.Validated來做入參校驗!

一般不推薦使用這種方式

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.alibaba.fastjson.JSON;
import com.su.demo.bean.dto.UserDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

@RestController
@RequestMapping(value = "/param_type/body_json")
public class TestBodyController {

   /**
     * <ul>
     *     <li><b>入參類別</b>:body參數方式
     *     <li><b>定義方式</b>: 在方式形參的位置,用{@link RequestBody}接收,
     *         而且是直接用一個Map對象實例類來接收了(spring自動調用相應的{@link org.springframework.http.converter.HttpMessageConverter}去做轉換)
     *         </li>
     *     <li><b>調用方式</b>: 參數放在請求體 body 當中
     *     <li><b>兼容的請求方式</b>:GET POST PUT DELETE</li>
     *     <li><b>適用場景</b>:從技術上來說,這種傳參方式同時適用于GET POST PUT DELETE等請求方式,一般使用在偷懶不想專門定義一個實體來接收入參的場景。一不太推薦使用這種方式/li>
     *     <li><b>優(yōu)點</b>:1)方法形參的定義非常簡潔;
     *                  2)調用的時候參數放在body中,參數體可以很大,不像Query入參方式在當參數過多的時候容易觸發(fā)服務器端"Request header is too large"的報錯
     *         </li>
     *     <li><b>缺點</b>:好像沒啥缺點</li>
     * </ul>
     */
    @RequestMapping(value = "/test4_requestbody_map")
    public String test4(@RequestBody Map<String, String> paramMap, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        String name = paramMap.get("name");
        // 判斷:如果paramMap.get("age")為null,則age賦默認值0;否則進行入參類型的轉換
        Integer age = null == paramMap.get("age") ? 0: Integer.parseInt(paramMap.get("age"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age;
    }

}

調用case

注意看上面這個/param_type/body_json/test4_requestbody_map接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證),為了節(jié)約文章篇幅,下面只以POST 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.2 x-www-form-urlencoded

x-www-form-urlencodedform-data,兩者都可以用來上傳前端表單數據,下面簡單將兩者的不同列舉出來

1.支持的入參類型不同: x-www-form-urlencoded只支持普通的文本內容,不支持上傳File文件!而form-data則支持上傳File文件(如圖片、音頻、視頻)。

2. 編碼不同: x-www-form-urlencoded的編碼方式就隱藏在名字里urlencoded,即使用js中encodeURI()函數;而form-data的格式,要比 x-www-form-urlencoded復雜的多,它會把內容分成多個部分,每個部分都支持不同的格式

3. x-www-form-urlencoded占用字節(jié)少,form-data占用字節(jié)多

x-www-form-urlencoded會將表單內的數據轉換為鍵值對,比如name=lisi&age=23,并放在請求體body中進行傳輸

3.2.1 接口定義方式1:在方法形參的位置,把每個參數都平鋪開來

  • 定義方式: 方法形參的位置,把每個參數都平鋪開來,也可以使用@RequestParam注解
  • 兼容的請求方式POST PUT DELETE,注意,不兼容GET請示方式
  • 適用場景:雖然這種傳參方式,適用于POST PUT DELETE等請求方式,但是一般偏向于應用在 用POST或 PUT方式去發(fā)送的表單數據,且參數個數少,且表單字段都是普通類型(即表單字段不是File文件)
  • 優(yōu)點:方便簡單
  • 缺點:1)參數個數如果過多,方法體結構會顯得很臃腫

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.su.demo.bean.dto.TeacherDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.net.URLDecoder;
import java.util.Map;

@RestController
@RequestMapping(value = "/param_type/body_form_urlencoded")
public class TestFormUrlEncodeController {

    /**
     * <p>注意,如果使用GET請求方式,則后端獲取不到入參?。。?lt;/p>
     * <ul>
     *     <li><b>入參類別</b>:表單參數方式,Content-Type=application/x-www-form-urlencoded
     *     <li><b>定義方式</b>: 在方法形參的位置,把每個參數都平鋪開來</li>
     *     <li><b>調用方式</b>: 入參放在表單中,且Content-Type=application/x-www-form-urlencoded</li>
     *     <li><b>兼容的請求方式</b>:POST PUT DELETE</li>
     *     <li><b>適用場景</b>:雖然這種傳參方式,適用于POST PUT DELETE等請求方式,但是一般偏向于應用在 用<b>POST</b>或b>PUT</b>方式去發(fā)送的表單數據,且參數個數少,且表單字段都是普通類型(即表單字段不是File文件),</li>
     *     <li><b>優(yōu)點</b>:方便簡單</li>
     *     <li><b>缺點</b>:1)參數個數如果過多,方法體結構會顯得很臃腫</li>
     * </ul>
     */
    @RequestMapping(value = "/test1_requestparam")
    public String test1(String name, @RequestParam(name = "age", required = false) Integer age, Boolean enable, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age + ", enable = " + enable;
    }
}

調用case

注意看上面這個/param_type/body_form_urlencoded/test1_requestparam接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證)——經過實測發(fā)現,當請示方式為GET 的時候,后端代碼獲取不到入參!而當請求方式為POST PUT DELETE的時候,后端可以獲取到入參。
下面是示例

GET,傳參失敗

在這里插入圖片描述

可以看到,沒有獲取到入參!

POST PUT DELETE 傳參成功

為了節(jié)約文章篇幅,下面只以POST 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.2.2 接口定義方式2:用一個實例來接收入參

  • 定義方式: 把入參封裝到一個實體中,且實體一定不能使用@RequestParam@RequestBody注解修飾
  • 兼容的請求方式POST PUT DELETE,注意,不兼容GET請示方式
  • 適用場景:雖然這種傳參方式,適用于POST PUT DELETE等請求方式,但是一般偏向于應用在 用POSTPUT方式去發(fā)送的表單數據,且表單字段都是普通類型(即表單字段不是File文件)
  • 優(yōu)點:方便簡單,不管表單字段個個數多或少,一般如果表單字段類型沒有File文件類型的,都可以使用這種方式
  • 缺點:缺點的話就是針對Content-Type=application/x-www-form-urlencoded這種入參方式來說了:不能上傳文件

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.su.demo.bean.dto.TeacherDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.net.URLDecoder;
import java.util.Map;

@RestController
@RequestMapping(value = "/param_type/body_form_urlencoded")
public class TestFormUrlEncodeController {

    /**
     * <p>注意,如果使用GET請求方式,則后端獲取不到入參?。。≈恢С諴OST PUT DELETE</p>
     * <p>且形參定義那里,一定不能使用{@link RequestParam}修飾</p>
     * <ul>
     *     <li><b>入參類別</b>:表單參數方式,Content-Type=application/x-www-form-urlencoded
     *     <li><b>定義方式</b>: 把入參封裝到一個實體中(入參個數多于5個時一般用這種方式)</li>
     *     <li><b>調用方式</b>: 入參放在表單中,且Content-Type=application/x-www-form-urlencoded</li>
     *     <li><b>兼容的請求方式</b>:POST PUT DELETE</li>
     *     <li><b>適用場景</b>:雖然這種傳參方式,適用于POST PUT DELETE等請求方式,但是一般偏向于應用在 用<b>POST</b>或<b>PUT</b>方式去發(fā)送的表單數據,且表單字段都是普通類型(即表單字段不是File文件),</li>
     *     <li><b>優(yōu)點</b>:方便簡單,不管表單字段個個數多或少,一般如果表單字段類型沒有File文件類型的,都可以使用這種方式</li>
     *     <li><b>缺點</b>:缺點的話就是針對Content-Type=application/x-www-form-urlencoded這種入參方式來說了:不能上傳文件</li>
     * </ul>
     */
    @RequestMapping(value = "/test2_entity")
    public String test2(TeacherDTO teacherDTO, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        return requestMetaInfo + " ---> SUCCESS! teacherDTO = " + teacherDTO;
    }

}

調用case

注意看上面這個/param_type/body_form_urlencoded/test2_entity接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證)——經過實測發(fā)現,當請示方式為GET 的時候,后端代碼獲取不到入參!而當請求方式為POST PUT DELETE的時候,后端可以獲取到入參。
下面是示例

GET,傳參失敗

在這里插入圖片描述

可以看到,沒有獲取到入參!

POST PUT DELETE 傳參成功

為了節(jié)約文章篇幅,下面只以PUT 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,參數都獲取到了。

3.2.3 接口定義方式3:用原生的HttpServletRequest接收參數

  • 定義方式: 用原生的HttpServletRequest接收參數
  • 兼容的請求方式POST PUT DELETE,注意,不兼容GET請示方式
  • 適用場景:由于當請求的Content-Type=application/x-www-form-urlencoded時,只支持GET請求方式,并且即使是GET請求方式能獲取到入參了,之后的校驗和處理也很麻煩,所以一般不用這種方式來接收Content-Type=application/x-www-form-urlencoded的請求
  • 優(yōu)點:方便簡單,且這接收入參的方式,直接調用方用GET的請求方式傳參
  • 缺點:
    • 1)需要自己在代碼中顯式的從request的inputStream流【獲取+轉換+解碼】數據,很麻煩
    • 2)如果請求方式是POST PUT DELETE等,同時Content-Type=application/x-www-form-urlencoded,則無法將入參傳到后面代碼中!

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.su.demo.bean.dto.TeacherDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.net.URLDecoder;
import java.util.Map;

@RestController
@RequestMapping(value = "/param_type/body_form_urlencoded")
public class TestFormUrlEncodeController {

    /**
     * <p>注意,只支持GET請求方式,如果使用POST、PUT、DELETE請求方式,則后端獲取不到入參?。?!</p>
     * <ul>
     *     <li><b>入參類別</b>:表單參數方式,Content-Type=application/x-www-form-urlencoded
     *     <li><b>定義方式</b>: 在方法形參的位置,用{@link HttpServletRequest}來接收入參</li>
     *     <li><b>調用方式</b>: 入參放在表單中,且Content-Type=application/x-www-form-urlencoded</li>
     *     <li><b>兼容的請求方式</b>:GET</li>
     *     <li><b>適用場景</b>:由于當請求的Content-Type=application/x-www-form-urlencoded時,只支持GET請求方式,
     *     并且即使是GET請求方式能獲取到入參了,之后的校驗和處理也很麻煩,所以一般不用這種方式來接收Content-Type=application/x-www-form-urlencoded的請求</li>
     *     <li><b>優(yōu)點</b>:方便簡單,且這接收入參的方式,直接調用方用GET的請求方式傳參</li>
     *     <li><b>缺點</b>:1)需要自己在代碼中顯式的從request的inputStream流【獲取+轉換+解碼】數據,很麻煩
     *                    2)如果請求方式是POST PUT DELETE等,同時Content-Type=application/x-www-form-urlencoded,則無法將入參傳到后面代碼中!
     *      </li>
     * </ul>
     */
    @RequestMapping(value = "/test3_request")
    public String test3(HttpServletRequest request) throws IOException {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        ServletInputStream inputStream = request.getInputStream();
        String inputStr = IoUtil.read(inputStream, "UTF-8");
        String decodeRes = URLDecoder.decode(inputStr, "UTF-8");

        return requestMetaInfo + " ---> SUCCESS! " + inputStr + ", decodeResult = " + decodeRes;
    }

}

調用case

注意看上面這個/param_type/body_form_urlencoded/test3_request接口的定義方式,它并沒有指定請求方式,因此它支持GET POST PUT DELETE等所有的請求方式(已經過驗證)——但是經過實測發(fā)現,只有當請示方式為GET 的時候,后端代碼才能獲取到入參!而當請求方式為POST PUT DELETE的時候,后端獲取入參失敗。
下面是示例

GET,傳參成功

在這里插入圖片描述

可以看到,獲取到入參!

POST PUT DELETE 傳參失敗

為了節(jié)約文章篇幅,下面只以POST 請求方式的調用結果為例,看是否可以在controller代碼中獲取到調用方傳過來的實參。

在這里插入圖片描述

可以看到,沒有獲取到參數!

3.2.4 (error)接口定義方式4:用Map接收參數

提前說明:這是一種錯誤的定義方式,這種方式,無論是否在map前面添加RequestParam還是RequestBody, 后端代碼都獲取不到 Content-Type=application/x-www-form-urlencoded類型請求的入參?。?!

  • 定義方式: 用Map接收參數

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.su.demo.bean.dto.TeacherDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.net.URLDecoder;
import java.util.Map;

@RestController
@RequestMapping(value = "/param_type/body_form_urlencoded")
public class TestFormUrlEncodeController {

    /**
     * <p>這是一種錯誤的定義方式,這種方式,無論是否在map前面添加{@link RequestParam}還是{@link RequestBody}, 代碼都獲取不到 Content-Type=application/x-www-form-urlencoded類型請求的入參!?。?lt;/p>
     * <ul>
     *     <li><b>入參類別</b>:表單參數方式,Content-Type=application/x-www-form-urlencoded
     *     <li><b>定義方式</b>: 在方法形參的位置,用Map來接收入參</li>
     *     <li><b>調用方式</b>: 入參放在表單中,且Content-Type=application/x-www-form-urlencoded</li>
     * </ul>
     */
    @RequestMapping(value = "/test4_map")
    public String test4(Map<String, String> paramMap, HttpServletRequest request) {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));

        String name = paramMap.get("name");
        // 判斷:如果paramMap.get("age")為null,則age賦默認值0;否則進行入參類型的轉換
        Integer age = null == paramMap.get("age") ? 0: Integer.parseInt(paramMap.get("age"));

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age;
    }

}

調用case

無論哪種請求方式,后端獲取入參都失??!下面以PUT請求方式作為示例
下面是示例

PUT,傳參失敗

在這里插入圖片描述

可以看到,獲取不到入參!

3.2.5 (error)接口定義方式5:每個參數都平鋪開來,并嘗試獲取File文件入參

先說結論,雖然在下面方法定義的,=形參中添加了MultipartFile,但是如果調用接口的時候入參類型是Content-Type=application/x-www-form-urlencoded, 那由于Content-Type=application/x-www-form-urlencoded入參類型限制了入參就無法將【文件】傳過來,所以該方法的MultipartFile對象始終為空!

  • 定義方式: 方法形參的位置,把每個參數都平鋪開來,也可以使用@RequestParam注解,是時嘗試使用MultipartFile類型入參,去接收文件

代碼

package com.su.demo.controller.param_type;

import cn.hutool.core.io.IoUtil;
import com.su.demo.bean.dto.TeacherDTO;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.ServletInputStream;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.net.URLDecoder;
import java.util.Map;

@RestController
@RequestMapping(value = "/param_type/body_form_urlencoded")
public class TestFormUrlEncodeController {

    /**
     * <p>
     *     雖然在方法定義這里,形參中添加了MultipartFile,但是如果調用接口的時候入參類型是Content-Type=application/x-www-form-urlencoded,
     *     那由于Content-Type=application/x-www-form-urlencoded入參類型限制了入參就無法將【文件】傳過來,所以該方法的MultipartFile對象始終為空!
     * </p>
     * <ul>
     *     <li><b>入參類別</b>:表單參數方式,Content-Type=application/x-www-form-urlencoded
     *     <li><b>定義方式</b>: 在方法形參的位置,把每個參數都平鋪開來</li>
     *     <li><b>調用方式</b>: 入參放在表單中,且Content-Type=application/x-www-form-urlencoded</li>
     * </ul>
     */
    @RequestMapping(value = "/test5_requestparam_file")
    public String test5(String name, Integer age, Boolean enable, MultipartFile myfile, HttpServletRequest request) throws IOException {
        // 從request中獲取一些接口請求時的元數據信息,包括請求方式,Content-type等
        String requestMetaInfo = String.format("method: [%s], uri: [%s], Content-Type: [%s] ", request.getMethod(), request.getRequestURI(),  request.getHeader("Content-Type"));
        String fileName = null;
        if (null != myfile) {
            fileName = myfile.getOriginalFilename();
        }

        return requestMetaInfo + " ---> SUCCESS! name = " + name + ", age = " + age + ", enable = " + enable + ", fileName = " + fileName;
    }

}

調用case

實測發(fā)現,不管是哪種請求方式,只要請求的時候Content-Type=application/x-www-form-urlencoded,那都無法將文件傳給后端!
下面是用POST請求方式作示例:

在這里插入圖片描述

以上就是SpringBoot接收接口入參的方式小結的詳細內容,更多關于SpringBoot接收接口入參的資料請關注腳本之家其它相關文章!

相關文章

最新評論

亚洲精品在线资源站| 人妻少妇中文有码精品| 国产伦精品一区二区三区竹菊| 91久久精品色伊人6882| 97青青青手机在线视频| 大香蕉日本伊人中文在线| 色哟哟在线网站入口| 老司机午夜精品视频资源| 人妻无码色噜噜狠狠狠狠色| 人妻丝袜诱惑我操她视频| 欧美地区一二三专区| 天天日天天日天天射天天干| 国产亚洲欧美视频网站| 五十路熟女人妻一区二区9933 | 99久久99一区二区三区| 亚洲成人激情av在线| 91精品激情五月婷婷在线| 成人影片高清在线观看| 超碰在线观看免费在线观看| 亚洲国产成人最新资源| 大香蕉伊人国产在线| 一区二区三区另类在线 | 视频一区 视频二区 视频| 在线不卡成人黄色精品| ka0ri在线视频| 特大黑人巨大xxxx| 中文字幕亚洲久久久| 亚洲少妇人妻无码精品| 一区二区三区 自拍偷拍| 精品亚洲国产中文自在线| 99热99re在线播放| 国产三级精品三级在线不卡| 手机看片福利盒子日韩在线播放| 中文字母永久播放1区2区3区| 少妇人妻100系列| 欧美老妇精品另类不卡片| 1区2区3区4区视频在线观看| 97少妇精品在线观看| 中文字幕av男人天堂| 国产一区二区在线欧美| 欧美viboss性丰满| 国产精品手机在线看片| 成人sm视频在线观看| 日韩av有码一区二区三区4| 日日摸夜夜添夜夜添毛片性色av| 绯色av蜜臀vs少妇| 欧美精品激情在线最新观看视频| 国产综合高清在线观看| 日韩成人免费电影二区| 少妇人妻100系列| 日日夜夜精品一二三| 天天日夜夜操天天摸| 乱亲女秽乱长久久久| 婷婷综合亚洲爱久久| 成人av在线资源网站| 一色桃子久久精品亚洲| 日韩a级精品一区二区| 午夜毛片不卡免费观看视频| 久久这里有免费精品| 成人免费做爰高潮视频| 99精品视频在线观看婷婷| 一区国内二区日韩三区欧美| 青娱乐蜜桃臀av色| 韩国黄色一级二级三级| 欧美成人综合视频一区二区| 国产午夜亚洲精品麻豆| 久草视频在线免播放| 中国视频一区二区三区| 成人激情文学网人妻| 精品人妻每日一部精品| 97超碰国语国产97超碰| 国产一区二区在线欧美| 人妻丝袜榨强中文字幕| 91香蕉成人app下载| 18禁免费av网站| 天天操天天干天天艹| 免费一级特黄特色大片在线观看| 欧美精品一二三视频| 久久久久久久久久久免费女人| 亚洲欧美色一区二区| 女警官打开双腿沦为性奴| 久久精品在线观看一区二区| 亚洲天天干 夜夜操| 日本一区精品视频在线观看| 天堂av在线最新版在线| 精品亚洲国产中文自在线| 亚洲av无乱一区二区三区性色| 久久国产精品精品美女| 美女福利写真在线观看视频| 国产va精品免费观看| 久久精品美女免费视频| 欧美一区二区中文字幕电影| 久久久极品久久蜜桃| 黄片三级三级三级在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 日韩欧美高清免费在线| 亚洲精品国产综合久久久久久久久 | 亚洲2021av天堂| 99re6热在线精品| 黄色三级网站免费下载| 精品一线二线三线日本| 成人蜜臀午夜久久一区| 小穴多水久久精品免费看| 精品一区二区三区午夜| 91一区精品在线观看| 亚洲成人激情av在线| 黄色无码鸡吧操逼视频| 天天日天天干天天要| 亚洲国产第一页在线观看| 亚洲伊人久久精品影院一美女洗澡| 亚洲av午夜免费观看| 欧美老鸡巴日小嫩逼| 日韩在线中文字幕色| 97资源人妻免费在线视频| 国产av一区2区3区| 91精品综合久久久久3d动漫| 熟女国产一区亚洲中文字幕| 欧美女同性恋免费a| 天天操天天操天天碰| 男人和女人激情视频| 伊人情人综合成人久久网小说| 97国产在线av精品| 亚洲一级av大片免费观看| av日韩在线免费播放| 国产免费高清视频视频| 欧美精品激情在线最新观看视频| 亚洲自拍偷拍综合色| 九色视频在线观看免费| 最近中文字幕国产在线| 18禁无翼鸟成人在线| 婷婷五月亚洲综合在线| 午夜激情精品福利视频| 国产精品成久久久久三级蜜臀av| 婷婷综合蜜桃av在线| 国产日韩欧美视频在线导航| 五十路人妻熟女av一区二区| sspd152中文字幕在线| 国产白袜脚足J棉袜在线观看| 日本免费视频午夜福利视频| 中文字幕在线乱码一区二区| 午夜在线精品偷拍一区二| 一色桃子人妻一区二区三区| 少妇一区二区三区久久久| 欧美精品中文字幕久久二区| 97小视频人妻一区二区| 免费黄色成人午夜在线网站| 国产刺激激情美女网站| 少妇人妻100系列| 适合午夜一个人看的视频| 国产视频精品资源网站| 亚洲 中文字幕在线 日韩| 99国内小视频在现欢看| 亚洲成人午夜电影在线观看| 日本人妻少妇18—xx| 色偷偷伊人大杳蕉综合网| 熟女视频一区,二区,三区| 中国熟女@视频91| 最近的中文字幕在线mv视频| 伊拉克及约旦宣布关闭领空| 91在线免费观看成人| 熟女人妻一区二区精品视频| 色综合色综合色综合色| 日本最新一二三区不卡在线| 日本www中文字幕| 超污视频在线观看污污污| 夏目彩春在线中文字幕| 在线可以看的视频你懂的| 亚洲天堂精品久久久| 欧美怡红院视频在线观看| avjpm亚洲伊人久久| 日韩欧美在线观看不卡一区二区| 在线观看的黄色免费网站| 夏目彩春在线中文字幕| 一色桃子人妻一区二区三区| 亚洲色偷偷综合亚洲AV伊人| jiuse91九色视频| 美日韩在线视频免费看| 黄色录像鸡巴插进去| 国产伦精品一区二区三区竹菊| 天天摸天天日天天操| 国产福利在线视频一区| 青青青视频手机在线观看| 在线播放国产黄色av| 美女福利写真在线观看视频| 国产精品自拍偷拍a| 蜜桃久久久久久久人妻| 亚洲av午夜免费观看| 午夜av一区二区三区| 国产精品视频资源在线播放| 久精品人妻一区二区三区| 亚洲 中文 自拍 无码| 国产精品手机在线看片| 中文字幕高清在线免费播放| 亚洲男人让女人爽的视频| 欧美日韩情色在线观看| 日本a级视频老女人| 青娱乐最新视频在线| av手机在线观播放网站| 成人网18免费视频版国产| 色吉吉影音天天干天天操| 东游记中文字幕版哪里可以看到| 38av一区二区三区| 久久精品视频一区二区三区四区| 在线免费观看欧美小视频| 国产黄网站在线观看播放| 丝袜美腿视频诱惑亚洲无| www日韩a级s片av| 亚洲成人三级在线播放| 精品人妻伦一二三区久| 狠狠躁狠狠爱网站视频| av手机免费在线观看高潮| 国产黄色a级三级三级三级| 国产精彩福利精品视频| 精品国产成人亚洲午夜| 久久久久只精品国产三级| 国产成人自拍视频播放| 性色蜜臀av一区二区三区| 老熟妇xxxhd老熟女| 2022精品久久久久久中文字幕| 毛片av在线免费看| 2018最新中文字幕在线观看| 亚洲国产免费av一区二区三区| 韩国女主播精品视频网站| 绝顶痉挛大潮喷高潮无码 | 天天操天天干天天插| 91麻豆精品秘密入口在线观看| 日韩精品电影亚洲一区| 人妻熟女中文字幕aⅴ在线| 欧美另类z0z变态| 国产91嫩草久久成人在线视频| 天天干天天日天天干天天操| 秋霞午夜av福利经典影视| 99re6热在线精品| 在线观看视频一区麻豆| 一区二区三区蜜臀在线| www日韩毛片av| 亚洲 中文 自拍 另类 欧美| 直接观看免费黄网站| 爆乳骚货内射骚货内射在线| 日韩欧美中文国产在线| 天天爽夜夜爽人人爽QC| 天天做天天干天天舔| 青青色国产视频在线| 性欧美激情久久久久久久 | 91中文字幕最新合集| 青青操免费日综合视频观看| 大鸡巴操b视频在线| 久久精品国产999| 经典国语激情内射视频| 亚洲精品国偷自产在线观看蜜桃| 懂色av之国产精品| 欧美3p在线观看一区二区三区| 内射久久久久综合网| 欧美精品欧美极品欧美视频| 久久久久久久精品成人热| 91高清成人在线视频| 超碰公开大香蕉97| 激情人妻校园春色亚洲欧美| 2020国产在线不卡视频| 婷婷久久久综合中文字幕| 国产妇女自拍区在线观看| 欧美日本aⅴ免费视频| 国产亚洲精品视频合集| 91九色porny国产蝌蚪视频| 97a片免费在线观看| 亚洲欧美成人综合视频| 38av一区二区三区| 人妻少妇精品久久久久久| 精品乱子伦一区二区三区免费播 | 红杏久久av人妻一区| 日韩精品激情在线观看| 欧美激情精品在线观看| 一区二区三区美女毛片| 欧美日韩人妻久久精品高清国产| 日韩美女综合中文字幕pp| 人妻丝袜精品中文字幕| 国产综合高清在线观看| 东游记中文字幕版哪里可以看到| 可以在线观看的av中文字幕| 亚洲av可乐操首页| 天天躁日日躁狠狠躁躁欧美av| 国产精品大陆在线2019不卡 | 在线观看欧美黄片一区二区三区 | 青娱乐极品视频青青草| 亚洲熟女女同志女同| 91精品激情五月婷婷在线| 日韩欧美国产一区不卡| 2020韩国午夜女主播在线| 欧美天堂av无线av欧美| 亚洲激情偷拍一区二区| 亚洲av日韩av网站| 亚洲综合在线视频可播放| 亚洲成人情色电影在线观看| 老司机午夜精品视频资源| 男女之间激情网午夜在线| 亚洲中文精品字幕在线观看 | 日韩美av高清在线| 日本熟妇色熟妇在线观看| 天天艹天天干天天操| 天堂va蜜桃一区入口| 青春草视频在线免费播放| 亚洲1区2区3区精华液| 美女福利视频网址导航| 久久久久久久久久一区二区三区| 又黄又刺激的午夜小视频| 精品日产卡一卡二卡国色天香| 色av色婷婷人妻久久久精品高清| 人人妻人人爱人人草| 欧美亚洲免费视频观看| avjpm亚洲伊人久久| 成人av在线资源网站| 四虎永久在线精品免费区二区| 天天摸天天干天天操科普| 亚洲免费福利一区二区三区| 亚洲变态另类色图天堂网| 国产黑丝高跟鞋视频在线播放| 操的小逼流水的文章| 国产高清97在线观看视频| 日视频免费在线观看| 欧美女同性恋免费a| 中文字幕乱码人妻电影| 国产极品精品免费视频| 亚洲成人午夜电影在线观看 | 日韩精品二区一区久久| 1000小视频在线| 天天躁夜夜躁日日躁a麻豆| 粉嫩av蜜乳av蜜臀| 孕妇奶水仑乱A级毛片免费看| 日比视频老公慢点好舒服啊| 色av色婷婷人妻久久久精品高清| 亚洲熟妇无码一区二区三区| 超鹏97历史在线观看| 亚洲第一黄色在线观看| 蜜臀av久久久久蜜臀av麻豆| 亚洲va天堂va国产va久| 国产福利小视频大全| 果冻传媒av一区二区三区| 亚洲国产在人线放午夜| 巨乳人妻日下部加奈被邻居中出| 国产成人精品一区在线观看| 99久久超碰人妻国产| 亚洲成人国产综合一区| 国产精品久久久久久久久福交| 国产精品一区二区三区蜜臀av | 3337p日本欧洲大胆色噜噜| 人人爱人人妻人人澡39| 中文字幕人妻三级在线观看| 亚洲视频在线视频看视频在线| av老司机亚洲一区二区| 大陆av手机在线观看| 日本三极片视频网站观看| 久久久久久九九99精品| 水蜜桃国产一区二区三区| 人人爱人人妻人人澡39| 日本一道二三区视频久久| 国产janese在线播放| 天天干夜夜操天天舔| 日美女屁股黄邑视频| 久久永久免费精品人妻专区| 国产91精品拍在线观看| 中文字幕第1页av一天堂网| 国产熟妇乱妇熟色T区| 2018在线福利视频| 国产又色又刺激在线视频| 国产老熟女伦老熟妇ⅹ| 熟女少妇激情五十路| 色爱av一区二区三区| 蜜臀av久久久久蜜臀av麻豆| 亚洲天堂成人在线观看视频网站| 亚洲午夜福利中文乱码字幕| 伊人情人综合成人久久网小说| 欧美亚洲少妇福利视频| 免费十精品十国产网站| 日本人妻少妇18—xx| 啊慢点鸡巴太大了啊舒服视频| 国产亚洲精品品视频在线| 沈阳熟妇28厘米大战黑人| 四川乱子伦视频国产vip| 亚洲精品久久综合久| 亚洲欧美清纯唯美另类| 成年女人免费播放视频| 伊人情人综合成人久久网小说| 青青青国产免费视频| 欧美精品一二三视频| 天天通天天透天天插| 青青伊人一精品视频| 日本av在线一区二区三区| 人妻熟女中文字幕aⅴ在线| 毛茸茸的大外阴中国视频| 护士小嫩嫩又紧又爽20p| 在线成人日韩av电影| 午夜国产福利在线观看| 亚洲欧美人精品高清| 国产精品国产三级国产午| 美女视频福利免费看| 97少妇精品在线观看| 午夜精品一区二区三区城中村| 亚洲卡1卡2卡三卡四老狼| 国产亚洲精品视频合集| 狠狠躁夜夜躁人人爽天天久天啪| 国产实拍勾搭女技师av在线| 亚洲 中文 自拍 无码| 性欧美激情久久久久久久| 欧美另类重口味极品在线观看| 日本午夜爽爽爽爽爽视频在线观看| 色97视频在线播放| gav成人免费播放| 日本少妇高清视频xxxxx| 亚洲伊人色一综合网| 少妇高潮无套内谢麻豆| 99久久激情婷婷综合五月天| 中国老熟女偷拍第一页| 亚洲一区二区激情在线| 欧美偷拍自拍色图片| 男人靠女人的逼视频| 国产夫妻视频在线观看免费| 欧美精品国产综合久久| 偷拍3456eee| 91精品激情五月婷婷在线| 日韩精品中文字幕在线| 精内国产乱码久久久久久| 在线免费观看国产精品黄色| 美女日逼视频免费观看| 国产+亚洲+欧美+另类| 亚洲国产在人线放午夜| 一区二区三区精品日本| 久草视频在线免播放| av高潮迭起在线观看| 日韩精品啪啪视频一道免费| 欧美黄片精彩在线免费观看| 中文字幕日韩91人妻在线| 少妇与子乱在线观看| 亚洲人妻视频在线网| 无忧传媒在线观看视频| 大鸡巴后入爆操大屁股美女| 女警官打开双腿沦为性奴| 九色视频在线观看免费| 日本成人一区二区不卡免费在线| 五十路在线观看完整版| 99国产精品窥熟女精品| 免费无毒热热热热热热久| 亚国产成人精品久久久| 性色蜜臀av一区二区三区| 福利视频一区二区三区筱慧| 成人网18免费视频版国产| 青青草精品在线视频观看| 做爰视频毛片下载蜜桃视频1 | 亚洲欧洲av天堂综合| 国产精品3p和黑人大战| 日本午夜久久女同精女女| 大鸡吧插入女阴道黄色片| 国产极品精品免费视频 | 2020中文字幕在线播放| 亚洲男人在线天堂网| 自拍偷拍亚洲精品第2页| 蜜桃久久久久久久人妻| 国产精选一区在线播放| 午夜精品久久久久麻豆影视| 天美传媒mv视频在线观看| 性色蜜臀av一区二区三区| 欧美精品亚洲精品日韩在线| 国产久久久精品毛片| 亚洲国产免费av一区二区三区| 97香蕉碰碰人妻国产樱花| 久草视频在线免播放| 久青青草视频手机在线免费观看 | 婷婷激情四射在线观看视频| 日韩av免费观看一区| 综合激情网激情五月天| 国产综合精品久久久久蜜臀| 一区二区三区日本伦理| 亚洲中文字字幕乱码| 成人av天堂丝袜在线观看| 在线可以看的视频你懂的| 白白操白白色在线免费视频| 亚洲成人国产av在线| 欧美亚洲中文字幕一区二区三区 | 动漫黑丝美女的鸡巴| 伊人成人综合开心网| 四川五十路熟女av| 三级等保密码要求条款| 日曰摸日日碰夜夜爽歪歪| 欧美精产国品一二三产品区别大吗| 亚洲欧美人精品高清| 九九视频在线精品播放| 2019av在线视频| 巨乳人妻日下部加奈被邻居中出| 久久久久久cao我的性感人妻| 男人的网址你懂的亚洲欧洲av| av手机在线免费观看日韩av| 北条麻妃高跟丝袜啪啪| 亚洲成人激情视频免费观看了| 粗大的内捧猛烈进出爽大牛汉子| 2012中文字幕在线高清| 91人妻人人做人人爽在线| 欧美少妇性一区二区三区| 自拍 日韩 欧美激情| 亚洲国产精品久久久久久6| 国产高清女主播在线| 91天堂精品一区二区| 国产va精品免费观看| 亚洲欧美色一区二区| 少妇人妻真实精品视频| 9色精品视频在线观看| 欧美在线精品一区二区三区视频| 80电影天堂网官网| 97国产在线观看高清| 亚洲护士一区二区三区| 精品日产卡一卡二卡国色天香| 91精品国产高清自在线看香蕉网| 国产精品视频一区在线播放| 中文字幕在线视频一区二区三区| 骚逼被大屌狂草视频免费看| 人妻激情图片视频小说| 动漫精品视频在线观看| 成年人免费看在线视频| 亚洲中文字幕人妻一区| 老司机免费福利视频网| 久草福利电影在线观看| www日韩a级s片av| 人妻少妇精品久久久久久| 久久久久久久久久一区二区三区| 日韩加勒比东京热二区| 中文字幕高清资源站| 99re久久这里都是精品视频| 欧美成人猛片aaaaaaa| 传媒在线播放国产精品一区 | 免费无毒热热热热热热久| 黄色资源视频网站日韩| 阿v天堂2014 一区亚洲| 国产成人精品一区在线观看| 在线观看日韩激情视频| www天堂在线久久| 亚洲精品无码色午夜福利理论片| 色婷婷精品大在线观看| 亚洲第17页国产精品| 国产精品久久久久网| 国产精品午夜国产小视频| 午夜dv内射一区区| 国产精品自拍在线视频| 天天日夜夜操天天摸| 中文字幕在线免费第一页| 日本xx片在线观看| 天天操天天射天天操天天天| 久久久久久久精品老熟妇| 国产密臀av一区二区三| 91超碰青青中文字幕| 9l人妻人人爽人人爽| 顶级尤物粉嫩小尤物网站| 偷拍自拍亚洲美腿丝袜| 亚国产成人精品久久久| 亚洲1区2区3区精华液| 一区二区在线视频中文字幕| 亚洲综合在线视频可播放| 日本一区二区三区免费小视频| 免费岛国喷水视频在线观看 | 青草青永久在线视频18| 色婷婷精品大在线观看| 日韩北条麻妃一区在线| 久久久久只精品国产三级| 91在线视频在线精品3| 精品美女在线观看视频在线观看| 久久综合老鸭窝色综合久久| 日韩国产乱码中文字幕| 在线视频免费观看网| 夜色福利视频在线观看| 亚洲av极品精品在线观看| 中文字幕熟女人妻久久久| 青青草在观免费国产精品| 午夜免费体验区在线观看| 初美沙希中文字幕在线| 538精品在线观看视频| 视频久久久久久久人妻| 日韩精品中文字幕在线| 狠狠的往里顶撞h百合| 制丝袜业一区二区三区| 成年女人免费播放视频| 91欧美在线免费观看| 在线观看911精品国产| 2022天天干天天操| 中文字幕av一区在线观看| 孕妇奶水仑乱A级毛片免费看| 国产精品久久久久网| 午夜精彩视频免费一区| 亚洲欧美综合在线探花| 精品人妻一二三区久久| 亚洲精品乱码久久久久久密桃明| 最后99天全集在线观看| 92福利视频午夜1000看| 国产亚洲成人免费在线观看 | 动色av一区二区三区| 天天躁夜夜躁日日躁a麻豆| 国产又粗又黄又硬又爽| 国产福利小视频大全| 男人天堂最新地址av| 亚洲国产最大av综合| 国产精品人妻66p| 天天日天天天天天天天天天天| 福利视频一区二区三区筱慧| av中文字幕电影在线看| 日本美女性生活一级片| 在线观看911精品国产| 五色婷婷综合狠狠爱| 国产欧美精品不卡在线| 午夜激情精品福利视频| 99精品国产aⅴ在线观看 | 国产女孩喷水在线观看| 国产美女精品福利在线| 黄色录像鸡巴插进去| 国产综合视频在线看片| 一区二区三区日韩久久| 日本熟妇一区二区x x| 天天做天天爽夜夜做少妇| 亚洲va天堂va国产va久| japanese日本熟妇另类| 欧美黑人性猛交xxxxⅹooo| 少妇被强干到高潮视频在线观看| 美女 午夜 在线视频| 国产精品视频一区在线播放| 亚洲国际青青操综合网站| 国产美女午夜福利久久| 日美女屁股黄邑视频| 欧美在线偷拍视频免费看| 经典av尤物一区二区| 久久机热/这里只有| 一个人免费在线观看ww视频| 自拍偷拍亚洲另类色图| 日本少妇精品免费视频| 在线观看日韩激情视频| 最新国产精品拍在线观看| 二区中出在线观看老师| 国产高清97在线观看视频| 日本熟妇喷水xxx| 亚洲另类综合一区小说| 婷婷六月天中文字幕| 污污小视频91在线观看| 成年人中文字幕在线观看| 天天干天天爱天天色| 亚洲天堂成人在线观看视频网站| 在线观看视频污一区| 成熟丰满熟妇高潮xx×xx | avjpm亚洲伊人久久| 午夜婷婷在线观看视频| 亚洲免费国产在线日韩| 精品黑人一区二区三区久久国产| 亚洲国产成人最新资源| 亚洲国产最大av综合| 在线观看亚洲人成免费网址| 成人伊人精品色xxxx视频| 老司机免费福利视频网| 亚洲国产欧美一区二区丝袜黑人| 精品一线二线三线日本| 色秀欧美视频第一页| av男人天堂狠狠干| 免费69视频在线看| 91精品国产91青青碰| 中文字幕最新久久久| 亚洲另类图片蜜臀av| 成人性黑人一级av| 51精品视频免费在线观看| 超鹏97历史在线观看| 激情人妻校园春色亚洲欧美| 可以免费看的www视频你懂的| 国产久久久精品毛片| 老熟妇xxxhd老熟女| 亚洲第17页国产精品| 国产内射中出在线观看| 久草视频在线一区二区三区资源站 | 欧美亚洲偷拍自拍色图| 天天操天天插天天色| 无码日韩人妻精品久久| 一色桃子人妻一区二区三区| 久久农村老妇乱69系列| 欧美成人综合视频一区二区| 性生活第二下硬不起来| 青青青青视频在线播放| 一二三中文乱码亚洲乱码one| 国产美女一区在线观看| 亚洲天堂第一页中文字幕| 色哟哟在线网站入口| 9色在线视频免费观看| 午夜精品久久久久麻豆影视| 91久久国产成人免费网站| 国产精品亚洲在线观看| 第一福利视频在线观看| 日本阿v视频在线免费观看| 亚洲一区自拍高清免费视频| 天天操天天爽天天干| jiuse91九色视频| 51国产偷自视频在线播放| 少妇人妻久久久久视频黄片| 亚洲特黄aaaa片| 9久在线视频只有精品| 五月天色婷婷在线观看视频免费| 六月婷婷激情一区二区三区| 欧美黄片精彩在线免费观看| 黄片三级三级三级在线观看| 久久h视频在线观看| 97瑟瑟超碰在线香蕉| 日韩影片一区二区三区不卡免费| 欲乱人妻少妇在线视频裸| 亚洲午夜福利中文乱码字幕| 国产成人精品久久二区91| 亚洲成人av一区在线| 久久久91蜜桃精品ad| 男人插女人视频网站| 亚洲一级特黄特黄黄色录像片| 男生舔女生逼逼的视频| huangse网站在线观看| 免费手机黄页网址大全| 97人妻总资源视频| xxx日本hd高清| 97精品成人一区二区三区| 在线免费观看欧美小视频| 欧美成一区二区三区四区| 又色又爽又黄又刺激av网站| 国产精品入口麻豆啊啊啊| 欧美精产国品一二三产品价格| 无码日韩人妻精品久久| gogo国模私拍视频| 女生自摸在线观看一区二区三区| av俺也去在线播放| ka0ri在线视频| 亚洲熟色妇av日韩熟色妇在线 | 国产亚洲欧美另类在线观看| 午夜在线观看一区视频| 岛国av高清在线成人在线| 日韩美av高清在线| 亚洲欧美激情人妻偷拍| 免费国产性生活视频| 国产精品探花熟女在线观看| 中文字幕欧美日韩射射一| 夜色撩人久久7777| 人人妻人人爽人人添夜| 成人av电影免费版| 亚洲天堂精品福利成人av| 日韩无码国产精品强奸乱伦| 欧美一区二区三区高清不卡tv | 亚洲成人情色电影在线观看| nagger可以指黑人吗| 不卡精品视频在线观看| 欧美一区二区三区高清不卡tv| 国产精品熟女久久久久浪潮| 人妻凌辱欧美丰满熟妇| 亚洲熟妇久久无码精品| 黄工厂精品视频在线观看| 天天摸天天日天天操| 亚洲熟女久久久36d| 97青青青手机在线视频| 亚洲国产第一页在线观看| 亚洲 色图 偷拍 欧美| 日本一区二区三区免费小视频| 亚洲精品亚洲人成在线导航 | 人人妻人人爽人人澡人人精品| 日噜噜噜夜夜噜噜噜天天噜噜噜| 97人妻色免费视频| 2017亚洲男人天堂| 欧美精品 日韩国产| 中文字幕在线一区精品| 性感美女高潮视频久久久| 班长撕开乳罩揉我胸好爽| 青青草原色片网站在线观看| 日本性感美女写真视频| 岛国免费大片在线观看| 久久久久久cao我的性感人妻| 快插进小逼里大鸡吧视频| 亚洲区美熟妇久久久久| 超碰97人人做人人爱| 老司机欧美视频在线看| 欧美成人黄片一区二区三区 | 欧美日韩情色在线观看| 一区二区三区毛片国产一区| 骚货自慰被发现爆操| 日韩欧美国产一区不卡| 免费无毒热热热热热热久| 亚洲成人av在线一区二区| 一区二区三区四区视频在线播放| 日辽宁老肥女在线观看视频| 久久久久久久久久久免费女人| 青青社区2国产视频| 粉嫩欧美美人妻小视频| www骚国产精品视频| 日韩精品啪啪视频一道免费| 一区二区三区激情在线| 成人免费毛片aaaa| 偷青青国产精品青青在线观看| 影音先锋女人av噜噜色| 2o22av在线视频| 国产日韩欧美视频在线导航| 沈阳熟妇28厘米大战黑人| 天天想要天天操天天干| 亚洲国产成人最新资源| 99精品国自产在线人| 男人操女人逼逼视频网站| 亚洲 图片 欧美 图片| 91久久人澡人人添人人爽乱| 91快播视频在线观看| 18禁污污污app下载| 亚洲人妻国产精品综合| 日韩精品中文字幕播放| 狠狠操狠狠操免费视频| 亚洲丝袜老师诱惑在线观看| 日韩成人性色生活片| 男人天堂最新地址av| 亚洲一级美女啪啪啪| 免费观看理论片完整版| 黑人进入丰满少妇视频| 久久久91蜜桃精品ad| 人人妻人人澡欧美91精品| 亚洲的电影一区二区三区| www日韩a级s片av| 91天堂精品一区二区| 亚洲成人精品女人久久久| 18禁网站一区二区三区四区| av成人在线观看一区| 黄页网视频在线免费观看| 91成人精品亚洲国产| 免费在线观看视频啪啪 | 国产激情av网站在线观看| 无码精品一区二区三区人| 日韩美女福利视频网| 午夜场射精嗯嗯啊啊视频| 强行扒开双腿猛烈进入免费版| 91欧美在线免费观看| 日本人妻少妇18—xx| 色呦呦视频在线观看视频| 男女第一次视频在线观看| 97人妻人人澡爽人人精品| 天天色天天爱天天爽| 视频二区在线视频观看| 欧美黑人巨大性xxxxx猛交| 无码中文字幕波多野不卡| 91国产在线免费播放| 93视频一区二区三区| 老鸭窝在线观看一区| 青青草国内在线视频精选| 日曰摸日日碰夜夜爽歪歪| 亚洲 清纯 国产com| 啊慢点鸡巴太大了啊舒服视频| 亚洲1卡2卡三卡4卡在线观看 | huangse网站在线观看| 国产精品人妻66p| 久久精品美女免费视频| www骚国产精品视频| 国产乱子伦精品视频潮优女| 亚洲av日韩av第一区二区三区| 欧美一级色视频美日韩| 天干天天天色天天日天天射| 欧美黑人巨大性xxxxx猛交| 99热久久这里只有精品8| 91人妻人人做人人爽在线| 孕妇奶水仑乱A级毛片免费看| 在线观看视频污一区| 婷婷久久久综合中文字幕| 偷拍自拍视频图片免费| 国产黄色片蝌蚪九色91| 骚逼被大屌狂草视频免费看| 最新欧美一二三视频| 免费看国产av网站| 成人免费做爰高潮视频| 大黑人性xxxxbbbb| 最近的中文字幕在线mv视频| 欧美亚洲牲夜夜综合久久| 国产露脸对白在线观看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 免费av岛国天堂网站| 97a片免费在线观看| 国产男女视频在线播放| 青青青青青青青青青国产精品视频| 中文字幕 人妻精品| 成人精品视频99第一页| 欧美特色aaa大片| 又大又湿又爽又紧A视频| 天天干天天操天天扣| 免费在线看的黄网站| 超碰97人人澡人人| 亚洲午夜福利中文乱码字幕| 国产丰满熟女成人视频| 黄色视频成年人免费观看| 中文字幕AV在线免费看 | 99久久成人日韩欧美精品| 国产内射中出在线观看| 国产成人精品一区在线观看| 天天日天天透天天操| 青草亚洲视频在线观看| 无忧传媒在线观看视频| 亚洲综合一区二区精品久久| 男人插女人视频网站| 91精品啪在线免费| 欧美专区日韩专区国产专区| 日本少妇人妻xxxxxhd| 美女 午夜 在线视频| 日视频免费在线观看| 黄色成年网站午夜在线观看| 色婷婷久久久久swag精品| 2021国产一区二区| 男女啪啪啪啪啪的网站| 操人妻嗷嗷叫视频一区二区| 蝴蝶伊人久久中文娱乐网| av俺也去在线播放| 五十路老熟女码av| 中文字幕亚洲久久久| 丝袜美腿欧美另类 中文字幕| 亚洲国产美女一区二区三区软件| 中文字幕人妻熟女在线电影| av天堂加勒比在线| 中国熟女一区二区性xx| 亚洲美女自偷自拍11页| 把腿张开让我插进去视频| 亚洲一级av大片免费观看| 亚洲男人在线天堂网| 一区二区三区在线视频福利| 青青青青操在线观看免费| 久久永久免费精品人妻专区 | 91免费福利网91麻豆国产精品| 成人蜜桃美臀九一一区二区三区| 性生活第二下硬不起来| 天天日天天鲁天天操| 国内精品在线播放第一页| 亚洲2021av天堂| 动漫美女的小穴视频| 天天色天天舔天天射天天爽| 国产日韩一区二区在线看| 日韩欧美在线观看不卡一区二区| 岛国av高清在线成人在线| 99re久久这里都是精品视频| 亚洲的电影一区二区三区| 无码精品一区二区三区人| 777奇米久久精品一区| 班长撕开乳罩揉我胸好爽| 久草视频中文字幕在线观看| 亚洲的电影一区二区三区| 成人av亚洲一区二区| av无限看熟女人妻另类av| jiuse91九色视频| 日韩人妻丝袜中文字幕| 蜜桃色婷婷久久久福利在线| 日韩av熟妇在线观看| 久草视频首页在线观看| 一区二区三区久久久91| 特一级特级黄色网片| 国产真实乱子伦a视频| 绝顶痉挛大潮喷高潮无码| 十八禁在线观看地址免费| 日本韩国在线观看一区二区| 成年人黄色片免费网站| 亚洲 中文 自拍 无码| 久久这里有免费精品| 天天日天天透天天操| 亚洲视频在线观看高清| 少妇被强干到高潮视频在线观看 | 国产又粗又黄又硬又爽| 一区二区三区av高清免费| 成人免费公开视频无毒| 肏插流水妹子在线乐播下载| 哥哥姐姐综合激情小说| 久草视频在线看免费| 国产美女午夜福利久久| 馒头大胆亚洲一区二区| 亚洲一区二区三区偷拍女厕91| 日韩人妻丝袜中文字幕| 哥哥姐姐综合激情小说| 99精品免费观看视频| 久久麻豆亚洲精品av| 中文字幕网站你懂的| 五十路在线观看完整版| 黑人3p华裔熟女普通话| 免费在线播放a级片| 日本少妇人妻xxxxxhd| 日本欧美视频在线观看三区| 91片黄在线观看喷潮| 婷婷久久久综合中文字幕| 精品av国产一区二区三区四区| 欧美日韩情色在线观看| 日韩美女福利视频网| 成人国产影院在线观看| 啪啪啪啪啪啪啪啪啪啪黄色| 亚洲另类在线免费观看| 日韩精品电影亚洲一区| 国产视频网站国产视频| 无码精品一区二区三区人| 国产乱子伦一二三区| 日本高清成人一区二区三区| 亚洲精品无码久久久久不卡| yy6080国产在线视频| 在线免费观看黄页视频| 啊啊啊想要被插进去视频| 久久久人妻一区二区| 老鸭窝日韩精品视频观看| 国产午夜激情福利小视频在线| 后入美女人妻高清在线| 欧美在线一二三视频| 一个色综合男人天堂| 亚国产成人精品久久久| 免费人成黄页网站在线观看国产| 91破解版永久免费| av天堂中文免费在线| 成人亚洲国产综合精品| 99精品国自产在线人| 国产精品污污污久久| 激情国产小视频在线| 天天操夜夜骑日日摸| av中文字幕国产在线观看| 天天操夜夜操天天操天天操| av中文字幕在线观看第三页| 久久这里只有精彩视频免费| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 国产av一区2区3区| caoporm超碰国产| 天天爽夜夜爽人人爽QC| 亚洲欧美成人综合视频| 欧美视频一区免费在线| 日本高清撒尿pissing| 国产成人精品一区在线观看| av无限看熟女人妻另类av| 丰满的子国产在线观看| 一区二区三区四区五区性感视频| 国产成人精品一区在线观看| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 青青草人人妻人人妻| 成人免费公开视频无毒| 欧美爆乳肉感大码在线观看| 在线观看免费av网址大全| 日韩成人综艺在线播放| 五月婷婷在线观看视频免费| 一区二区三区的久久的蜜桃的视频| 最新日韩av传媒在线| 国产品国产三级国产普通话三级| 亚洲精品亚洲人成在线导航| 久久www免费人成一看片| 日本丰满熟妇大屁股久久| 日本少妇在线视频大香蕉在线观看 | 女同互舔一区二区三区| 九一传媒制片厂视频在线免费观看| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 韩国女主播精品视频网站| sspd152中文字幕在线| 美洲精品一二三产区区别| 91在线视频在线精品3| 内射久久久久综合网| 75国产综合在线视频| 国产夫妻视频在线观看免费| 丁香花免费在线观看中文字幕| 日本少妇人妻xxxxxhd| 亚洲欧美人精品高清| 视频久久久久久久人妻| 99热99这里精品6国产| 欧美老妇精品另类不卡片| 阿v天堂2014 一区亚洲| 岛国黄色大片在线观看| 中国无遮挡白丝袜二区精品| 大屁股肉感人妻中文字幕在线| 天天插天天色天天日| 亚洲欧美色一区二区| 久久久久久久一区二区三| 欧美一区二区三区高清不卡tv | 亚洲 中文 自拍 另类 欧美| 女同互舔一区二区三区| 性感美女诱惑福利视频| 91香蕉成人app下载| 成人国产影院在线观看| av中文字幕网址在线| 青青青青青青青在线播放视频 | 天天日天天添天天爽| 最后99天全集在线观看| 在线免费观看视频一二区| 男生用鸡操女生视频动漫| 五十路老熟女码av| 又色又爽又黄又刺激av网站| 热99re69精品8在线播放| 天天操天天插天天色| 中文字幕日韩精品日本| 欧美综合婷婷欧美综合| 2018在线福利视频| 青青在线视频性感少妇和隔壁黑丝| 肏插流水妹子在线乐播下载| 2022天天干天天操| 亚洲av在线观看尤物| av黄色成人在线观看| 国产三级精品三级在线不卡| 天天干天天操天天扣| 99热这里只有精品中文| 亚洲国产中文字幕啊啊啊不行了| 丝袜国产专区在线观看| 又黄又刺激的午夜小视频| 老司机福利精品视频在线| 日韩欧美中文国产在线| 亚洲第一黄色在线观看| 老司机欧美视频在线看| 久久精品久久精品亚洲人| 亚洲丝袜老师诱惑在线观看| 人人妻人人爽人人澡人人精品| 91极品大一女神正在播放| 在线观看操大逼视频| 视频一区 视频二区 视频| 亚洲av无码成人精品区辽| 男人在床上插女人视频| 福利片区一区二体验区| 亚洲中文字幕人妻一区| 阿v天堂2014 一区亚洲| 美女福利视频网址导航| 亚洲第一黄色在线观看| jiuse91九色视频| 国产精品手机在线看片| 欧美一区二区三区激情啪啪啪| 天天日天天日天天擦| 欧美偷拍自拍色图片| 狠狠鲁狠狠操天天晚上干干| 大鸡吧插逼逼视频免费看| 顶级尤物粉嫩小尤物网站| 中文字幕一区二区亚洲一区| 亚洲一区二区三区久久午夜 | 精品亚洲国产中文自在线| 青青青青在线视频免费观看| eeuss鲁片一区二区三区| 天天插天天色天天日| 国产精品日韩欧美一区二区| nagger可以指黑人吗| 亚洲无线观看国产高清在线| 日本一本午夜在线播放| 天天日天天鲁天天操| 性色蜜臀av一区二区三区| 成年人中文字幕在线观看| 非洲黑人一级特黄片| 日韩欧美一级精品在线观看| 天天综合天天综合天天网| 最新中文字幕免费视频| 任我爽精品视频在线播放| 888亚洲欧美国产va在线播放| 99久久99一区二区三区| av中文字幕电影在线看| 男人天堂av天天操| 亚洲福利精品视频在线免费观看| 欧美一区二区三区啪啪同性| 国产高清精品极品美女| 精品一区二区三区午夜| 欧美精品资源在线观看| 在线免费观看日本伦理| 在线免费观看日本伦理| 日韩欧美国产一区ab| 2021最新热播中文字幕| 精彩视频99免费在线| 5528327男人天堂| 蜜桃久久久久久久人妻| 女生被男生插的视频网站| 一区二区三区日韩久久| 久草视频福利在线首页| 2021年国产精品自拍| 40道精品招牌菜特色| 国产伦精品一区二区三区竹菊| 动漫精品视频在线观看| 激情啪啪啪啪一区二区三区 | 亚洲少妇人妻无码精品| 在线免费观看国产精品黄色| 操操网操操伊剧情片中文字幕网| 欧美老鸡巴日小嫩逼| 亚洲激情,偷拍视频| 性感美女高潮视频久久久| 国产内射中出在线观看| 99久久激情婷婷综合五月天| 欧美黄片精彩在线免费观看| 老司机在线精品福利视频| 日韩三级电影华丽的外出| 亚洲欧洲一区二区在线观看| 亚洲中文精品人人免费| 亚洲一区二区激情在线| 97a片免费在线观看| 日本精品一区二区三区在线视频。 | 91试看福利一分钟| 午夜毛片不卡免费观看视频| 老有所依在线观看完整版| 日本韩国免费福利精品| 亚洲日本一区二区久久久精品| 欧美国品一二三产区区别| 日本男女操逼视频免费看| 日视频免费在线观看| 精品av久久久久久久| 99亚洲美女一区二区三区| 欧美日韩v中文在线| 亚洲av自拍天堂网| huangse网站在线观看| 少妇高潮无套内谢麻豆| 国产片免费观看在线观看| 日本裸体熟妇区二区欧美| 中文字幕av熟女人妻| 中文字幕第三十八页久久| 亚洲国产美女一区二区三区软件| 精品亚洲中文字幕av| 欧美区一区二区三视频| 亚洲av成人网在线观看| 超碰在线中文字幕一区二区| 另类av十亚洲av| 激情五月婷婷综合色啪| 国产麻豆剧果冻传媒app| 蜜桃色婷婷久久久福利在线| chinese国产盗摄一区二区| 日韩成人综艺在线播放| 91大神福利视频网| av一本二本在线观看| 中文字幕最新久久久| 国产精品久久久黄网站| 国产视频一区在线观看| 都市家庭人妻激情自拍视频| 99亚洲美女一区二区三区| 午夜极品美女福利视频| 天天日天天舔天天射进去| 熟女人妻在线观看视频| 午夜毛片不卡在线看| 亚洲一区二区三区久久午夜| 操日韩美女视频在线免费看| 亚洲乱码中文字幕在线| 大学生A级毛片免费视频| 日韩中文字幕精品淫| 成年午夜影片国产片| 青青草在观免费国产精品| 性欧美日本大妈母与子| 高潮视频在线快速观看国家快速| 亚洲高清国产一区二区三区| free性日本少妇| 在线制服丝袜中文字幕| 一区国内二区日韩三区欧美| 亚洲自拍偷拍精品网| AV无码一区二区三区不卡| 久久久久五月天丁香社区| 国产无遮挡裸体免费直播视频| 视频一区二区综合精品| 午夜在线一区二区免费| 中文 成人 在线 视频| 蜜桃精品久久久一区二区| 精品日产卡一卡二卡国色天香| 天天躁夜夜躁日日躁a麻豆| 国产一区成人在线观看视频| 婷婷五月亚洲综合在线| 日韩人妻xxxxx| 88成人免费av网站| 人人爱人人妻人人澡39| 99精品国产aⅴ在线观看| 年轻的人妻被夫上司侵犯| 国产视频在线视频播放| 日韩欧美在线观看不卡一区二区| 日本韩国在线观看一区二区| 在线免费91激情四射| 青青青爽视频在线播放| 亚洲第一黄色在线观看| 最新中文字幕乱码在线| 欧美日韩情色在线观看| 婷婷色国产黑丝少妇勾搭AV| 好吊操视频这里只有精品| 性感美女福利视频网站| 日本人妻少妇18—xx| 国产午夜男女爽爽爽爽爽视频| 天天干天天搞天天摸| 亚洲日本一区二区三区| 97年大学生大白天操逼| 日韩三级黄色片网站| 蜜桃臀av蜜桃臀av| 午夜久久久久久久精品熟女| 久久国产精品精品美女| 国产午夜男女爽爽爽爽爽视频| 91老熟女连续高潮对白| 国产精品久久久黄网站| 午夜精品久久久久久99热| 不卡精品视频在线观看| 久久一区二区三区人妻欧美 | 91精品国产麻豆国产| 成人蜜桃美臀九一一区二区三区| 欧美日本在线观看一区二区| 欧美xxx成人在线| 亚洲天堂第一页中文字幕| 99精品视频在线观看婷婷| 日韩一区二区三区三州| 91久久精品色伊人6882| 在线观看国产免费麻豆| 天天夜天天日天天日| 亚洲美女美妇久久字幕组| 性生活第二下硬不起来| 欧美精品欧美极品欧美视频| 岛国青草视频在线观看| 天天操天天爽天天干| av资源中文字幕在线观看| avjpm亚洲伊人久久| 97人妻人人澡爽人人精品| 亚洲欧美色一区二区| 国产一区av澳门在线观看| 无码精品一区二区三区人| 亚欧在线视频你懂的| 少妇人妻二三区视频| 亚洲va欧美va人人爽3p| 日韩在线视频观看有码在线| 2020久久躁狠狠躁夜夜躁| 18禁网站一区二区三区四区| 亚洲av日韩av第一区二区三区| 大香蕉伊人中文字幕| 爆乳骚货内射骚货内射在线| 91精品一区二区三区站长推荐| 亚洲女人的天堂av| 国产自拍在线观看成人| 免费成人av中文字幕| 夜色17s精品人妻熟女| 国产一区二区三免费视频| 婷婷色国产黑丝少妇勾搭AV | 亚洲高清一区二区三区视频在线| 久草视频在线看免费| 欧美交性又色又爽又黄麻豆| 黄色录像鸡巴插进去| 色爱av一区二区三区| 免费观看理论片完整版| 久久久久久久久久久久久97| 亚洲日本一区二区三区 | 中文字幕av男人天堂| 亚洲一级美女啪啪啪| 三级av中文字幕在线观看| 3D动漫精品啪啪一区二区下载| 亚洲 欧美 精品 激情 偷拍| 欧美老鸡巴日小嫩逼| 久久久久五月天丁香社区| 成人伊人精品色xxxx视频| 扒开腿挺进肉嫩小18禁视频| 1区2区3区4区视频在线观看| 亚洲 欧美 精品 激情 偷拍 | 久久精品亚洲成在人线a| 国产又粗又猛又爽又黄的视频美国| 国产亚洲视频在线观看| 新婚人妻聚会被中出| 高清成人av一区三区| 国产91嫩草久久成人在线视频| 999久久久久999| 日韩北条麻妃一区在线| 99精品国产自在现线观看| 午夜av一区二区三区| 天堂女人av一区二区| 东京干手机福利视频| 红桃av成人在线观看| 亚洲一区久久免费视频| 亚洲成人av一区久久| 欧美一区二区三区高清不卡tv | 无码中文字幕波多野不卡| 亚洲av日韩精品久久久| 中国无遮挡白丝袜二区精品| 亚洲精品国品乱码久久久久| 91九色porny国产蝌蚪视频| www,久久久,com| 大学生A级毛片免费视频| 午夜精品久久久久久99热| 中文字幕人妻三级在线观看| 日本中文字幕一二区视频| 把腿张开让我插进去视频| 亚洲午夜福利中文乱码字幕| 国产熟妇一区二区三区av | 人妻少妇中文有码精品| 天天日天天干天天要| 5528327男人天堂| 初美沙希中文字幕在线| 国产白袜脚足J棉袜在线观看| 亚洲在线免费h观看网站| 久草视频在线免播放| 91she九色精品国产| 精品一区二区三区在线观看| 欧美亚洲国产成人免费在线 | 精品欧美一区二区vr在线观看| 操的小逼流水的文章| 欧美精品亚洲精品日韩在线| 999九九久久久精品| 中文字幕av第1页中文字幕| 91精品视频在线观看免费| 天天操天天插天天色| AV无码一区二区三区不卡| 免费看高清av的网站| 欧美一区二区三区啪啪同性| 九色精品视频在线播放| 国产精品成人xxxx| 亚洲粉嫩av一区二区三区| 一区二区三区 自拍偷拍| 午夜婷婷在线观看视频| 免费手机黄页网址大全| 最新欧美一二三视频| 班长撕开乳罩揉我胸好爽| 青青在线视频性感少妇和隔壁黑丝| 欧美精品国产综合久久| 粉嫩av蜜乳av蜜臀| 性感美女诱惑福利视频| 亚洲丝袜老师诱惑在线观看| 日本av在线一区二区三区| 国产极品精品免费视频| 欧洲精品第一页欧洲精品亚洲| 91成人在线观看免费视频| 国产精品成人xxxx| 中文字幕一区二 区二三区四区| 97香蕉碰碰人妻国产樱花| 欧美久久一区二区伊人| 91精品国产高清自在线看香蕉网 | 5528327男人天堂| 狠狠嗨日韩综合久久| 亚洲av男人的天堂你懂的| 国产亚洲国产av网站在线| 欧美亚洲自偷自拍 在线| 91麻豆精品传媒国产黄色片| 一个人免费在线观看ww视频| 国产一区二区在线欧美| 亚洲在线一区二区欧美| 91色网站免费在线观看| 亚洲综合另类欧美久久| 天天综合天天综合天天网| 国产V亚洲V天堂无码欠欠| 国产欧美日韩第三页| 任我爽精品视频在线播放| 韩国三级aaaaa高清视频| 欧美一区二区三区四区性视频| 自拍偷拍 国产资源| 国产无遮挡裸体免费直播视频| 经典亚洲伊人第一页| 2021天天色天天干| 国产黄色高清资源在线免费观看 | 绯色av蜜臀vs少妇| 欧美黄片精彩在线免费观看| www天堂在线久久| 成年人黄视频在线观看| 91国产资源在线视频| 天天日夜夜操天天摸| 国产一区二区神马久久| 99久久久无码国产精品性出奶水| 成人精品在线观看视频| 精品黑人巨大在线一区| 3337p日本欧洲大胆色噜噜| 天码人妻一区二区三区在线看 | 97人妻无码AV碰碰视频| 青青在线视频性感少妇和隔壁黑丝| 亚洲粉嫩av一区二区三区| 久久久久91精品推荐99| 久久久精品精品视频视频| 乱亲女秽乱长久久久| 人妻少妇性色欲欧美日韩 | 91天堂精品一区二区| 阴茎插到阴道里面的视频| 人人妻人人澡人人爽人人dvl| 成人av在线资源网站| 自拍偷拍亚洲精品第2页| 午夜久久久久久久99| 3337p日本欧洲大胆色噜噜| 亚洲av日韩高清hd| 韩国三级aaaaa高清视频| 91精品国产91久久自产久强| 日本黄色三级高清视频| 少妇人妻久久久久视频黄片| 欧美偷拍自拍色图片| 男人在床上插女人视频| 青青草国内在线视频精选| 五十路老熟女码av| 亚洲一区二区久久久人妻| 中文字幕人妻av在线观看| 国产亚洲成人免费在线观看| 亚洲特黄aaaa片| 干逼又爽又黄又免费的视频| 女生被男生插的视频网站| 国产av福利网址大全| 黄页网视频在线免费观看| 男女啪啪视频免费在线观看| 亚洲美女高潮喷浆视频| 欧美日韩亚洲国产无线码| 天堂v男人视频在线观看| 天天日天天敢天天干| 欧美日韩v中文在线| 国产精品手机在线看片| 久久永久免费精品人妻专区| av网站色偷偷婷婷网男人的天堂| 在线免费视频 自拍| 91国内视频在线观看| 日日操综合成人av| 青娱乐极品视频青青草| 天天射,天天操,天天说| 9色精品视频在线观看| 国产午夜亚洲精品不卡在线观看| 懂色av蜜桃a v| 2021年国产精品自拍| 亚洲午夜福利中文乱码字幕| 亚洲图片欧美校园春色| 久久艹在线观看视频| 红桃av成人在线观看| av天堂加勒比在线| 欧美另类重口味极品在线观看| 搞黄色在线免费观看| 亚洲av自拍偷拍综合| 婷婷激情四射在线观看视频| 天干天天天色天天日天天射| 91精品激情五月婷婷在线| 激情啪啪啪啪一区二区三区| 99久久中文字幕一本人| 一区二区三区四区中文| 在线国产精品一区二区三区| 护士特殊服务久久久久久久| 日本中文字幕一二区视频| 在线观看日韩激情视频| 2021年国产精品自拍| 日本熟女50视频免费| 人妻少妇亚洲一区二区| 午夜美女福利小视频| 国产伊人免费在线播放| 婷婷久久久久深爱网| 日韩北条麻妃一区在线| 免费无毒热热热热热热久| 日本最新一二三区不卡在线| 在线国产精品一区二区三区| 久久久久久久精品老熟妇| 综合国产成人在线观看| 人妻自拍视频中国大陆| 神马午夜在线观看视频| 日韩一区二区三区三州| 中文字幕在线乱码一区二区 | 精品91高清在线观看| 成人av在线资源网站| 一区二区三区精品日本| 在线国产精品一区二区三区| 大香蕉大香蕉在线有码 av| 影音先锋女人av噜噜色| 扒开让我视频在线观看| 制丝袜业一区二区三区| 亚洲福利午夜久久久精品电影网| 五十路av熟女松本翔子| 最新日韩av传媒在线| 久久永久免费精品人妻专区| 亚洲 中文 自拍 无码| 国产伊人免费在线播放| 欧美日韩一区二区电影在线观看| 亚洲精品乱码久久久本| 人妻熟女在线一区二区| 久久久久久9999久久久久| 国产日韩精品电影7777| 亚洲最大黄了色网站| 999热精品视频在线| 大肉大捧一进一出好爽在线视频| 午夜精彩视频免费一区| 日本人妻欲求不满中文字幕| 亚洲人妻30pwc| 深夜男人福利在线观看| 国产精品自拍视频大全| 和邻居少妇愉情中文字幕| 午夜美女福利小视频| 九色porny九色9l自拍视频| 99国产精品窥熟女精品| 久久久久久久精品老熟妇| 91色老99久久九九爱精品| 天天日天天天天天天天天天天| 欧美日韩情色在线观看| 早川濑里奈av黑人番号| 青青青青青青草国产| 精品国产在线手机在线| 国产麻豆91在线视频| 少妇人妻二三区视频| 亚洲国产精品久久久久久6| 成人av在线资源网站| 国产实拍勾搭女技师av在线| 亚洲成人国产综合一区| 婷婷久久久久深爱网| 老司机深夜免费福利视频在线观看| 99热国产精品666| 99人妻视频免费在线| 91国产资源在线视频| 欲满人妻中文字幕在线| 国产97在线视频观看| 黄页网视频在线免费观看| 精品视频中文字幕在线播放| 啪啪啪啪啪啪啪啪啪啪黄色| 国产va精品免费观看| 午夜在线观看一区视频| 大鸡吧插入女阴道黄色片| 香港三日本三韩国三欧美三级| 少妇ww搡性bbb91| 日韩av有码中文字幕| 夜夜骑夜夜操夜夜奸| 亚洲色偷偷综合亚洲AV伊人| 在线亚洲天堂色播av电影| 天天日天天干天天要| 啪啪啪啪啪啪啪免费视频| 日本后入视频在线观看| 日本欧美视频在线观看三区| 99re国产在线精品| 午夜精品一区二区三区4| 超碰97免费人妻麻豆| 国产亚洲欧美45p| 在线观看亚洲人成免费网址| 欧美成人综合视频一区二区| 五十路熟女av天堂| 大鸡巴插入美女黑黑的阴毛| 色伦色伦777国产精品| 青娱乐最新视频在线| 青青草人人妻人人妻| 欧美精品黑人性xxxx| 在线不卡日韩视频播放| 日韩二区视频一线天婷婷五| 天天夜天天日天天日| 视频在线亚洲一区二区| 亚洲av无乱一区二区三区性色| 日本女大学生的黄色小视频| v888av在线观看视频| 国产女孩喷水在线观看| 麻豆精品成人免费视频| jiujiure精品视频在线| 91色九色porny| 国产精品3p和黑人大战| 国产精品一区二区久久久av| 免费看高清av的网站| 成人亚洲国产综合精品| 护士特殊服务久久久久久久| 欧美中国日韩久久精品| 操日韩美女视频在线免费看| 一级黄片久久久久久久久| 国产日本精品久久久久久久| 揄拍成人国产精品免费看视频| 亚洲少妇高潮免费观看| 日本免费视频午夜福利视频| 中文字幕在线视频一区二区三区| 日韩美女精品视频在线观看网站| 国产夫妻视频在线观看免费| 性欧美日本大妈母与子| 激情综合治理六月婷婷| 中文字幕无码一区二区免费| 成人av在线资源网站| 2017亚洲男人天堂| 91大屁股国产一区二区| 经典av尤物一区二区| 天天干天天插天天谢| 人人人妻人人澡人人| 91精品高清一区二区三区| 粉嫩av懂色av蜜臀av| 国产亚洲国产av网站在线| 亚洲精品国偷自产在线观看蜜桃| 中出中文字幕在线观看| 91天堂天天日天天操| 日本少妇人妻xxxxxhd| 久久机热/这里只有| 91国产在线视频免费观看| 抽查舔水白紧大视频| 午夜精品在线视频一区| 久草视频 久草视频2| 亚洲国产精品久久久久久6| 青青草原网站在线观看| 亚洲免费成人a v| 大陆精品一区二区三区久久| 在线免费观看欧美小视频| 777奇米久久精品一区| 亚洲成人情色电影在线观看| 福利片区一区二体验区| 青青青激情在线观看视频| 日韩人妻在线视频免费| 色狠狠av线不卡香蕉一区二区| 又色又爽又黄的美女裸体| 国产成人精品午夜福利训2021 | 黄色黄色黄片78在线| 在线免费观看黄页视频| 亚洲1区2区3区精华液| 免费观看理论片完整版| 小泽玛利亚视频在线观看| 久久久精品精品视频视频| 91成人在线观看免费视频| 巨乳人妻日下部加奈被邻居中出 | 国产之丝袜脚在线一区二区三区 | 欧美精品伦理三区四区| 9国产精品久久久久老师| 99久久成人日韩欧美精品| 亚洲黄色av网站免费播放| 青青青青青免费视频| 日韩精品电影亚洲一区| 精品亚洲在线免费观看| 久久久精品精品视频视频| 初美沙希中文字幕在线| 少妇被强干到高潮视频在线观看| 91中文字幕免费在线观看| 绝色少妇高潮3在线观看| 男人插女人视频网站| 黄色无码鸡吧操逼视频| 在线观看的a站 最新| 亚洲熟色妇av日韩熟色妇在线 | 色婷婷综合激情五月免费观看| 黄色片黄色片wyaa| 欧美老鸡巴日小嫩逼| 国产精品福利小视频a| 亚洲免费视频欧洲免费视频| 免费看美女脱光衣服的视频| 美味人妻2在线播放| 亚洲av日韩av第一区二区三区| 97人妻总资源视频| av资源中文字幕在线观看| 亚洲欧美综合另类13p| 91天堂精品一区二区| 亚洲熟女久久久36d| 操人妻嗷嗷叫视频一区二区| 中文字幕AV在线免费看 | 日韩在线中文字幕色| 天天操天天污天天射| 亚洲国产在线精品国偷产拍| 久久永久免费精品人妻专区 | 天天操夜夜骑日日摸| 熟女91pooyn熟女| 午夜美女少妇福利视频| 人妻自拍视频中国大陆| 久久久久久久精品老熟妇| 午夜极品美女福利视频| 深夜男人福利在线观看| 天天操天天干天天日狠狠插| 久久尻中国美女视频| 免费一级黄色av网站| 91精品国产91青青碰| 成人午夜电影在线观看 久久| 亚洲国产美女一区二区三区软件| 亚洲丝袜老师诱惑在线观看| 国产在线91观看免费观看| 午夜场射精嗯嗯啊啊视频| 亚洲精品一区二区三区老狼| 中文字幕在线一区精品| 91自产国产精品视频| 99久久成人日韩欧美精品| 亚洲一区av中文字幕在线观看| 久久久久久99国产精品| 男女啪啪视频免费在线观看| 91精品国产综合久久久蜜| 97青青青手机在线视频| 在线免费观看99视频| 大鸡巴后入爆操大屁股美女 | 国产欧美精品不卡在线| 亚洲成人免费看电影| 男人和女人激情视频| 在线制服丝袜中文字幕| 91精品激情五月婷婷在线| 男人靠女人的逼视频| 黄色的网站在线免费看| 国产精品久久综合久久| 在线观看亚洲人成免费网址| 日韩熟女系列一区二区三区| 国产+亚洲+欧美+另类| 国产九色91在线视频| 久久久噜噜噜久久熟女av| 啪啪啪啪啪啪啪免费视频| 中文字幕av第1页中文字幕| 亚洲av男人的天堂你懂的| av日韩在线免费播放| 91精品一区二区三区站长推荐| 啪啪啪啪啪啪啪啪啪啪黄色| 亚洲精品国产在线电影| 动漫黑丝美女的鸡巴| 888亚洲欧美国产va在线播放| 亚洲男人在线天堂网| 青青擦在线视频国产在线| 国产aⅴ一线在线观看| 午夜毛片不卡在线看| 久久这里只有精彩视频免费| 成人国产激情自拍三区| 国产1区,2区,3区| 亚洲女人的天堂av| 18禁无翼鸟成人在线| 男人的天堂在线黄色| 五月婷婷在线观看视频免费| 久草视频在线免播放| 一区二区三区视频,福利一区二区| 最新日韩av传媒在线| 国产乱子伦精品视频潮优女| 成人免费公开视频无毒| 人妻少妇性色欲欧美日韩| 东京热男人的av天堂| 人人爱人人妻人人澡39| 中文字幕第一页国产在线| 91精品国产黑色丝袜| 1769国产精品视频免费观看| 亚洲最大黄了色网站| 国产精品系列在线观看一区二区| av日韩在线观看大全| 精品亚洲国产中文自在线| 欧洲黄页网免费观看| 亚洲伊人久久精品影院一美女洗澡| 男人和女人激情视频| 狠狠鲁狠狠操天天晚上干干| 午夜极品美女福利视频| 98精产国品一二三产区区别| 欧美亚洲中文字幕一区二区三区| 99热碰碰热精品a中文| 人人爽亚洲av人人爽av| 亚洲伊人色一综合网| 中文字幕第一页国产在线| 大屁股肉感人妻中文字幕在线| 日本性感美女三级视频| 亚洲精品中文字幕下载| 97黄网站在线观看| 宅男噜噜噜666国产| 亚洲1卡2卡三卡4卡在线观看| 天堂va蜜桃一区入口| 国产精品3p和黑人大战| 蜜桃视频17c在线一区二区| 欧美专区第八页一区在线播放| 欧美亚洲免费视频观看| 黄色大片免费观看网站| 成人激情文学网人妻| 国产精品国产三级国产午| 亚洲av黄色在线网站| 在线观看操大逼视频| 高清一区二区欧美系列| 久久精品国产23696| 天天日天天干天天插舔舔| lutube在线成人免费看| 欧美在线偷拍视频免费看| 国产午夜亚洲精品麻豆| 日本精品美女在线观看| 中国视频一区二区三区| 中文字幕 亚洲av| 国产之丝袜脚在线一区二区三区| 亚洲中文精品字幕在线观看 | 九九视频在线精品播放| 91人妻精品一区二区在线看| 快插进小逼里大鸡吧视频| 在线亚洲天堂色播av电影| 热久久只有这里有精品| 欧美成人精品在线观看| 国产亚洲国产av网站在线| 最新中文字幕免费视频| 青青草成人福利电影| 国内精品在线播放第一页| 国产 在线 免费 精品| 国产亚洲天堂天天一区| 国产亚洲精品视频合集| 大香蕉日本伊人中文在线| 最近中文字幕国产在线| 亚洲国产最大av综合| 亚洲精品高清自拍av| 老鸭窝在线观看一区| 在线免费观看日本片| 又粗又长 明星操逼小视频| 99视频精品全部15| 人人爽亚洲av人人爽av| 国产在线观看黄色视频| www日韩a级s片av| 天天日天天做天天日天天做| 97黄网站在线观看| 在线亚洲天堂色播av电影| 18禁美女羞羞免费网站| av天堂中文免费在线| 天天日天天舔天天射进去| 含骚鸡巴玩逼逼视频| 欧美激情电影免费在线| 92福利视频午夜1000看| 91国产资源在线视频| 国产一区自拍黄视频免费观看| 欧美在线一二三视频| brazzers欧熟精品系列| 老司机福利精品免费视频一区二区| 1024久久国产精品| 中文亚洲欧美日韩无线码| 韩国爱爱视频中文字幕| 精品乱子伦一区二区三区免费播| 美女福利写真在线观看视频| 国产97视频在线精品| 免费在线看的黄网站| 午夜av一区二区三区| 国产日韩欧美视频在线导航| 可以免费看的www视频你懂的| 中文字幕日韩精品日本| 精品国产亚洲av一淫| 国产精品国产三级国产精东 | 欧美精产国品一二三区| 亚洲成人av在线一区二区| 绝色少妇高潮3在线观看| 人妻少妇亚洲精品中文字幕| 99婷婷在线观看视频| 端庄人妻堕落挣扎沉沦| 日韩美女搞黄视频免费| 日本在线一区二区不卡视频| 欧美亚洲免费视频观看| 黄片色呦呦视频免费看| 男人的天堂在线黄色| yellow在线播放av啊啊啊| 班长撕开乳罩揉我胸好爽| 清纯美女在线观看国产| 国产一区二区三免费视频| 免费69视频在线看| 亚洲综合另类精品小说| av视网站在线观看| 最新日韩av传媒在线| 岛国毛片视频免费在线观看| 精品av久久久久久久| 91久久人澡人人添人人爽乱| 日本av在线一区二区三区| 青青青青青操视频在线观看| av完全免费在线观看av| 国产精品日韩欧美一区二区| 日韩中文字幕精品淫| 不卡一区一区三区在线| 欧美成人综合色在线噜噜| 亚洲成人精品女人久久久| 任你操任你干精品在线视频| 色婷婷综合激情五月免费观看 | 国产夫妻视频在线观看免费| av天堂中文免费在线| 天天干天天爱天天色| 国产乱子伦一二三区| 免费成人va在线观看| 成人30分钟免费视频| 99热这里只有精品中文| av老司机亚洲一区二区| 日本一本午夜在线播放| 大骚逼91抽插出水视频| 亚洲欧美激情国产综合久久久 | 不卡精品视频在线观看| 日韩成人性色生活片| 91极品大一女神正在播放| 福利午夜视频在线合集| 天天操,天天干,天天射| 色综合久久无码中文字幕波多| 成人av久久精品一区二区| 久久久久久久亚洲午夜综合福利| 精彩视频99免费在线| 亚洲欧美一区二区三区电影| 亚洲青青操骚货在线视频| 亚洲福利精品视频在线免费观看| 精彩视频99免费在线| 欧美偷拍自拍色图片| 亚洲综合在线视频可播放| 亚洲va天堂va国产va久| 视频一区 视频二区 视频| 99久久激情婷婷综合五月天| 在线观看av亚洲情色| 少妇露脸深喉口爆吞精| 最近中文字幕国产在线| 一区二区熟女人妻视频| xxx日本hd高清| 久久久久久久久久久免费女人| 日本熟女精品一区二区三区| 韩国三级aaaaa高清视频 | 99人妻视频免费在线| 亚洲日本一区二区久久久精品| 在线播放 日韩 av| 老司机深夜免费福利视频在线观看| 中文字幕在线观看极品视频| 欧美麻豆av在线播放| 老司机99精品视频在线观看| 青娱乐极品视频青青草| 巨乳人妻日下部加奈被邻居中出 | 亚洲一级特黄特黄黄色录像片| 久久永久免费精品人妻专区| 亚洲福利精品视频在线免费观看| 亚洲成a人片777777| 视频啪啪啪免费观看| 中文字幕视频一区二区在线观看| 自拍偷拍 国产资源| 欧美亚洲国产成人免费在线 | 香蕉91一区二区三区| 97资源人妻免费在线视频| 欧美黑人性暴力猛交喷水| 国产日韩一区二区在线看| 黑人乱偷人妻中文字幕| 日本人妻少妇18—xx| 亚洲精品成人网久久久久久小说| 中文字幕一区二 区二三区四区 | 日本熟妇一区二区x x| 91国内精品自线在拍白富美| 9l人妻人人爽人人爽| 一区二区久久成人网| 国产精品久久久久久久精品视频| 成年人黄色片免费网站| 熟女人妻在线中出观看完整版| 亚洲专区激情在线观看视频| nagger可以指黑人吗| 天天操天天插天天色| 日韩中文字幕精品淫| 天堂资源网av中文字幕| 91快播视频在线观看| 黄色视频在线观看高清无码 | 日本黄色特一级视频| 国产男女视频在线播放| 婷婷五月亚洲综合在线| 欧美伊人久久大香线蕉综合| 中文字幕高清资源站| av手机在线观播放网站| 亚洲伊人久久精品影院一美女洗澡| 天堂av狠狠操蜜桃| 午夜精品在线视频一区| 天堂资源网av中文字幕| 国产黄色a级三级三级三级| 欧美成人综合视频一区二区| 亚洲免费国产在线日韩| 青娱乐蜜桃臀av色| 欧美视频中文一区二区三区| caoporm超碰国产| 91精品啪在线免费| 欧美日韩精品永久免费网址 | 日本xx片在线观看| 国产精品人久久久久久| 午夜免费观看精品视频| 最新欧美一二三视频| 久久久久久性虐视频| 伊人综合免费在线视频| 在线免费观看99视频| 亚洲成人线上免费视频观看| 绝顶痉挛大潮喷高潮无码| 夫妻在线观看视频91| 40道精品招牌菜特色| 久久久久久97三级| 亚洲综合图片20p| 特黄老太婆aa毛毛片| 国产自拍在线观看成人| 久久久久久久精品老熟妇| 精品高潮呻吟久久av| 伊人开心婷婷国产av| 啊啊好大好爽啊啊操我啊啊视频 | 欧美一级色视频美日韩| 国产剧情演绎系列丝袜高跟| 日日夜夜大香蕉伊人| 精品成人啪啪18免费蜜臀| 亚洲一级美女啪啪啪| 黄色中文字幕在线播放| 日本高清在线不卡一区二区| 亚洲av第国产精品| 国产麻豆乱子伦午夜视频观看| 国产精品黄页网站视频| 新婚人妻聚会被中出| 天天操天天弄天天射| 精品一区二区三区三区88| 免费黄页网站4188| 日本福利午夜电影在线观看| 全国亚洲男人的天堂| 自拍偷拍一区二区三区图片| 成年人啪啪视频在线观看| 免费人成黄页网站在线观看国产| 欧美精品一区二区三区xxxx| 亚洲精品亚洲人成在线导航| 国产精品国色综合久久 | 久草视频首页在线观看| 粉嫩av蜜乳av蜜臀| 五月精品丁香久久久久福利社| 11久久久久久久久久久| 97人妻无码AV碰碰视频| 又色又爽又黄又刺激av网站| 91破解版永久免费| 99亚洲美女一区二区三区| 国内资源最丰富的网站| 黄色录像鸡巴插进去| www日韩a级s片av| 鸡巴操逼一级黄色气| 欧美日韩情色在线观看| 日本少妇的秘密免费视频| 日日日日日日日日夜夜夜夜夜夜| 97人妻总资源视频| 日韩近亲视频在线观看| 中文字母永久播放1区2区3区| 精彩视频99免费在线| 3344免费偷拍视频| 国产一区二区视频观看| 中文字幕日韩人妻在线三区| 精品视频一区二区三区四区五区| 日韩剧情片电影在线收看| 精品一区二区三区欧美| 日本性感美女写真视频| 91国内视频在线观看| 日日操综合成人av| 亚洲 中文字幕在线 日韩| 中文字幕欧美日韩射射一| 欧美精品免费aaaaaa| 精品av久久久久久久| 91自产国产精品视频| 中文字幕欧美日韩射射一| 国产精品黄页网站视频| 亚洲熟妇x久久av久久| 伊人成人综合开心网| 国产日本精品久久久久久久| 欧美成人综合视频一区二区| 少妇系列一区二区三区视频| 国产真实灌醉下药美女av福利| 久久精品美女免费视频| 日本少妇在线视频大香蕉在线观看| 日视频免费在线观看| 国产一区av澳门在线观看| 日韩美女福利视频网| 亚洲一区自拍高清免费视频| 亚洲一区二区三区精品乱码| v888av在线观看视频| 国产精品久久久久国产三级试频| 在线观看国产免费麻豆| 欧美成一区二区三区四区| 欧美日韩高清午夜蜜桃大香蕉| 亚洲国产免费av一区二区三区| 日韩视频一区二区免费观看| v888av在线观看视频| 韩国AV无码不卡在线播放| 国产日韩一区二区在线看| 少妇人妻久久久久视频黄片| 免费大片在线观看视频网站| 欧洲国产成人精品91铁牛tv| ka0ri在线视频| 人妻另类专区欧美制服| 亚洲国际青青操综合网站| 国产又粗又硬又猛的毛片视频 | 亚洲 清纯 国产com| 夜夜嗨av一区二区三区中文字幕| 国产又粗又黄又硬又爽| 都市激情校园春色狠狠| 综合一区二区三区蜜臀| 偷拍美女一区二区三区| 亚洲国产美女一区二区三区软件| 在线观看国产网站资源| 中文字幕在线观看极品视频| 亚洲在线一区二区欧美| 人妻久久无码中文成人| 91大神福利视频网| 国产黄色片在线收看| 制服丝袜在线人妻中文字幕| 亚洲 欧美 自拍 偷拍 在线| 2022精品久久久久久中文字幕| 欧美精品国产综合久久| 日本美女性生活一级片| av手机在线观播放网站| 久久国产精品精品美女| 国产精品中文av在线播放| 日本黄色三级高清视频| av老司机亚洲一区二区| 亚洲精品高清自拍av| 久久综合老鸭窝色综合久久| www天堂在线久久| 日本美女成人在线视频| 2025年人妻中文字幕乱码在线| 中文字幕在线乱码一区二区| 91麻豆精品91久久久久同性| 亚洲伊人久久精品影院一美女洗澡| 性色蜜臀av一区二区三区| 绝顶痉挛大潮喷高潮无码 | 淫秽激情视频免费观看| 人人妻人人澡欧美91精品| 免费观看理论片完整版| 91av中文视频在线| 亚洲综合色在线免费观看| 亚洲麻豆一区二区三区| 天堂av狠狠操蜜桃| 在线观看av亚洲情色| 五十路在线观看完整版| 啪啪啪18禁一区二区三区| 粉嫩欧美美人妻小视频| 婷婷午夜国产精品久久久| 天天日天天干天天干天天日| 动漫精品视频在线观看| 免费69视频在线看| 日韩一区二区三区三州| 黄网十四区丁香社区激情五月天| 2022国产精品视频| 久久精品国产999| 97欧洲一区二区精品免费| 国产免费av一区二区凹凸四季| 久久久久久久久久性潮| 亚洲va欧美va人人爽3p| 欧美一区二区三区四区性视频| 免费观看理论片完整版| 欧美成人黄片一区二区三区| 青青青激情在线观看视频| 国产日韩精品电影7777| 欧美另类z0z变态| 老司机福利精品免费视频一区二区 | 日辽宁老肥女在线观看视频| 天天想要天天操天天干| 亚洲成人激情视频免费观看了 | 国产在线拍揄自揄视频网站| 成人伊人精品色xxxx视频| 最新97国产在线视频| 久久久久五月天丁香社区| 黄色大片男人操女人逼| 亚洲国产精品黑丝美女| 少妇人妻久久久久视频黄片| 超碰公开大香蕉97| 日本男女操逼视频免费看| 中文字幕在线视频一区二区三区 | 亚洲码av无色中文| 在线国产精品一区二区三区| 一区二区三区精品日本| 蜜臀成人av在线播放| 黄色录像鸡巴插进去| 亚洲成人三级在线播放| 日噜噜噜夜夜噜噜噜天天噜噜噜| 国产在线拍揄自揄视频网站| 阴茎插到阴道里面的视频| 开心 色 六月 婷婷| 久久久久久9999久久久久| 亚洲一级av无码一级久久精品| 欧美激情电影免费在线| 亚洲无码一区在线影院| chinese国产盗摄一区二区| 99av国产精品欲麻豆| 亚洲天堂精品久久久| 亚洲熟妇x久久av久久| 精品人妻每日一部精品| 在线观看国产网站资源| 日本一二三区不卡无| 日韩不卡中文在线视频网站| 久草视频福利在线首页| 国产自拍在线观看成人| 成年人中文字幕在线观看| 婷婷久久久久深爱网| 久久久麻豆精亚洲av麻花| 好吊操视频这里只有精品| 成人在线欧美日韩国产| 97资源人妻免费在线视频| 99精品国自产在线人| 成年午夜免费无码区| 99国内小视频在现欢看| 欧美性受xx黑人性猛交| 91九色porny国产蝌蚪视频| 老司机福利精品免费视频一区二区| 亚洲精品三级av在线免费观看| 亚洲熟妇x久久av久久| 青青青视频自偷自拍38碰| 免费十精品十国产网站| 国产一区二区视频观看| 97超碰国语国产97超碰| 欧美一级片免费在线成人观看| 一级A一级a爰片免费免会员| 亚洲福利午夜久久久精品电影网| 国际av大片在线免费观看| 亚洲高清一区二区三区视频在线| 亚洲日本一区二区三区| 国产精选一区在线播放| 欧美日韩国产一区二区三区三州| 男人和女人激情视频| 天天日天天摸天天爱| 在线观看操大逼视频| 亚洲熟女女同志女同| 91色网站免费在线观看| 亚洲在线观看中文字幕av| 日本啪啪啪啪啪啪啪| 久久艹在线观看视频| 护士特殊服务久久久久久久| sejizz在线视频| 天天干天天插天天谢| 少妇人妻久久久久视频黄片| 在线观看黄色成年人网站| 国产美女精品福利在线| 视频一区 二区 三区 综合| 在线免费视频 自拍| 美味人妻2在线播放| 成人乱码一区二区三区av| 啊慢点鸡巴太大了啊舒服视频| 亚洲人妻av毛片在线| 丝袜国产专区在线观看| 日韩伦理短片在线观看| 一区二区免费高清黄色视频| 人人在线视频一区二区| 一本久久精品一区二区| rct470中文字幕在线| 这里有精品成人国产99| 青青青青操在线观看免费| 中文字幕 亚洲av| 欧美老鸡巴日小嫩逼| 福利一二三在线视频观看 | 亚洲欧美久久久久久久久| 大骚逼91抽插出水视频| 红杏久久av人妻一区| 国产综合精品久久久久蜜臀| 青青青青青青草国产| 老有所依在线观看完整版| 久久丁香婷婷六月天| 超级碰碰在线视频免费观看| 欧美日本aⅴ免费视频| 亚洲精品 欧美日韩| 亚洲综合乱码一区二区| 精品区一区二区三区四区人妻| 青青草原网站在线观看| 国产精品精品精品999| 天天色天天爱天天爽| 一区二区在线观看少妇| 欧美中国日韩久久精品| 亚洲中文字幕乱码区| 成年人的在线免费视频| 婷婷久久一区二区字幕网址你懂得| 在线视频自拍第三页| 国产大鸡巴大鸡巴操小骚逼小骚逼| 国产亚州色婷婷久久99精品| 亚洲欧美另类手机在线| 欧美性感尤物人妻在线免费看| 操操网操操伊剧情片中文字幕网| 97年大学生大白天操逼| 青青色国产视频在线| 日韩欧美高清免费在线| 色呦呦视频在线观看视频| 天美传媒mv视频在线观看| 99精品久久久久久久91蜜桃| eeuss鲁片一区二区三区| 狠狠操狠狠操免费视频| 91亚洲手机在线视频播放| 91亚洲手机在线视频播放| 美女被肏内射视频网站| 国产成人精品亚洲男人的天堂| 中国把吊插入阴蒂的视频| 日本乱人一区二区三区| 午夜频道成人在线91| 亚洲1区2区3区精华液| 老鸭窝在线观看一区| 蜜桃专区一区二区在线观看| 第一福利视频在线观看| 中英文字幕av一区| 在线可以看的视频你懂的| 青春草视频在线免费播放| 一区二区三区日本伦理| 国产精品国产三级麻豆| 久久久久久9999久久久久| 青娱乐最新视频在线| 成人国产影院在线观看| 亚洲人一区二区中文字幕| 国产精品人妻熟女毛片av久| 亚洲欧美清纯唯美另类| 黄色片黄色片wyaa| 成人高清在线观看视频| 日本美女成人在线视频| 亚洲成人av一区在线| 老司机午夜精品视频资源 | 99热久久极品热亚洲| 亚洲最大黄 嗯色 操 啊| 日韩无码国产精品强奸乱伦| 2021年国产精品自拍| 999九九久久久精品| 一区二区三区的久久的蜜桃的视频| av老司机亚洲一区二区| 日本五十路熟新垣里子| 国产乱子伦精品视频潮优女| 久久香蕉国产免费天天| 欧美精品 日韩国产| 好吊视频—区二区三区| 一区二区免费高清黄色视频| 在线观看免费视频网| 国产免费高清视频视频| 国产精品久久久黄网站| 日本少妇人妻xxxxx18| 精品人妻一二三区久久| 2021年国产精品自拍| 91破解版永久免费| 狠狠地躁夜夜躁日日躁| 精品亚洲国产中文自在线| av中文字幕福利网| 最近的中文字幕在线mv视频| 欧美精品资源在线观看| 亚洲精品欧美日韩在线播放| 国产揄拍高清国内精品对白| 亚洲av日韩高清hd| 一本久久精品一区二区| 绝色少妇高潮3在线观看| 果冻传媒av一区二区三区| 欧美怡红院视频在线观看| av在线免费观看亚洲天堂| 亚洲人人妻一区二区三区| 激情啪啪啪啪一区二区三区| 91国产在线免费播放| 国产三级精品三级在线不卡| 熟女妇女老妇一二三区| 亚洲av无码成人精品区辽| 精品国产乱码一区二区三区乱| 大屁股肉感人妻中文字幕在线| 中文字幕在线视频一区二区三区| 欧美精产国品一二三区| 国产高清在线在线视频| 天天干天天搞天天摸| 在线制服丝袜中文字幕| 亚洲一级av无码一级久久精品| 精品老妇女久久9g国产| 亚洲午夜福利中文乱码字幕| 中文字幕人妻被公上司喝醉在线 | 亚洲日本一区二区久久久精品| 在线观看视频一区麻豆| 伊人成人在线综合网| 免费在线观看视频啪啪 | 午夜在线一区二区免费| 中国老熟女偷拍第一页| 欧美韩国日本国产亚洲| 激情综合治理六月婷婷| 激情色图一区二区三区| 亚洲福利天堂久久久久久| 伊人综合免费在线视频| av视网站在线观看| 国产欧美日韩第三页| 黄色资源视频网站日韩| 亚洲成人黄色一区二区三区| 天天摸天天干天天操科普| 国产日韩欧美美利坚蜜臀懂色| 黄色男人的天堂视频| 好太好爽好想要免费| 夜色福利视频在线观看| 久精品人妻一区二区三区| 综合精品久久久久97| 国产精品一区二区av国| 午夜91一区二区三区| 伊人日日日草夜夜草| 青青青视频自偷自拍38碰| 熟女少妇激情五十路| 国产欧美精品一区二区高清| 521精品视频在线观看| 小穴多水久久精品免费看| 国产一区二区火爆视频| 日韩成人性色生活片| 久久久久久久久久性潮| 中文字幕人妻三级在线观看| 人妻久久无码中文成人| av视网站在线观看| 国产免费av一区二区凹凸四季| 在线免费观看靠比视频的网站| 久久精品亚洲国产av香蕉| 天天日天天爽天天干| 美女小视频网站在线| 亚洲熟妇无码一区二区三区| 精品一区二区亚洲欧美| av亚洲中文天堂字幕网| 91精品国产91久久自产久强| 色综合久久久久久久久中文| 青青青青青免费视频| 青青青艹视频在线观看| 91久久精品色伊人6882| 日本脱亚入欧是指什么| 91精品一区二区三区站长推荐| japanese日本熟妇另类| 操的小逼流水的文章| 欧美特级特黄a大片免费| 亚洲免费va在线播放| 国产va在线观看精品| 日本熟女精品一区二区三区| 人妻另类专区欧美制服| 年轻的人妻被夫上司侵犯| 美日韩在线视频免费看| 国产高清精品一区二区三区| 天天干夜夜操天天舔| av老司机亚洲一区二区| 人妻凌辱欧美丰满熟妇| 亚洲久久午夜av一区二区| 欧美久久久久久三级网| 大香蕉大香蕉在线看| 97黄网站在线观看| 日韩欧美国产一区不卡| 自拍偷拍,中文字幕| 亚洲精品亚洲人成在线导航| 亚洲国产精品免费在线观看| 亚洲美女自偷自拍11页| 偷拍自拍国产在线视频|