婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > drf序列化器serializer的具體使用

drf序列化器serializer的具體使用

熱門標(biāo)簽:外賣地址有什么地圖標(biāo)注 銀川電話機(jī)器人電話 煙臺(tái)電話外呼營(yíng)銷系統(tǒng) 企業(yè)彩鈴地圖標(biāo)注 預(yù)覽式外呼系統(tǒng) 電銷機(jī)器人錄音要學(xué)習(xí)什么 如何地圖標(biāo)注公司 上海正規(guī)的外呼系統(tǒng)最新報(bào)價(jià) 長(zhǎng)春極信防封電銷卡批發(fā)

一、序列化器-serializer

  • 序列化,序列化器會(huì)把模型對(duì)象轉(zhuǎn)成字典,經(jīng)過(guò)response以后變成JSON字符串
  • 反序列化:把客戶端發(fā)送過(guò)來(lái)的數(shù)據(jù),經(jīng)過(guò)request以后變成字典,序列化器可以把字典轉(zhuǎn)成模型
  • 反序列化:完成數(shù)據(jù)校驗(yàn)功能

二、序列化器的使用

序列化器的使用分為兩個(gè)階段:

  • 在客戶端請(qǐng)求時(shí),使用序列化器可以完成對(duì)數(shù)據(jù)的反序列化。
  • 在服務(wù)器響應(yīng)時(shí),使用序列化器可以完成對(duì)數(shù)據(jù)的序列化。

簡(jiǎn)單使用

1、創(chuàng)建一個(gè)表模型

from django.db import models

class Books(models.Model):
    title = models.CharField(verbose_name='書(shū)名', max_length=32)
    publish = models.CharField(verbose_name='出版社', max_length=32)
    price = models.DecimalField(verbose_name='價(jià)格', max_digits=5, decimal_places=2)

2、新建一個(gè)py文件,寫一個(gè)序列化的類,繼承Serializer

3、在類中寫要序列化的字段,想序列化那個(gè)字段,就在類中寫那個(gè)字段

from rest_framework import serializers

class BooksSerializer(serializers.Serializer):
    title = serializers.CharField()
    publish = serializers.CharField()
    price = serializers.DecimalField()

4、在視圖類中使用,導(dǎo)入——》實(shí)例化得到序列化對(duì)象,把要序列化的對(duì)象傳入

5、序列化的對(duì)象.data——》是一個(gè)字典

6、把字典返回,如果不使用rest_framework提供的Response,就得使用JsonResponse

from rest_framework.views import APIView
from rest_framework.request import Request
from app01.models import Books
from app01.ser import BooksSerializer

class BookView(APIView):
    def get(self, request, pk):
        # 響應(yīng)信息
        response_msg = {'status': 200, 'message': '查詢成功'}
        # 獲取要序列化的對(duì)象
        book = Books.objects.filter(pk=pk).first()
        # 要序列化誰(shuí)就把誰(shuí)傳到序列化類去
        book_ser = BooksSerializer(book)
        # book_ser.data————》序列化對(duì)象.data————》就是序列化后的字典
        # 將查詢結(jié)果添加到響應(yīng)信息內(nèi)
        response_msg['data'] = book_ser.data
        return Response(response_msg)
    
 # urls.py
re_path(r'^book/(?Ppk>\d+)/', views.BookView.as_view()),

7、如果要被序列化的是包含多條數(shù)據(jù)的查詢集queryset,可以通過(guò)添加many=True參數(shù)

from rest_framework.views import APIView
from rest_framework.response import Response
from app01.models import Books
from app01.ser import BooksSerializer


class BooksView(APIView):
    def get(self, request):
        # 響應(yīng)信息
        response_msg = {'status': 200, 'message': '查詢成功'}
        books = Books.objects.all()
        # 要序列化誰(shuí)就把誰(shuí)傳到序列化類去
        book_ser = BooksSerializer(books, many=True)
        # book_ser.data————》序列化對(duì)象.data————》就是序列化后的字典
        # 將查詢結(jié)果添加到響應(yīng)信息內(nèi)
        response_msg['data'] = book_ser.data
        return Response(response_msg)

