精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

扒一扒Bean注入到Spring的那些姿勢

開發 架構
配置文件的方式就是以外部化的配置方式來聲明Spring Bean,在Spring容器啟動時指定配置文件。配置文件方式現在用的不多了,但是為了文章的完整性和連續性,這里我還是列出來了,知道的小伙伴可以自行跳過這節。

大家好,我是三友~~

這篇文章我準備來扒一扒Bean注入到Spring的那些姿勢。

其實關于Bean注入Spring容器的方式網上也有很多相關文章,但是很多文章可能會存在以下常見的問題

  • 注入方式總結的不全
  • 沒有分析可以使用這些注入方式背后的原因
  • 沒有這些注入方式在源碼中的應用示例
  • ...

所以本文就帶著解決上述的問題的目的來重新梳理一下Bean注入到Spring的那些姿勢。

配置文件

配置文件的方式就是以外部化的配置方式來聲明Spring Bean,在Spring容器啟動時指定配置文件。配置文件方式現在用的不多了,但是為了文章的完整性和連續性,這里我還是列出來了,知道的小伙伴可以自行跳過這節。

配置文件的類型Spring主要支持xml和properties兩種類型。

xml

在XmlBeanInjectionDemo.xml文件中聲明一個class為類型為User的Bean

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://www.springframework.org/schema/beans"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
">

<bean class="com.sanyou.spring.bean.injection.User"/>

</beans>

User

@Data
@ToString
public class User {

private String username;

}

測試:

public class XmlBeanInjectionDemo {

public static void main(String[] args){
ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:XmlBeanInjectionDemo.xml");
applicationContext.refresh();
User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

結果:

User(username=null)

可以看出成功將User注入到Spring中,由于沒有設置username屬性值,所以是null。

properties

除了xml,spring還支持properties配置文件聲明Bean的方式。

如下,在PropertiesBeanInjectionDemo.properties文件中聲明了class類型為User的Bean,并且設置User的username屬性為sanyou。

user.(class) = com.sanyou.spring.bean.injection.User
user.username = sanyou

測試:

public class PropertiesBeanInjectionDemo {

public static void main(String[] args){
GenericApplicationContext applicationContext = new GenericApplicationContext();
//創建一個PropertiesBeanDefinitionReader,可以從properties讀取Bean的信息,將讀到的Bean信息放到applicationContext中
PropertiesBeanDefinitionReader propReader = new PropertiesBeanDefinitionReader(applicationContext);
//創建一個properties文件對應的Resource對象
Resource classPathResource = new ClassPathResource("PropertiesBeanInjectionDemo.properties");
//加載配置文件
propReader.loadBeanDefinitions(classPathResource);
applicationContext.refresh();
User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

結果:

User(username=sanyou)

成功獲取到User對象,并且username的屬性為properties設置的sanyou。

除了可以配置屬性之外還支持其它的配置,如何配置可以查看PropertiesBeanDefinitionReader類上的注釋。

圖片

注解聲明

上一節介紹了通過配置文件的方式來聲明Bean,但是配置文件這種方式最大的缺點就是不方便,因為隨著項目的不斷擴大,可能會產生大量的配置文件。為了解決這個問題,Spring在2.x的版本中開始支持注解的方式來聲明Bean。

@Component + @ComponentScan

這種方式其實就不用多說,在項目中自定義的業務類就是通過@Component及其派生注解(@Service、@Controller等)來注入到Spring容器中的。

在SpringBoot環境底下,一般情況下不需要我們主動調用@ComponentScan注解,因為@SpringBootApplication會調用@ComponentScan注解,掃描啟動引導類(加了@SpringBootApplication注解的類)所在的包及其子包下所有加了@Component注解及其派生注解的類,注入到Spring容器中。

圖片

@Bean

雖然上面@Component + @ComponentScan的這種方式可以將Bean注入到Spring中,但是有個問題那就是對于第三方jar包來說,如果這個類沒加@Component注解,那么@ComponentScan就掃不到,這樣就無法注入到Spring容器中,所以Spring提供了一種@Bean的方式來聲明Bean。

比如,在使用MybatisPlus的分頁插件的時候,就可以按如下方式這么來聲明。

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}

此時就能將MybatisPlusInterceptor這個Bean注入到Spring容器中。

@Import

@Import注解也可以用來將Bean注入到Spring容器中,@Import注解導入的類可以分為三種情況:

  • 普通類
  • 類實現了ImportSelector接口
  • 類實現了ImportBeanDefinitionRegistrar接口

普通類

普通類其實就很簡單,就是將@Import導入的類注入到Spring容器中,這沒什么好說的。

類實現了ImportSelector接口

public interface ImportSelector {

String[] selectImports(AnnotationMetadata importingClassMetadata);

@Nullable
default Predicate<String> getExclusionFilter(){
return null;
}

}

當@Import導入的類實現了ImportSelector接口的時候,Spring就會調用selectImports方法的實現,獲取一批類的全限定名,最終這些類就會被注冊到Spring容器中。

比如如下代碼中,UserImportSelector實現了ImportSelector,selectImports方法返回User的全限定名

public class UserImportSelector implements ImportSelector {

@Override
public String[] selectImports(AnnotationMetadata importingClassMetadata) {
System.out.println("調用 UserImportSelector 的 selectImports 方法獲取一批類限定名");
return new String[]{"com.sanyou.spring.bean.injection.User"};
}

}

當使用@Import注解導入UserImportSelector這個類的時候,其實最終就會把User注入到Spring容器中,如下測試

@Import(UserImportSelector.class)
public class ImportSelectorDemo {

public static void main(String[] args){
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext();
//將 ImportSelectorDemo 注冊到容器中
applicationContext.register(ImportSelectorDemo.class);
applicationContext.refresh();

User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

運行結果

User(username=null)

對于類實現了ImportBeanDefinitionRegistrar接口的情況,這個后面說。

一般來說,@Import都是配合@EnableXX這類注解來使用的,比如常見的@EnableScheduling、@EnableAsync注解等,其實最終都是靠@Import來實現的。

圖片

@EnableScheduling

圖片

@EnableAsync

講完通過注解的方式來聲明Bean之后,可以來思考一個問題,那就是既然注解方式這么簡單,為什么Spring還寫一堆代碼來支持配置文件這種聲明的方式?

其實答案很簡單,跟Spring的發展歷程有關。Spring在創建之初Java還不支持注解,所以只能通過配置文件的方式來聲明Bean,在Java1.5版本開始支持注解之后,Spring才開始支持通過注解的方式來聲明Bean。

注冊BeanDefinition

在說注冊BeanDefinition之前,先來聊聊什么是BeanDefinition?

BeanDefinition是Spring Bean創建環節中很重要的一個東西,它封裝了Bean創建過程中所需要的元信息。

public interface BeanDefinition extends AttributeAccessor, BeanMetadataElement {
//設置Bean className
void setBeanClassName(@Nullable String beanClassName);

//獲取Bean className
@Nullable
String getBeanClassName();

//設置是否是懶加載
void setLazyInit(boolean lazyInit);

//判斷是否是懶加載
boolean isLazyInit();

//判斷是否是單例
boolean isSingleton();

}

如上代碼是BeanDefinition接口的部分方法,從這方法的定義名稱可以看出,一個Bean所創建過程中所需要的一些信息都可以從BeanDefinition中獲取,比如這個Bean的class類型,這個Bean是否是懶加載,這個Bean是否是單例的等等,因為有了這些信息,Spring才知道要創建一個什么樣的Bean。

有了BeanDefinition這個概念之后,再來看一下配置文件和注解聲明這些方式往Spring容器注入Bean的原理。

圖片

Bean注入到Spring原理

如圖為Bean注入到Spring大致原理圖,整個過程大致分為以下幾個步驟

  • 通過BeanDefinitionReader組件讀取配置文件或者注解的信息,為每一個Bean生成一個BeanDefinition
  • BeanDefinition生成之后,添加到BeanDefinitionRegistry中,BeanDefinitionRegistry就是用來保存BeanDefinition
  • 當需要創建Bean對象時,會從BeanDefinitionRegistry中拿出需要創建的Bean對應的BeanDefinition,根據BeanDefinition的信息來生成Bean
  • 當生成的Bean是單例的時候,Spring會將Bean保存到SingletonBeanRegistry中,也就是平時說的三級緩存中的第一級緩存中,以免重復創建,需要使用的時候直接從SingletonBeanRegistry中查找

好了,通過以上分析我們知道,配置文件和注解聲明的方式其實都是聲明Bean的一種方式,最終都會轉換成BeanDefinition,Spring是基于BeanDefinition的信息來創建Bean。

既然Spring最終是基于BeanDefinition的信息來創建Bean,那么我們是不是可以跳過配置文件和注解聲明的方式,直接通過手動創建和注冊BeanDefinition的方式實現往Spring容器中注入呢?

答案是可以的。

前面說過,BeanDefinition最終會被注冊到BeanDefinitionRegistry中,那么如何拿到BeanDefinitionRegistry呢?主要有以下兩種方式:

  • ImportBeanDefinitionRegistrar
  • BeanDefinitionRegistryPostProcessor

ImportBeanDefinitionRegistrar

上面在說@Import的時候,關于導入的類實現了ImportBeanDefinitionRegistrar接口的情況沒有說,主要是因為在這里說比較合適

public interface ImportBeanDefinitionRegistrar {

default void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry,BeanNameGenerator importBeanNameGenerator){
registerBeanDefinitions(importingClassMetadata, registry);
}

default void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry){
}

}

ImportBeanDefinitionRegistrar中有兩個方法,方法的參數就是BeanDefinitionRegistry。當@Import導入的類實現了ImportBeanDefinitionRegistrar接口之后,Spring就會調用registerBeanDefinitions方法,傳入BeanDefinitionRegistry。

來個Demo

UserImportBeanDefinitionRegistrar實現ImportBeanDefinitionRegistrar

public class UserImportBeanDefinitionRegistrar implements ImportBeanDefinitionRegistrar {

@Override
public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry, BeanNameGenerator importBeanNameGenerator){
//構建一個 BeanDefinition , Bean的類型為 User
AbstractBeanDefinition beanDefinition = BeanDefinitionBuilder.rootBeanDefinition(User.class)
//設置User這個Bean的屬性username的值為三友的java日記
.addPropertyValue("username", "三友的java日記")
.getBeanDefinition();
//把User的BeanDefinition注入到BeanDefinitionRegistry中
registry.registerBeanDefinition("user", beanDefinition);
}

}

測試類

@Import(UserImportBeanDefinitionRegistrar.class)
public class UserImportBeanDefinitionRegistrarDemo {

public static void main(String[] args){
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext();
applicationContext.register(UserImportBeanDefinitionRegistrarDemo.class);
applicationContext.refresh();
User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

結果

User(username=三友的java日記)

從結果可以看出,成功將User注入到了Spring容器中。

上面的例子中有行代碼

applicationContext.register(UserImportBeanDefinitionRegistrarDemo.class);

這行代碼的意思就是把UserImportBeanDefinitionRegistrarDemo這個Bean注冊到Spring容器中,所以這里其實也算一種將Bean注入到Spring的方式,原理也跟上面一樣,會為UserImportBeanDefinitionRegistrarDemo生成一個BeanDefinition注冊到Spring容器中。

BeanDefinitionRegistryPostProcessor

除了ImportBeanDefinitionRegistrar可以拿到BeanDefinitionRegistry之外,還可以通過BeanDefinitionRegistryPostProcessor拿到BeanDefinitionRegistry

圖片

BeanDefinitionRegistryPostProcessor

這種方式就不演示了。

手動注冊BeanDefinition這種方式還是比較常見的。就比如說OpenFeign在啟用過程中,會為每個標注了@FeignClient注解的接口創建一個BeanDefinition,然后再往Spring中的注冊的,如下是OpenFeign注冊FeignClient的部分代碼

class FeignClientsRegistrar implements ImportBeanDefinitionRegistrar, ResourceLoaderAware, EnvironmentAware {

private void registerFeignClient(BeanDefinitionRegistry registry, AnnotationMetadata annotationMetadata, Map<String, Object> attributes){
//構建BeanDefinition,class類型為FeignClientFactoryBean
BeanDefinitionBuilder definition = BeanDefinitionBuilder.genericBeanDefinition(FeignClientFactoryBean.class);
String alias = contextId + "FeignClient";
AbstractBeanDefinition beanDefinition = definition.getBeanDefinition();
BeanDefinitionHolder holder = new BeanDefinitionHolder(beanDefinition, className, new String[] { alias });
//注冊BeanDefinition
BeanDefinitionReaderUtils.registerBeanDefinition(holder, registry);
}
}

注冊創建完成的Bean

上一節說可以跳過配置文件或者是注解,直接通過注冊BeanDefinition以達到將Bean注入到Spring中的目的。

既然已經可以跳過配置文件或者是注解,那么我們可不可以更激進一步,跳過注冊BeanDefinition這一步,直接往Spring中注冊一個已經創建好的Bean呢?

答案依然是可以的。

因為上面在提到當創建的Bean是單例的時候,會將這個創建完成的Bean保存到SingletonBeanRegistry中,需要用到直接從SingletonBeanRegistry中查找。既然最終是從SingletonBeanRegistry中查找的Bean,那么直接注入一個創建好的Bean有什么不可以呢?

既然可以,那么如何拿到SingletonBeanRegistry呢?

其實拿到SingletonBeanRegistry的方法其實很多,因為ConfigurableListableBeanFactory就繼承了SingletonBeanRegistry接口,所以只要能拿到ConfigurableListableBeanFactory就相當于拿到了SingletonBeanRegistry。

圖片

ConfigurableListableBeanFactory類圖

而ConfigurableListableBeanFactory可以通過BeanFactoryPostProcessor來獲取

圖片BeanFactoryPostProcessor

來個Demo

RegisterUserBeanFactoryPostProcessor實現BeanFactoryPostProcessor, 往Spring容器中添加一個手動創建的User對象

public class RegisterUserBeanFactoryPostProcessor implements BeanFactoryPostProcessor {

@Override
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
//創建一個User對象
User user = new User();
user.setUsername("三友的java日記");
//將這個User對象注入到Spring容器中
beanFactory.registerSingleton("user", user);
}

}

測試

public class RegisterUserDemo {

public static void main(String[] args){
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext();
applicationContext.register(RegisterUserBeanFactoryPostProcessor.class);
applicationContext.refresh();
User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

結果

User(username=三友的java日記)

從結果還是可以看出,成功從Spring容器中獲取到了User對象。

這種直接將創建好的Bean注入到Spring容器中在Spring框架內部使用的還是比較多的,Spring的一些內建的Bean就是通過這個方式注入到Spring中的。

圖片

如上圖,在SpringBoot項目啟動的過程中會往Spring容器中添加兩個創建好的Bean,如果你的程序需要使用到這些Bean,就可以通過依賴注入的方式獲取到。

雖然基于這種方式可以將Bean注入到Spring容器,但是這種方式注入的Bean是不經過Bean的生命周期的,也就是說這個Bean中諸如@Autowired等注解和Bean生命周期相關的回調都不會生效的,注入到Spring時Bean是什么樣就是什么樣,Spring不做處理,僅僅只是做一個保存作用。

FactoryBean

FactoryBean是一種特殊的Bean的類型,通過FactoryBean也可以將Bean注入到Spring容器中。

圖片

FactoryBean

當我們通過配置文件、注解聲明或者是注冊BeanDenifition的方式,往Spring容器中注入了一個class類型為FactoryBean類型的Bean時候,其實真正注入的Bean類型為getObjectType方法返回的類型,并且Bean的對象是通過getObject方法返回的。

來個Demo

UserFactoryBean實現了FactoryBean,getObjectType返回了User類型,所以這個UserFactoryBean會往Spring容器中注入User這個Bean,并且User對象是通過getObject()方法的實現返回的。

public class UserFactoryBean implements FactoryBean<User> {
@Override
public User getObject() throws Exception {
User user = new User();
user.setUsername("三友的java日記");
return user;
}

@Override
public Class<?> getObjectType() {
return User.class;
}
}

測試

public class UserFactoryBeanDemo {

public static void main(String[] args){
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext();
//將UserFactoryBean注入到Spring容器中
applicationContext.register(UserFactoryBean.class);
applicationContext.refresh();
User user = applicationContext.getBean(User.class);
System.out.println(user);
}

}

結果

User(username=三友的java日記)

成功通過UserFactoryBean將User這個Bean注入到Spring容器中了。

FactoryBean這中注入的方式使用也是非常多的,就拿上面舉例的OpenFeign來說,OpenFeign為每個FeignClient的接口創建的BeanDefinition的Bean的class類型FeignClientFactoryBean就是FactoryBean的實現。

class FeignClientFactoryBean implements FactoryBean<Object>, InitializingBean, ApplicationContextAware {

// FeignClient接口類型
private Class<?> type;

@Override
public Object getObject() throws Exception {
return getTarget();
}

@Override
public Class<?> getObjectType() {
return type;
}
}

getObject()方法就會返回接口的動態代理的對象,并且這個代理對象是由Feign創建的,這也就實現了Feign和Spring的整合。

總結

通過以上分析可以看出,將Bean注入到Spring容器中大致可以分為5類:

  • 配置文件
  • 注解聲明
  • 注冊BeanDefinition
  • 注冊創建完成的Bean
  • FactoryBean

以上幾種注入的方式,在日常業務開發中,基本上都是使用注解聲明的方式注入Spring中的;在第三方框架在和Spring整合時,注冊BeanDefinition和FactoryBean這些注入方式也會使用的比較多;至于配置文件和注冊創建完成的Bean的方式,有但是不多。

最后,本文所有的示例代碼地址:https://github.com/sanyou3/spring-bean-injection.git

責任編輯:武曉燕 來源: 三友的java日記
相關推薦

2018-04-03 15:42:40

2015-08-18 09:12:54

app推廣渠道

2025-06-04 01:20:00

2015-09-16 14:11:47

2022-07-11 20:46:39

AQSJava

2019-10-21 10:59:52

編程語言JavaC

2019-09-10 07:29:44

2019-02-25 22:46:39

2020-01-15 15:29:52

InnoDB數據硬盤

2015-10-15 13:38:39

2023-04-10 23:05:54

NacosOpenFeignRibbon

2015-09-16 14:04:06

大數據巨頭

2015-09-21 10:07:31

2019-01-03 11:09:19

2025-08-22 13:29:21

2017-09-07 18:45:51

C#

2022-09-30 09:40:39

智能汽車

2025-04-30 07:26:04

2015-12-15 09:51:42

大公司技術知乎

2021-05-13 05:25:16

數據分析數分培訓大數據
點贊
收藏

51CTO技術棧公眾號

青青一区二区三区| 欧美最新精品| 91在线国内视频| 国产精品对白刺激| 无码黑人精品一区二区| youjizz亚洲| 91黄色免费网站| 一二三在线视频| 色就是色亚洲色图| 国产在线视频一区二区三区| 午夜伦理精品一区| 美女网站视频色| 九九热hot精品视频在线播放| 精品视频在线免费| 久久精品国产sm调教网站演员| 97人人在线| 99久久综合国产精品| 91精品在线影院| 狠狠人妻久久久久久| 欧美暴力喷水在线| 亚洲日本欧美中文幕| 亚洲AV成人精品| 欧美韩国日本| 91九色最新地址| 国产精品无码av在线播放| 久久99精品久久| 久久久久成人黄色影片| 国产伦精品一区二区三区在线 | 色呦呦中文字幕| 久久福利资源站| 国产aaa精品| 国产做受高潮漫动| 激情综合视频| 蜜月aⅴ免费一区二区三区| 久久午夜福利电影| 蜜桃一区二区三区| 亚洲精品动漫久久久久| 手机在线播放av| 99re8精品视频在线观看| 色老汉一区二区三区| 一二三四视频社区在线| 不卡一本毛片| 亚洲一区二区三区中文字幕| 最新视频 - x88av| 国产黄a三级三级三级av在线看| 国产日韩欧美综合一区| 蜜桃传媒视频第一区入口在线看| 人妻一区二区三区免费| 国产不卡视频在线播放| 91精品网站| 精品国产av鲁一鲁一区| 国产综合久久久久久鬼色| 91精品免费久久久久久久久| 最近中文字幕在线观看视频| 免费亚洲电影在线| 国产精品欧美日韩一区二区| 中文字幕精品一区二| 日韩电影在线观看电影| 国产精品久久久久久久久粉嫩av| 波多野结衣黄色| 日韩电影在线观看网站| 国产精品狼人色视频一区| 在线观看国产精品入口男同| 麻豆一区二区在线| 国产日韩在线播放| 国产黄a三级三级看三级| 精品夜夜嗨av一区二区三区| 成人精品一区二区三区电影免费| 136福利视频导航| 国产精品自在在线| 国产精品免费一区二区三区四区| 亚洲女同志亚洲女同女播放| 99久久婷婷国产综合精品电影| 久久综合毛片| 1769在线观看| 有码一区二区三区| 妞干网在线观看视频| 日韩大片免费观看| 欧美午夜一区二区三区| 国内外成人免费在线视频| 91视频亚洲| 亚洲成人精品av| 欧美日韩高清丝袜| 亚洲国产精品久久久久蝴蝶传媒| 久久中文字幕在线视频| 尤物视频在线观看国产| 青草av.久久免费一区| 成人免费在线视频网站| 天天干视频在线观看| 中文字幕成人av| 五月天激情图片| 毛片免费看不卡网站| 欧美久久久久久久久久| 男男一级淫片免费播放| 嫩草影视亚洲| 美女久久久久久久| 一区二区三区在线观看av| 久久精品国产一区二区| 国产日韩精品一区观看| 在线免费观看黄色| 婷婷成人综合网| 中文字幕日韩综合| 香蕉久久精品日日躁夜夜躁| 久久精品影视伊人网| 日韩精品手机在线| 国产综合成人久久大片91| 免费99视频| 97超碰资源站在线观看| 色天天综合久久久久综合片| 俄罗斯女人裸体性做爰| 青青一区二区三区| 欧美亚洲激情在线| 亚洲av无码国产精品久久不卡| 久久久噜噜噜久久人人看| 黄色特一级视频| 国产精品麻豆成人av电影艾秋| 精品日韩在线观看| 精品人妻伦九区久久aaa片| 性伦欧美刺激片在线观看| 91网免费观看| 麻豆视频在线| 欧美亚洲自拍偷拍| a级大片在线观看| 一本久道综合久久精品| av一区二区在线看| 国产精品剧情| 欧美精品在线观看播放| 污片免费在线观看| 亚洲午夜av| 3d精品h动漫啪啪一区二区| 在线观看完整版免费| 一本色道久久综合亚洲aⅴ蜜桃| www.四虎精品| 欧美91精品| 樱花草国产18久久久久| 国产精品久久久精品| 国产黄色av片| 亚洲黄色av一区| 欧美熟妇另类久久久久久多毛| 日韩精品网站| 国产成人涩涩涩视频在线观看| 五月婷婷六月色| 亚洲高清不卡在线| 日本人妻一区二区三区| 在线中文一区| 91久久国产精品91久久性色| 免费黄色电影在线观看| 欧美日韩国产首页在线观看| www.黄色在线| 久久精品国产**网站演员| 五月天色一区| 亚洲精品第一| 久久中国妇女中文字幕| 国产成人av免费看| 亚洲综合在线视频| 黄色激情在线观看| 国产精品毛片在线| 欧美日韩亚洲一区二区三区在线观看| 欧美一级大片| 色爱av美腿丝袜综合粉嫩av| 国产精品老熟女视频一区二区| 中文字幕一区二区不卡| 波多野结衣在线免费观看| 中文字幕亚洲综合久久五月天色无吗''| 亚洲free性xxxx护士hd| 国语对白在线刺激| 亚洲欧美国产高清va在线播| 不卡av电影在线| 中文字幕日韩精品一区| 成年人性生活视频| 亚洲永久视频| 亚洲精品乱码视频| 蜜桃精品视频| …久久精品99久久香蕉国产| 精品视频一二区| 欧美日韩亚洲另类| 国产一级片免费| 久久亚洲捆绑美女| 黄色小视频免费网站| 在线播放精品| 日韩国产精品一区二区| 精品视频一区二区三区在线观看| 久久久久久久色| 猫咪在线永久网站| 欧美一区二区三区男人的天堂| 久久免费精品视频| 中文字幕日本视频| 一区二区三区欧美日| 免费a v网站| 蜜臀久久99精品久久久画质超高清| 久久久久久久久久久久久国产| 欧美大胆a级| 91久久久久久久久久| 午夜裸体女人视频网站在线观看| 综合激情国产一区| 亚洲人妻一区二区| 制服丝袜亚洲精品中文字幕| caoporn国产| 亚洲精品国产精华液| 人妻精品久久久久中文字幕| 国产精品自拍一区| 久久99爱视频| 香蕉成人久久| 国产精品www在线观看| 日韩电影免费网址| 久久综合久久久| 91精品入口| 国产在线精品一区免费香蕉 | 日韩免费不卡av| 国产成人l区| 亚洲一级一级97网| 天天干天天插天天操| 日韩欧美在线影院| 91国偷自产中文字幕久久| 欧美视频中文字幕在线| 私库av在线播放| 亚洲欧洲日产国码二区| 中字幕一区二区三区乱码| 成人免费黄色大片| 无套白嫩进入乌克兰美女| 日韩高清欧美激情| 国产成人综合一区| 免费看黄裸体一级大秀欧美| 欧美一级免费播放| 韩日视频一区| 五月天激情图片| 在线成人直播| 色撸撸在线观看| 99久久精品费精品国产| 无遮挡亚洲一区| 精品国产乱码久久久| 欧美人xxxxx| 亚洲伊人春色| 乱色588欧美| 色婷婷综合久久久久久| 国内一区在线| 窝窝社区一区二区| 国偷自产av一区二区三区小尤奈| 动漫美女无遮挡免费| 亚洲一区二区三区四区五区午夜 | 亚洲精品久久久久久一区二区| 欧美极品中文字幕| 日本视频一区在线观看| 久草成人在线| 日本一区二区在线视频观看| 九九热线有精品视频99| 青青草原亚洲| 成人情趣视频| 在线视频不卡一区二区三区| 欧美电影《睫毛膏》| 在线综合视频网站| 1024精品久久久久久久久| 亚洲成人动漫在线| 国内精品亚洲| 精品国产一区三区| 久久xxxx精品视频| 中文字幕第36页| 久久99精品久久久久久动态图| 在线看免费毛片| 国产91丝袜在线观看| 久久久午夜精品福利内容| 91性感美女视频| 西西444www无码大胆| 中文字幕一区二区三区精华液 | 99自拍偷拍视频| 椎名由奈av一区二区三区| 九九热精品在线观看| 亚洲国产成人av| 国产污视频网站| 69堂精品视频| 亚州视频一区二区三区| 亚洲欧美日韩精品| 免费超碰在线| 91av视频在线观看| 欧美123区| 99在线观看视频网站| 亚洲欧洲av| 懂色av一区二区三区四区五区| 一区久久精品| 麻豆三级在线观看| 国产v综合v亚洲欧| 韩国女同性做爰三级| 亚洲日本成人在线观看| 中国一级特黄毛片| 欧美精品久久久久久久多人混战| 黄色av网址在线| 在线观看久久久久久| 色呦呦视频在线观看| 日韩av男人的天堂| 无码国模国产在线观看| 欧美电影一区二区| 香港三级日本三级| 欧美极品aⅴ影院| 久久久久久久国产视频| 91九色最新地址| 六月丁香综合网| 日韩在线小视频| 国产夫妻在线播放| 成人黄色免费网站在线观看| 日韩伦理一区二区三区| 免费观看中文字幕| 日日夜夜精品视频免费| 最新日本中文字幕| 亚洲欧洲日韩一区二区三区| 国产精品视频一区在线观看| 日韩一区二区三区电影在线观看 | 中文字幕久精品免费视频| 丁香花在线电影| 国产一区香蕉久久| 精品国产91乱码一区二区三区四区| 黄色片免费在线观看视频| 蜜桃av一区二区| 一本加勒比北条麻妃| 亚洲成人免费影院| 国产成人精品亚洲精品色欲| 一区二区成人精品| 在线免费三级电影网站| 福利视频一区二区三区| 五月婷婷亚洲| 性chinese极品按摩| 久久久久国产精品麻豆ai换脸 | 欧美一卡2卡三卡4卡5免费| 久色视频在线| 欧美亚洲日本网站| 成人午夜网址| 欧美高清中文字幕| 国产伦精品一区二区三区视频青涩| 能直接看的av| 日本丰满少妇一区二区三区| 色视频精品视频在线观看| 久久欧美在线电影| 亚洲一区二区电影| 91传媒免费视频| 国产精品一区在线观看你懂的| 国产精品久久国产精麻豆96堂| 在线欧美一区二区| 国产在线色视频| 国产成+人+综合+亚洲欧洲| 人妖一区二区三区| 91专区在线观看| 99视频一区二区| 青青国产在线观看| 亚洲免费电影在线观看| 欧美美女日韩| 奇米精品在线| 日韩国产欧美在线视频| 欧美一区二区三区粗大| 欧美色视频一区| 尤物网在线观看| 91久久精品国产91久久性色| 久久久9色精品国产一区二区三区| 91av视频免费观看| 亚洲欧美欧美一区二区三区| 精品美女www爽爽爽视频| 91一区一区三区| 中文字幕22页| 中文字幕中文字幕一区二区| 国产又粗又猛视频| 欧美日韩福利视频| 美女av一区| 国产无套粉嫩白浆内谢的出处| 中文字幕国产一区| 国产aⅴ爽av久久久久成人| 久久久久中文字幕2018| 婷婷综合电影| 婷婷免费在线观看| 亚洲精品免费在线| 性猛交xxxx| 国产精品久久久久久网站| 99国产**精品****| 中文字幕视频观看| 日韩欧美中文免费| 伊人免费在线| 国产精品白丝jk白祙| 久久久天天操| 精品国产视频一区二区三区| 亚洲国产精品久久久| 成人免费av电影| 伊人久久在线观看| 久久亚洲捆绑美女| 99久久精品国产色欲| 91精品91久久久久久| 精品国产一级毛片| 中文字幕亚洲日本| 在线中文字幕不卡| 色a资源在线| 日韩精品欧美在线| 粉嫩绯色av一区二区在线观看| 在线精品免费视| 久久成年人视频| 一呦二呦三呦国产精品| 欧美在线a视频| 欧美日韩中文在线观看| 福利在线视频网站| 欧美一区二区三区成人久久片 | 国产白嫩美女无套久久| 欧美午夜精品免费| caoporn视频在线| 国产av不卡一区二区| 国产亚洲制服色|