# urls.py
re_path(r'^books/', views.BookView.as_view()),

高級(jí)使用

source

1、可以修改字段名字

class BooksSerializer(serializers.Serializer):
    xxx = serializers.CharField(source='title')  # 相當(dāng)于——》xxx = Books.title
      
# 響應(yīng)
{
    "status": 200,
    "message": "查詢成功",
    "data": {
        "xxx": "魔道祖師"   ————》響應(yīng)的字段名被修改了
    }
}

2、可以跨表查詢

class BookSerializer(serializers.Serializer):
    publish_email = serializers.CharField(source='publish.email')
    # 相當(dāng)于——》publish_email = Book.publish.email 連表查詢publish表的email字段
    
    
# 響應(yīng)
{
    "status": 200,
    "message": "查詢成功",
    "data": {
        "publish_email": "modao@163.com"
    }
}

3、可以執(zhí)行方法

# models.py
class Book(models.Model):
    title = models.CharField(max_length=32)
    price = models.IntegerField()
    pub_date = models.DateTimeField()
    publish = models.ForeignKey("Publish", on_delete=models.CASCADE, null=True)
    authors = models.ManyToManyField("Author")

    def func(self):
        return '666666'

    
# ser.py
class BookSerializer(serializers.Serializer):
    msg = serializers.CharField(source='func')
    # msg = Book.func  ——》調(diào)用Book類中的func()方法的返回值
    
    
# 響應(yīng)
{
    "status": 200,
    "message": "查詢成功",
    "data": {
        "msg": "666666"
    }
}

**SerializerMethodField( ) **

它需要有一個(gè)配套的方法,方法名叫做get_字段名,返回值就是要顯示的東西

class BookSerializer(serializers.Serializer):
    authors = serializers.SerializerMethodField()

    def get_authors(self, instance):
        # instance ——》 Book對(duì)象
        authors = instance.authors.all()    # 取出所有作者
        author_list = []
        for author in authors:
            author_list.append({'name': author.name, 'age': author.age})
        return author_list

通用參數(shù)

read_only:(只讀)表明該字段僅用于序列化輸出,默認(rèn)False,如果設(shè)置成True,響應(yīng)中可以看到該字段,修改時(shí),不需要傳該字段

write_only:(只寫)表明該字段僅用于反序列化輸入,默認(rèn)False,如果設(shè)置成True,響應(yīng)中看不到該字段,修改時(shí),該字段需要傳

from rest_framework import serializers

class BooksSerializer(serializers.Serializer):
    title = serializers.CharField(read_only = True)  # 響應(yīng)中能看到改字段,修改不需要傳值
    publish = serializers.CharField(write_only = True) # 響應(yīng)中看不到改字段,修改需要傳值
    price = serializers.DecimalField()

還有參數(shù)如下:

  • required  表明該字段在反序列化時(shí)必須輸入,默認(rèn)True
  • default   反序列化時(shí)使用的默認(rèn)值
  • allow_null  表明該字段是否允許傳入None,默認(rèn)False
  • validators  該字段使用的驗(yàn)證器
  • error_messages 包含錯(cuò)誤編號(hào)與錯(cuò)誤信息的字典

三、反序列化數(shù)據(jù)校驗(yàn)

當(dāng)使用序列化器對(duì)數(shù)據(jù)進(jìn)行反序列化時(shí),就需要對(duì)數(shù)據(jù)進(jìn)行校驗(yàn)了,只有校驗(yàn)成功的數(shù)據(jù)才能被保存成模型類對(duì)象

將要校驗(yàn)的數(shù)據(jù)傳入序列化器中并實(shí)例化:obj = BooksSerializer(data=request.data),調(diào)用is_valid()方法校驗(yàn),校驗(yàn)成功返回True,失敗返回False。

失敗,可以通過(guò)序列化器對(duì)象的errors獲取錯(cuò)誤信息(字典)

成功,可以公共序列化對(duì)象的validated_data屬性獲取數(shù)據(jù)。

校驗(yàn)方法有:局部鉤子,全局鉤子,validators,和序列化類型和字段屬性也是

字段屬性

  • max_length  最大長(zhǎng)度
  • min_lenght  最小長(zhǎng)度
  • allow_blank  是否允許為空
  • trim_whitespace 是否截?cái)嗫瞻鬃址?/li>
  • max_value  最小值
  • min_value  最大值

局部鉤子

在序列化器類中創(chuàng)建局部鉤子:validate_字段名,并且接收一個(gè)參數(shù)

# ser.py
class BooksSerializer(serializers.Serializer):
    title = serializers.CharField()
    publish = serializers.CharField()
    price = serializers.DecimalField(max_digits=5, decimal_places=2)
    
    # 局部鉤子對(duì)price字段校驗(yàn)
    def validate_price(self, data):
        if float(data) > 20:
            # 校驗(yàn)成功就通過(guò)
            return data
        else:
            # 校驗(yàn)失敗就拋異常
            raise ValidationError('價(jià)格太低')

全局鉤子

全局鉤子:validate( ), 接收一個(gè)參數(shù),

同時(shí)對(duì)多個(gè)字段進(jìn)行比較驗(yàn)證

# ser.py
class BooksSerializer(serializers.Serializer):
    title = serializers.CharField()
    publish = serializers.CharField()
    price = serializers.DecimalField(max_digits=5, decimal_places=2)
    
def validate(self, validate_data):
    title = validate_data.get('title')
    publish = validate_data.get('publish')
    if not title == publish:
        return validate_data
    else:
        raise ValidationError('書(shū)名和出版社不能一致')

validators

使用字段的validators=[func],來(lái)校驗(yàn)

# ser.py
# 校驗(yàn)函數(shù)
def check_price(data):
    if float(data) > 10:
        return data
    else:
        raise ValidationError('價(jià)格太低')

class BooksSerializer(serializers.Serializer):
    title = serializers.CharField()
    publish = serializers.CharField()
    price = serializers.CharField(validators=[check_price]) # 配置

四、序列化器操作數(shù)據(jù)

查詢所有

# views.py
class BooksView(APIView):
    def get(self, request):
        # 響應(yīng)信息
        response_msg = {'status': 200, 'message': '查詢成功'}
        # 獲取所有數(shù)據(jù)
        books = Books.objects.all()
        # 把數(shù)據(jù)誰(shuí)傳到序列化器中
        book_ser = BooksSerializer(instance=books, many=True) # 序列化多條需要加 many=True
        # book_ser.data————》序列化對(duì)象.data————》就是序列化后的字典
        # 將查詢結(jié)果添加到響應(yīng)信息內(nèi)
        response_msg['data'] = book_ser.data
        return Response(response_msg)
    
# urls.py
path('books/', views.BooksView.as_view()),

查詢單條

# views.py
class BookView(APIView):
    def get(self, request, pk):
        # 響應(yīng)信息
        response_msg = {'status': 200, 'message': '查詢成功'}
        # 獲取要序列化的對(duì)象
        book = Books.objects.filter(pk=pk).first()
        # 要序列化誰(shuí)就把誰(shuí)傳到序列化器中
        book_ser = BooksSerializer(instance=book)
        # book_ser.data————》序列化對(duì)象.data————》就是序列化后的字典
        # 將查詢結(jié)果添加到響應(yīng)信息內(nèi)
        response_msg['data'] = book_ser.data
        return Response(response_msg)
    
# urls.py
re_path(r'^book/(?Ppk>\d+)/', views.BookView.as_view()),

新增數(shù)據(jù)

新增數(shù)據(jù)需要在序列化器中重寫create( ) 方法:

注意沒(méi)有傳遞instance實(shí)例,則調(diào)用save()方法的時(shí)候,create()被調(diào)用,相反,如果傳遞了instance實(shí)例,調(diào)用save()方法的時(shí)候,update()被調(diào)用。

# views.py
class BookView(APIView):
    def post(self, request):
        # 響應(yīng)信息
        response_msg = {'status': 201, 'message': '增加成功'}
        # 修改才有instance,新增沒(méi)有instance,只有data
        book_ser = BooksSerializer(data=request.data)

        # 校驗(yàn)字段
        if book_ser.is_valid():
            book_ser.save()  # 需要在序列化器中重寫create()方法
            # 保存成功把原數(shù)據(jù)返回
            response_msg['data'] = book_ser.data
        else:
            response_msg['status'] = 202
            response_msg['message'] = '數(shù)據(jù)校驗(yàn)失敗'
            response_msg['data'] = book_ser.error_messages
        return Response(response_msg)
    
    
# ser.py
class BooksSerializer(serializers.Serializer):
    title = serializers.CharField()
    publish = serializers.CharField()
    price = serializers.DecimalField(max_digits=5, decimal_places=2)

    # 重寫create
    def create(self, validated_data):   # validated_data——>傳入的新增數(shù)據(jù)
        instance = Books.objects.create(**validated_data)
        # instance——> 新增的字段對(duì)象,需要返回
        return instance
       
# urls.py
path('book/', views.BookView.as_view()),

修改數(shù)據(jù)

修改數(shù)據(jù)需要在序列化器中重寫update( ) 方法:

# views.py
class BookView(APIView):
    def put(self, request, pk):
        # 響應(yīng)信息
        response_msg = {'status': 200, 'message': '修改成功'}
        # 獲取需要修改的字段對(duì)象
        book = Books.objects.filter(pk=pk).first()
        # 將字段對(duì)象和修改數(shù)據(jù)添加到序列化器中
        book_ser = BooksSerializer(instance=book, data=request.data)

        # 校驗(yàn)數(shù)據(jù)
        if book_ser.is_valid():
            book_ser.save()     # 需要在序列化器中重寫update()方法
            response_msg['data'] = book_ser.data
        else:
            response_msg['status'] = 202
            response_msg['message'] = '數(shù)據(jù)校驗(yàn)失敗'
            response_msg['data'] = book_ser.error_messages
        return Response(response_msg)
    
# urls.py
re_path('book/(?Ppk>\d+)', views.BookView.as_view()),

刪除數(shù)據(jù)

# views.py
class BooksView(APIView):
    def delete(self, request, pk):
    # 響應(yīng)信息
    response_msg = {'status': 200, 'message': '刪除成功'}
    # 刪除數(shù)據(jù)
    Books.objects.filter(pk=pk).delete()
    return Response(response_msg)
    
# urls.py
re_path('book/(?Ppk>\d+)', views.BooksView.as_view()),

五、模型類序列化器

DRF提供了ModelSerializer模型類序列化器來(lái)幫助我們快速創(chuàng)建一個(gè)Serializer類。

ModelSerializer與常規(guī)的Serializer相同,但是提供了:

  • 基于模型類自動(dòng)生成一系列字段
  • 基于模型類自動(dòng)為Serializer生成validators,比如unique_together
  • 包含默認(rèn)的create( ) 和update( )。

實(shí)例:

class BookSerializer(serializers.ModelSerializer):
    class Meta:
        model = Book        # 指明參照那個(gè)模型類
        fields = '__all__'  # 為模型類的那些字段生成

字段操作

1、可以使用fields來(lái)明確字段,__all__表示包含所以字段,具體那些字段->fields = ('title','price')

2、exclude表示排除那些字段,不能和fields一起寫——>exclude = ('price',)

3、額外參數(shù)extra_kwargs,給字段添加額外的參數(shù)

class BookSerializer(serializers.ModelSerializer):
    class Meta:
        model = Book        # 指明參照那個(gè)模型類
        fields = '__all__'  # 為模型類的那些字段生成
  
        # 類似于  title = serializers.CharField(read_only = True)
        extra_kwargs = {
            'title': {'read_only': True},
        }

六、源碼分析many=True

當(dāng)我們需要查詢多條數(shù)據(jù)時(shí)就需要在實(shí)例化序列化器的時(shí)候傳many=True

book_ser = BooksSerializer(instance=books, many=True) # 查詢多條
book_one_ser = BooksSerializer(instance=book) # 查詢單條

print(type(book_ser))
#class 'rest_framework.serializers.ListSerializer'>

print(type(book_one_ser))
#class 'app01.ser.BookModelSerializer'>

# 對(duì)象的生成-->先調(diào)用類的__new__方法,生成空對(duì)象,如果many=True,生成ListSerializer對(duì)象,反之生成Serializer對(duì)象

# 類的__new__方法控制對(duì)象的生成
def __new__(cls, *args, **kwargs):
    # 如果many=True,就會(huì)自動(dòng)創(chuàng)建ListSerializer類
    if kwargs.pop('many', False):
        return cls.many_init(*args, **kwargs)
    return super().__new__(cls, *args, **kwargs)

到此這篇關(guān)于drf序列化器serializer的具體使用的文章就介紹到這了,更多相關(guān)drf序列化器serializer內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • DRF跨域后端解決之django-cors-headers的使用
  • django DRF圖片路徑問(wèn)題的解決方法
  • Django框架之DRF 基于mixins來(lái)封裝的視圖詳解
  • DRF使用simple JWT身份驗(yàn)證的實(shí)現(xiàn)
  • Django DRF APIView源碼運(yùn)行流程詳解
  • python drf各類組件的用法和作用
  • DRF框架API版本管理實(shí)現(xiàn)方法解析
  • Django drf請(qǐng)求模塊源碼解析

標(biāo)簽:佳木斯 盤錦 上饒 潮州 湖北 珠海 西寧 宜昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《drf序列化器serializer的具體使用》,本文關(guān)鍵詞  drf,序列化,器,serializer,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《drf序列化器serializer的具體使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于drf序列化器serializer的具體使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久久久久久久久久电影| 欧美三级一区二区| 久久免费午夜影院| 99视频一区二区| 97久久超碰国产精品电影| 日一区二区三区| 欧美成人a在线| 欧美aaa在线| 亚洲精品va在线观看| 色噜噜狠狠成人中文综合| 欧美日本不卡视频| 国产自产2019最新不卡| 中文字幕在线视频一区| 丁香激情综合五月| 日韩影视精彩在线| 欧美极品xxx| 日韩欧美中文字幕精品| 奇米影视一区二区三区小说| 成人app下载| 亚洲综合小说图片| 69堂成人精品免费视频| 69p69国产精品| 波多野结衣中文字幕一区| 69久久99精品久久久久婷婷| 99热精品一区二区| 亚洲精品成人a在线观看| 色8久久精品久久久久久蜜| 欧美经典一区二区| 不卡的电影网站| 亚洲品质自拍视频网站| 成人av手机在线观看| 欧美一区二区三区系列电影| 久久国产精品一区二区| 婷婷综合另类小说色区| 亚洲欧洲av另类| 精品少妇一区二区三区在线视频| 亚洲妇女屁股眼交7| 日韩电影网1区2区| 国内外精品视频| 亚洲综合久久久| 成人免费在线视频| 欧美大黄免费观看| 国产日韩视频一区二区三区| 欧美性受xxxx| 亚洲最色的网站| 国产乱码精品一品二品| 亚洲欧洲成人av每日更新| 精品欧美一区二区久久| 国产不卡视频在线播放| 欧美日韩国产综合久久| 久久亚洲一区二区三区四区| 欧美成人vps| 福利视频网站一区二区三区| 日韩精品欧美精品| 不卡的电影网站| 亚洲天堂成人网| 色婷婷综合久久久久中文一区二区| 日本欧美韩国一区三区| 久久久久久久电影| 懂色av一区二区三区免费看| 亚洲另类色综合网站| 久久亚洲精品小早川怜子| 国产乱码精品一品二品| 亚洲制服丝袜av| 五月婷婷激情综合| 九色porny丨国产精品| 91在线观看高清| 精品一区二区三区免费| 久久夜色精品一区| 日韩国产欧美在线播放| 国产一二三精品| 欧美一区二区成人6969| 久久久久久黄色| 国产91精品精华液一区二区三区 | 天天亚洲美女在线视频| 欧美体内she精高潮| 欧美一级一区二区| 久久超级碰视频| 亚洲人成亚洲人成在线观看图片| 色综合av在线| 国产激情一区二区三区四区 | 国产精品99久久久久| 91精品国产乱码久久蜜臀| 久久国产尿小便嘘嘘| 中文字幕在线播放不卡一区| 日本一区二区三区高清不卡| 91久久人澡人人添人人爽欧美| 秋霞av亚洲一区二区三| 日产国产欧美视频一区精品| 精品国产凹凸成av人网站| 91麻豆文化传媒在线观看| 国产精品少妇自拍| 中文字幕视频一区二区三区久| 欧美人与性动xxxx| 国产成人一级电影| 国产麻豆精品在线| 亚洲午夜在线观看视频在线| 精品国产三级电影在线观看| 久久久国产精华| 国产亚洲精品7777| 欧美日韩国产免费一区二区| 欧美精品一区二区三区蜜桃视频| 久久久精品欧美丰满| 日韩午夜激情电影| 北岛玲一区二区三区四区| 91高清视频在线| 成人妖精视频yjsp地址| 精品系列免费在线观看| 成人高清免费观看| 国产一区二区三区综合| 日日夜夜精品视频天天综合网| 欧美日韩不卡在线| 国产色一区二区| 久久久久久久久99精品| www日韩大片| 中文字幕制服丝袜一区二区三区 | 国内偷窥港台综合视频在线播放| 丁香激情综合国产| 国产激情一区二区三区四区 | 久久精品免费看| 丁香亚洲综合激情啪啪综合| 日韩高清不卡一区二区| 亚洲高清不卡在线| 日韩欧美一区二区免费| 亚洲女人****多毛耸耸8| 亚洲丝袜精品丝袜在线| 国产黄色91视频| 日韩久久久久久| 亚洲狠狠丁香婷婷综合久久久| 亚洲精品成人精品456| 午夜欧美电影在线观看| av电影在线观看完整版一区二区| 成人午夜精品一区二区三区| 99riav久久精品riav| 高清不卡一区二区在线| 99久久久国产精品| 欧美日韩成人激情| 成人免费的视频| 久久久亚洲欧洲日产国码αv| 久久久99精品免费观看不卡| 一区二区中文字幕在线| 韩国av一区二区三区四区| 99re成人精品视频| 91精品国产乱码久久蜜臀| 欧美影院午夜播放| 亚洲色图欧洲色图| 青青草97国产精品免费观看无弹窗版| 日韩va欧美va亚洲va久久| 欧美亚洲日本一区| 色av成人天堂桃色av| 欧美日韩国产一二三| 裸体健美xxxx欧美裸体表演| 欧美亚洲综合久久| 久久综合九色综合欧美就去吻 | 国产一区视频导航| 不卡区在线中文字幕| 欧美丝袜自拍制服另类| 亚洲日韩欧美一区二区在线| 一区二区三区国产豹纹内裤在线| 亚洲伊人色欲综合网| 久久精品免费在线观看| 裸体在线国模精品偷拍| 99久久er热在这里只有精品15| 欧美理论在线播放| 久久男人中文字幕资源站| 综合久久国产九一剧情麻豆| 91精品国产色综合久久不卡电影| 国产一区二区免费视频| 中文字幕欧美日本乱码一线二线| 天天综合天天做天天综合| 麻豆国产一区二区| 一区二区三区在线视频免费观看| 日本一区二区三区在线观看| 麻豆精品视频在线| 国产91色综合久久免费分享| 国产一区不卡精品| 一区二区三区美女| 国产亚洲成年网址在线观看| 97精品国产露脸对白| 极品瑜伽女神91| 日韩激情中文字幕| 亚洲一区二区不卡免费| 国产精品久久久久久亚洲伦| 欧美大胆人体bbbb| 日韩一区二区三区在线视频| 国产传媒一区在线| 亚洲欧洲综合另类在线| 欧美日韩在线综合| 国产一区二区剧情av在线| 欧美日韩国产综合视频在线观看 | 亚洲自拍欧美精品| 国产精品嫩草影院com| 国产精品久久福利| 国产精品对白交换视频| av中文一区二区三区| 欧美成人一区二区三区在线观看| 岛国一区二区在线观看| 美女在线一区二区| 亚洲欧洲av另类| 国产日韩欧美精品电影三级在线 |