日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

java build path entries 为空_同事的代码简直没法看,我来教你如何更优雅的设计Java异常...

發(fā)布時間:2023/11/27 生活经验 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java build path entries 为空_同事的代码简直没法看,我来教你如何更优雅的设计Java异常... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

點擊上方藍色字體,選擇“設(shè)為星標(biāo)”

回復(fù)”666“獲取面試寶典

異常處理是程序開發(fā)中必不可少操作之一,但如何正確優(yōu)雅的對異常進行處理確是一門學(xué)問,筆者根據(jù)自己的開發(fā)經(jīng)驗來談一談我是如何對異常進行處理的。

由于本文只作一些經(jīng)驗之談,不涉及到基礎(chǔ)知識部分,如果讀者對異常的概念還很模糊,請先查看基礎(chǔ)知識。

如何選擇異常類型

異常的類別

正如我們所知道的,java中的異常的超類是java.lang.Throwable(后文省略為Throwable),它有兩個比較重要的子類,java.lang.Exception(后文省略為Exception)和java.lang.Error(后文省略為Error),其中Error由JVM虛擬機進行管理,如我們所熟知的OutOfMemoryError異常等,所以我們本文不關(guān)注Error異常,那么我們細(xì)說一下Exception異常。

Exception異常有個比較重要的子類,叫做RuntimeException。我們將RuntimeException或其他繼承自RuntimeException的子類稱為非受檢異常(unchecked Exception),其他繼承自Exception異常的子類稱為受檢異常(checked Exception)。本文重點來關(guān)注一下受檢異常和非受檢異常這兩種異常。

如何選擇異常

從筆者的開發(fā)經(jīng)驗來看,如果在一個應(yīng)用中,需要開發(fā)一個方法(如某個功能的service方法),這個方法如果中間可能出現(xiàn)異常,那么你需要考慮這個異常出現(xiàn)之后是否調(diào)用者可以處理,并且你是否希望調(diào)用者進行處理,如果調(diào)用者可以處理,并且你也希望調(diào)用者進行處理,那么就要拋出受檢異常,提醒調(diào)用者在使用你的方法時,考慮到如果拋出異常時如果進行處理。

相似的,如果在寫某個方法時,你認(rèn)為這是個偶然異常,理論上說,你覺得運行時可能會碰到什么問題,而這些問題也許不是必然發(fā)生的,也不需要調(diào)用者顯示的通過異常來判斷業(yè)務(wù)流程操作的,那么這時就可以使用一個RuntimeException這樣的非受檢異常.

好了,估計我上邊說的這段話,你讀了很多遍也依然覺得晦澀了。

那么,請跟著我的思路,在慢慢領(lǐng)會一下。

什么時候才需要拋異常

首先我們需要了解一個問題,什么時候才需要拋異常?異常的設(shè)計是方便給開發(fā)者使用的,但不是亂用的,筆者對于什么時候拋異常這個問題也問了很多朋友,能給出準(zhǔn)確答案的確實不多。其實這個問題很簡單,如果你覺得某些”問題”解決不了了,那么你就可以拋出異常了。

比如,你在寫一個service,其中在寫到某段代碼處,你發(fā)現(xiàn)可能會產(chǎn)生問題,那么就請拋出異常吧,相信我,你此時拋出異常將是一個最佳時機。

應(yīng)該拋出怎樣的異常

了解完了什么時候才需要拋出異常后,我們再思考一個問題,真的當(dāng)我們拋出異常時,我們應(yīng)該選用怎樣的異常呢?究竟是受檢異常還是非受檢異常呢(RuntimeException)呢?

我來舉例說明一下這個問題,先從受檢異常說起,比如說有這樣一個業(yè)務(wù)邏輯,需要從某文件中讀取某個數(shù)據(jù),這個讀取操作可能是由于文件被刪除等其他問題導(dǎo)致無法獲取從而出現(xiàn)讀取錯誤,那么就要從redis或mysql數(shù)據(jù)庫中再去獲取此數(shù)據(jù),參考如下代碼,getKey(Integer)為入口程序.

public?String?getKey(Integer?key){
????String??value;
????try?{
????????InputStream?inputStream?=?getFiles("/file/nofile");
????????//接下來從流中讀取key的value指
????????value?=?...;
????}?catch?(Exception?e)?{
????????//如果拋出異常將從mysql或者redis進行取之
????????value?=?...;
????}
}

public?InputStream?getFiles(String?path)?throws?Exception?{
????File?file?=?new?File(path);
????InputStream?inputStream?=?null;
????try?{
????????inputStream?=?new?BufferedInputStream(new?FileInputStream(file));
????}?catch?(FileNotFoundException?e)?{
????????throw?new?Exception("I/O讀取錯誤",e.getCause());
????}
????return?inputStream;
}

ok,看了以上代碼以后,你也許心中有一些想法,原來受檢異常可以控制義務(wù)邏輯,對,沒錯,通過受檢異常真的可以控制業(yè)務(wù)邏輯,但是切記不要這樣使用,我們應(yīng)該合理的拋出異常,因為程序本身才是流程,異常的作用僅僅是當(dāng)你進行不下去的時候找到的一個借口而已,它并不能當(dāng)成控制程序流程的入口或出口,如果這樣使用的話,是在將異常的作用擴大化,這樣將會導(dǎo)致代碼復(fù)雜程度的增加,耦合性會提高,代碼可讀性降低等問題。

那么就一定不要使用這樣的異常嗎?其實也不是,在真的有這樣的需求的時候,我們可以這樣使用,只是切記,不要把它真的當(dāng)成控制流程的工具或手段。那么究竟什么時候才要拋出這樣的異常呢?要考慮,如果調(diào)用者調(diào)用出錯后,一定要讓調(diào)用者對此錯誤進行處理才可以,滿足這樣的要求時,我們才會考慮使用受檢異常。

接下來,我們來看一下非受檢異常呢(RuntimeException),對于RuntimeException這種異常,我們其實很多見,比如java.lang.NullPointerException/java.lang.IllegalArgumentException等,那么這種異常我們時候拋出呢?

當(dāng)我們在寫某個方法的時候,可能會偶然遇到某個錯誤,我們認(rèn)為這個問題時運行時可能為發(fā)生的,并且理論上講,沒有這個問題的話,程序?qū)?zhí)行的時候,它不強制要求調(diào)用者一定要捕獲這個異常,此時拋出RuntimeException異常。

舉個例子,當(dāng)傳來一個路徑的時候,需要返回一個路徑對應(yīng)的File對象:

public?void?test()?{
????myTest.getFiles("");
}

public?File?getFiles(String?path)?{
????if(null?==?path?||?"".equals(path)){
????????throw??new?NullPointerException("路徑不能為空!");
????}
????File?file?=?new?File(path);

????return?file;
}

上述例子表明,如果調(diào)用者調(diào)用getFiles(String)的時候如果path是空,那么就拋出空指針異常(它是RuntimeException的子類),調(diào)用者不用顯示的進行try…catch…操作進行強制處理.這就要求調(diào)用者在調(diào)用這樣的方法時先進行驗證,避免發(fā)生RuntimeException.如下:

public?void?test()?{
????String?path?=?"/a/b.png";
????if(null?!=?path?&&?!"".equals(path)){
????????myTest.getFiles("");
????}
}

public?File?getFiles(String?path)?{
????if(null?==?path?||?"".equals(path)){
????????throw??new?NullPointerException("路徑不能為空!");
????}
????File?file?=?new?File(path);

????return?file;
}

應(yīng)該選用哪種異常

通過以上的描述和舉例,可以總結(jié)出一個結(jié)論,**RuntimeException異常和受檢異常之間的區(qū)別就是:是否強制要求調(diào)用者必須處理此異常,如果強制要求調(diào)用者必須進行處理,那么就使用受檢異常,否則就選擇非受檢異常(RuntimeException)。**一般來講,如果沒有特殊的要求,我們建議使用RuntimeException異常。

場景介紹和技術(shù)選型

架構(gòu)描述

正如我們所知,傳統(tǒng)的項目都是以MVC框架為基礎(chǔ)進行開發(fā)的,本文主要從使用restful風(fēng)格接口的設(shè)計來體驗一下異常處理的優(yōu)雅。

我們把關(guān)注點放在restful的api層(和web中的controller層類似)和service層,研究一下在service中如何拋出異常,然后api層如何進行捕獲并且轉(zhuǎn)化異常。

使用的技術(shù)是:spring-boot,jpa(hibernate),mysql,如果對這些技術(shù)不是太熟悉,讀者需要自行閱讀相關(guān)材料。

業(yè)務(wù)場景描述

選擇一個比較簡單的業(yè)務(wù)場景,以電商中的收貨地址管理為例,用戶在移動端進行購買商品時,需要進行收貨地址管理,在項目中,提供一些給移動端進行訪問的api接口,如:添加收貨地址,刪除收貨地址,更改收貨地址,默認(rèn)收貨地址設(shè)置,收貨地址列表查詢,單個收貨地址查詢等接口。

構(gòu)建約束條件

ok,這個是設(shè)置好的一個很基本的業(yè)務(wù)場景,當(dāng)然,無論什么樣的api操作,其中都包含一些規(guī)則:

添加收貨地址: 入?yún)?

  • 用戶id
  • 收貨地址實體信息

約束:

  • 用戶id不能為空,且此用戶確實是存在 的
  • 收貨地址的必要字段不能為 空
  • 如果用戶還沒有收貨地址,當(dāng)此收貨地址創(chuàng)建時設(shè)置成默認(rèn)收貨地址 —

刪除收貨地址: 入?yún)?

  • 用戶id
  • 收貨地址id

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址不能為空,且此收貨地址確實是存在的
  • 判斷此收貨地址是否是用戶的收貨地址
  • 判斷此收貨地址是否為默認(rèn)收貨地址,如果是默認(rèn)收貨地址,那么不能進行刪除

更改收貨地址: 入?yún)?

  • 用戶id
  • 收貨地址id

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址不能為空,且此收貨地址確實是存在的
  • 判斷此收貨地址是否是用戶的收貨地址

默認(rèn)地址設(shè)置: 入?yún)?

  • 用戶id
  • 收貨地址id

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址不能為空,且此收貨地址確實是存在的
  • 判斷此收貨地址是否是用戶的收貨地址

收貨地址列表查詢: 入?yún)?

  • 用戶id

約束:

  • 用戶id不能為空,且此用戶確實是存在的

單個收貨地址查詢: 入?yún)?

  • 用戶id
  • 收貨地址id

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址不能為空,且此收貨地址確實是存在的
  • 判斷此收貨地址是否是用戶的收貨地址

約束判斷和技術(shù)選型

對于上述列出的約束條件和功能列表,我選擇幾個比較典型的異常處理場景進行分析:添加收貨地址,刪除收貨地址,獲取收貨地址列表。

那么應(yīng)該有哪些必要的知識儲備呢,讓我們看一下收貨地址這個功能:

添加收貨地址中需要對用戶id和收貨地址實體信息就行校驗,那么對于非空的判斷,我們?nèi)绾芜M行工具的選擇呢?傳統(tǒng)的判斷如下:

/**
?*?添加地址
?*?@param?uid
?*?@param?address
?*?@return
?*/
public?Address?addAddress(Integer?uid,Address?address){
????if(null?!=?uid){
????????//進行處理..
????}
????return?null;
}

上邊的例子,如果只判斷uid為空還好,如果再去判斷address這個實體中的某些必要屬性是否為空,在字段很多的情況下,這無非是災(zāi)難性的。

那我們應(yīng)該怎么進行這些入?yún)⒌呐袛嗄?#xff0c;給大家介紹兩個知識點:

  • Guava中的Preconditions類實現(xiàn)了很多入?yún)⒎椒ǖ呐袛?/li>
  • jsr 303的validation規(guī)范(目前實現(xiàn)比較全的是hibernate實現(xiàn)的hibernate-validator)

如果使用了這兩種推薦技術(shù),那么入?yún)⒌呐袛鄷兊煤唵魏芏唷?*推薦大家多使用這些成熟的技術(shù)和jar工具包,他可以減少很多不必要的工作量。****我們只需要把重心放到業(yè)務(wù)邏輯上。**而不會因為這些入?yún)⒌呐袛嗟⒄`更多的時間。

如何優(yōu)雅的設(shè)計java異常

domain介紹

根據(jù)項目場景來看,需要兩個domain模型,一個是用戶實體,一個是地址實體.

Address domain如下:

@Entity
@Data
public?class?Address?{
????@Id
????@GeneratedValue
????private?Integer?id;
????private?String?province;//省
????private?String?city;//市
????private?String?county;//區(qū)
????private?Boolean?isDefault;//是否是默認(rèn)地址

????@ManyToOne(cascade={CascadeType.ALL})
????@JoinColumn(name="uid")
????private?User?user;
}

User domain如下:

@Entity
@Data
public?class?User?{
????@Id
???@GeneratedValue
???private?Integer?id;
???private?String?name;//姓名

????@OneToMany(cascade=?CascadeType.ALL,mappedBy="user",fetch?=?FetchType.LAZY)
????????private?Set
?addresses;
}

ok,上邊是一個模型關(guān)系,用戶-收貨地址的關(guān)系是1-n的關(guān)系。上邊的@Data是使用了一個叫做lombok的工具,它自動生成了Setter和Getter等方法,用起來非常方便,感興趣的讀者可以自行了解一下。

dao介紹

數(shù)據(jù)連接層,我們使用了spring-data-jpa這個框架,它要求我們只需要繼承框架提供的接口,并且按照約定對方法進行取名,就可以完成我們想要的數(shù)據(jù)庫操作。

用戶數(shù)據(jù)庫操作如下:

@Repository
public?interface?IUserDao?extends?JpaRepository<User,Integer>?{

}

收貨地址操作如下:

@Repository
public?interface?IAddressDao?extends?JpaRepository
?{
}

正如讀者所看到的,我們的DAO只需要繼承JpaRepository,它就已經(jīng)幫我們完成了基本的CURD等操作,如果想了解更多關(guān)于spring-data的這個項目,請參考一下spring的官方文檔,它比不方案我們對異常的研究。

Service異常設(shè)計

ok,終于到了我們的重點了,我們要完成service一些的部分操作:添加收貨地址,刪除收貨地址,獲取收貨地址列表.

首先看我的service接口定義:

public?interface?IAddressService?{

/**
?*?創(chuàng)建收貨地址
?*?@param?uid
?*?@param?address
?*?@return
?*/
Address?createAddress(Integer?uid,Address?address);

/**
?*?刪除收貨地址
?*?@param?uid
?*?@param?aid
?*/
void?deleteAddress(Integer?uid,Integer?aid);

/**
?*?查詢用戶的所有收貨地址
?*?@param?uid
?*?@return
?*/
List
?listAddresses(Integer?uid);
}

我們來關(guān)注一下實現(xiàn):

添加收貨地址

首先再來看一下之前整理的約束條件:

入?yún)?

  • 用戶id
  • 收貨地址實體信息

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址的必要字段不能為空
  • 如果用戶還沒有收貨地址,當(dāng)此收貨地址創(chuàng)建時設(shè)置成默認(rèn)收貨地址

先看以下代碼實現(xiàn):

@Override
public?Address?createAddress(Integer?uid,?Address?address)?{
????//============?以下為約束條件???==============
????//1.用戶id不能為空,且此用戶確實是存在的
????Preconditions.checkNotNull(uid);
????User?user?=?userDao.findOne(uid);
????if(null?==?user){
????????throw?new?RuntimeException("找不到當(dāng)前用戶!");
????}
????//2.收貨地址的必要字段不能為空
????BeanValidators.validateWithException(validator,?address);
????//3.如果用戶還沒有收貨地址,當(dāng)此收貨地址創(chuàng)建時設(shè)置成默認(rèn)收貨地址
????if(ObjectUtils.isEmpty(user.getAddresses())){
????????address.setIsDefault(true);
????}

????//============?以下為正常執(zhí)行的業(yè)務(wù)邏輯???==============
????address.setUser(user);
????Address?result?=?addressDao.save(address);
????return?result;
}

其中,已經(jīng)完成了上述所描述的三點約束條件,當(dāng)三點約束條件都滿足時,才可以進行正常的業(yè)務(wù)邏輯,否則將拋出異常(一般在此處建議拋出運行時異常-RuntimeException)。

介紹以下以上我所用到的技術(shù):

1、Preconfitions.checkNotNull(T t)這個是使用Guava中的com.google.common.base.Preconditions進行判斷的,因為service中用到的驗證較多,所以建議將Preconfitions改成靜態(tài)導(dǎo)入的方式:

import?static?com.google.common.base.Preconditions.checkNotNull;?

當(dāng)然Guava的github中的說明也建議我們這樣使用。

2、BeanValidators.validateWithException(validator, address); 這個使用了hibernate實現(xiàn)的jsr 303規(guī)范來做的,需要傳入一個validator和一個需要驗證的實體,那么validator是如何獲取的呢,如下:

@Configuration
public?class?BeanConfigs?{

@Bean
public?javax.validation.Validator?getValidator(){
????return?new?LocalValidatorFactoryBean();
}
}

他將獲取一個Validator對象,然后我們在service中進行注入便可以使用了:

?@Autowired?????
private?Validator?validator?;

那么BeanValidators這個類是如何實現(xiàn)的?其實實現(xiàn)方式很簡單,只要去判斷jsr 303的標(biāo)注注解就ok了。

那么jsr 303的注解寫在哪里了呢?當(dāng)然是寫在address實體類中了:

@Entity
@Setter
@Getter
public?class?Address?{
@Id
????@GeneratedValue
????private?Integer?id;
????@NotNull
private?String?province;//省
@NotNull
private?String?city;//市
@NotNull
private?String?county;//區(qū)
private?Boolean?isDefault?=?false;//是否是默認(rèn)地址

@ManyToOne(cascade={CascadeType.ALL})
@JoinColumn(name="uid")
private?User?user;
}

寫好你需要的約束條件來進行判斷,如果合理的話,才可以進行業(yè)務(wù)操作,從而對數(shù)據(jù)庫進行操作。

這塊的驗證是必須的,一個最主要的原因是:這樣的驗證可以避免臟數(shù)據(jù)的插入。

如果讀者有正式上線的經(jīng)驗的話,就可以理解這樣的一個事情,**任何的代碼錯誤都可以容忍和修改,但是如果出現(xiàn)了臟數(shù)據(jù)問題,那么它有可能是一個毀滅性的災(zāi)難。**程序的問題可以修改,但是臟數(shù)據(jù)的出現(xiàn)有可能無法恢復(fù)。所以這就是為什么在service中一定要判斷好約束條件,再進行業(yè)務(wù)邏輯操作的原因了。

此處的判斷為業(yè)務(wù)邏輯判斷,是從業(yè)務(wù)角度來進行篩選判斷的,除此之外,有可能在很多場景中都會有不同的業(yè)務(wù)條件約束,只需要按照要求來做就好。

對于約束條件的總結(jié)如下:

  • 基本判斷約束(null值等基本判斷)
  • 實體屬性約束(滿足jsr 303等基礎(chǔ)判斷)
  • 業(yè)務(wù)條件約束(需求提出的不同的業(yè)務(wù)約束)

當(dāng)這個三點都滿足時,才可以進行下一步操作

ok,基本介紹了如何做一個基礎(chǔ)的判斷,那么再回到異常的設(shè)計問題上,上述代碼已經(jīng)很清楚的描述如何在適當(dāng)?shù)奈恢煤侠淼呐袛嘁粋€異常了,那么如何合理的拋出異常呢?

只拋出RuntimeException就算是優(yōu)雅的拋出異常嗎?當(dāng)然不是,對于service中的拋出異常,筆者認(rèn)為大致有兩種拋出的方法:

  • 拋出帶狀態(tài)碼RumtimeException異常
  • 拋出指定類型的RuntimeException異常

相對這兩種異常的方式進行結(jié)束,第一種異常指的是我所有的異常都拋RuntimeException異常,但是需要帶一個狀態(tài)碼,調(diào)用者可以根據(jù)狀態(tài)碼再去查詢究竟service拋出了一個什么樣的異常。

第二種異常是指在service中拋出什么樣的異常就自定義一個指定的異常錯誤,然后在進行拋出異常。

一般來講,如果系統(tǒng)沒有別的特殊需求的時候,在開發(fā)設(shè)計中,建議使用第二種方式。但是比如說像基礎(chǔ)判斷的異常,就可以完全使用guava給我們提供的類庫進行操作。jsr 303異常也可以使用自己封裝好的異常判斷類進行操作,因為這兩種異常都是屬于基礎(chǔ)判斷,不需要為它們指定特殊的異常。但是對于第三點義務(wù)條件約束判斷拋出的異常,就需要拋出指定類型的異常了。

對于

throw?new?RuntimeException("找不到當(dāng)前用戶!");

定義一個特定的異常類來進行這個義務(wù)異常的判斷:

public?class?NotFindUserException?extends?RuntimeException?{
public?NotFindUserException()?{
????super("找不到此用戶");
}

public?NotFindUserException(String?message)?{
????super(message);
}
}

然后將此處改為:

throw?new?NotFindUserException("找不到當(dāng)前用戶!");

or
throw?new?NotFindUserException();

ok,通過以上對service層的修改,代碼更改如下:

@Override
public?Address?createAddress(Integer?uid,?Address?address)?{
????//============?以下為約束條件???==============
????//1.用戶id不能為空,且此用戶確實是存在的
????checkNotNull(uid);
????User?user?=?userDao.findOne(uid);
????if(null?==?user){
????????throw?new?NotFindUserException("找不到當(dāng)前用戶!");
????}
????//2.收貨地址的必要字段不能為空
????BeanValidators.validateWithException(validator,?address);
????//3.如果用戶還沒有收貨地址,當(dāng)此收貨地址創(chuàng)建時設(shè)置成默認(rèn)收貨地址
????if(ObjectUtils.isEmpty(user.getAddresses())){
????????address.setIsDefault(true);
????}

????//============?以下為正常執(zhí)行的業(yè)務(wù)邏輯???==============
????address.setUser(user);
????Address?result?=?addressDao.save(address);
????return?result;
}

這樣的service就看起來穩(wěn)定性和理解性就比較強了。

刪除收貨地址:

入?yún)?

  • 用戶id
  • 收貨地址id

約束:

  • 用戶id不能為空,且此用戶確實是存在的
  • 收貨地址不能為空,且此收貨地址確實是存在的
  • 判斷此收貨地址是否是用戶的收貨地址
  • 判斷此收貨地址是否為默認(rèn)收貨地址,如果是默認(rèn)收貨地址,那么不能進行刪除

它與上述添加收貨地址類似,故不再贅述,delete的service設(shè)計如下:

@Override
public?void?deleteAddress(Integer?uid,?Integer?aid)?{
????//============?以下為約束條件???==============
????//1.用戶id不能為空,且此用戶確實是存在的
????checkNotNull(uid);
????User?user?=?userDao.findOne(uid);
????if(null?==?user){
????????throw?new?NotFindUserException();
????}
????//2.收貨地址不能為空,且此收貨地址確實是存在的
????checkNotNull(aid);
????Address?address?=?addressDao.findOne(aid);
????if(null?==?address){
????????throw?new?NotFindAddressException();
????}
????//3.判斷此收貨地址是否是用戶的收貨地址
????if(!address.getUser().equals(user)){
????????throw?new?NotMatchUserAddressException();
????}
????//4.判斷此收貨地址是否為默認(rèn)收貨地址,如果是默認(rèn)收貨地址,那么不能進行刪除
????if(address.getIsDefault()){
???????throw??new?DefaultAddressNotDeleteException();
????}

????//============?以下為正常執(zhí)行的業(yè)務(wù)邏輯???==============
????addressDao.delete(address);
}

設(shè)計了相關(guān)的四個異常類:NotFindUserException,NotFindAddressException,NotMatchUserAddressException,DefaultAddressNotDeleteException.根據(jù)不同的業(yè)務(wù)需求拋出不同的異常。

獲取收貨地址列表:入?yún)?

  • 用戶id

約束:

  • 用戶id不能為空,且此用戶確實是存在的

代碼如下:

??@Override
public?List
?listAddresses(Integer?uid)?{
????//============?以下為約束條件???==============
????//1.用戶id不能為空,且此用戶確實是存在的
????checkNotNull(uid);
????User?user?=?userDao.findOne(uid);
????if(null?==?user){
????????throw?new?NotFindUserException();
????}

????//============?以下為正常執(zhí)行的業(yè)務(wù)邏輯???==============
????User?result?=?userDao.findOne(uid);
????return?result.getAddresses();
}

api異常設(shè)計

大致有兩種拋出的方法:

  • 拋出帶狀態(tài)碼RumtimeException異常
  • 拋出指定類型的RuntimeException異常

這個是在設(shè)計service層異常時提到的,通過對service層的介紹,我們在service層拋出異常時選擇了第二種拋出的方式,不同的是,在api層拋出異常我們需要使用這兩種方式進行拋出:要指定api異常的類型,并且要指定相關(guān)的狀態(tài)碼,然后才將異常拋出,這種異常設(shè)計的核心是讓調(diào)用api的使用者更能清楚的了解發(fā)生異常的詳細(xì)信息。

除了拋出異常外,我們還需要將狀態(tài)碼對應(yīng)的異常詳細(xì)信息以及異常有可能發(fā)生的問題制作成一個對應(yīng)的表展示給用戶,方便用戶的查詢。(如github提供的api文檔,微信提供的api文檔等),還有一個好處:如果用戶需要自定義提示消息,可以根據(jù)返回的狀態(tài)碼進行提示的修改。

api驗證約束

首先對于api的設(shè)計來說,需要存在一個dto對象,這個對象負(fù)責(zé)和調(diào)用者進行數(shù)據(jù)的溝通和傳遞,然后dto->domain在傳給service進行操作,這一點一定要注意。

第二點,除了說道的service需要進行基礎(chǔ)判斷(null判斷)和jsr 303驗證以外,同樣的,api層也需要進行相關(guān)的驗證,如果驗證不通過的話,直接返回給調(diào)用者,告知調(diào)用失敗,不應(yīng)該帶著不合法的數(shù)據(jù)再進行對service的訪問。

那么讀者可能會有些迷惑,不是service已經(jīng)進行驗證了,為什么api層還需要進行驗證么?這里便設(shè)計到了一個概念:編程中的墨菲定律,如果api層的數(shù)據(jù)驗證疏忽了,那么有可能不合法數(shù)據(jù)就帶到了service層,進而講臟數(shù)據(jù)保存到了數(shù)據(jù)庫。

所以縝密編程的核心是:永遠(yuǎn)不要相信收到的數(shù)據(jù)是合法的。

api異常設(shè)計

設(shè)計api層異常時,正如我們上邊所說的,需要提供錯誤碼和錯誤信息,那么可以這樣設(shè)計,提供一個通用的api超類異常,其他不同的api異常都繼承自這個超類:

public?class?ApiException?extends?RuntimeException?{
protected?Long?errorCode?;
protected?Object?data?;

public?ApiException(Long?errorCode,String?message,Object?data,Throwable?e){
????super(message,e);
????this.errorCode?=?errorCode?;
????this.data?=?data?;
}

public?ApiException(Long?errorCode,String?message,Object?data){
????this(errorCode,message,data,null);
}

public?ApiException(Long?errorCode,String?message){
????this(errorCode,message,null,null);
}

public?ApiException(String?message,Throwable?e){
????this(null,message,null,e);
}

public?ApiException(){

}

public?ApiException(Throwable?e){
????super(e);
}

public?Long?getErrorCode()?{
????return?errorCode;
}

public?void?setErrorCode(Long?errorCode)?{
????this.errorCode?=?errorCode;
}

public?Object?getData()?{
????return?data;
}

public?void?setData(Object?data)?{
????this.data?=?data;
}
}

然后分別定義api層異常:ApiDefaultAddressNotDeleteException,ApiNotFindAddressException,ApiNotFindUserException,ApiNotMatchUserAddressException以默認(rèn)地址不能刪除為例:

public?class?ApiDefaultAddressNotDeleteException?extends?ApiException?{

public?ApiDefaultAddressNotDeleteException(String?message)?{
????super(AddressErrorCode.DefaultAddressNotDeleteErrorCode,?message,?null);
}
}

AddressErrorCode.DefaultAddressNotDeleteErrorCode就是需要提供給調(diào)用者的錯誤碼。錯誤碼類如下:

public?abstract?class?AddressErrorCode?{
????public?static?final?Long?DefaultAddressNotDeleteErrorCode?=?10001L;//默認(rèn)地址不能刪除
????public?static?final?Long?NotFindAddressErrorCode?=?10002L;//找不到此收貨地址
????public?static?final?Long?NotFindUserErrorCode?=?10003L;//找不到此用戶
????public?static?final?Long?NotMatchUserAddressErrorCode?=?10004L;//用戶與收貨地址不匹配
}

ok,那么api層的異常就已經(jīng)設(shè)計完了,在此多說一句,AddressErrorCode錯誤碼類存放了可能出現(xiàn)的錯誤碼,更合理的做法是把他放到配置文件中進行管理。

api處理異常

api層會調(diào)用service層,然后來處理service中出現(xiàn)的所有異常,首先,需要保證一點,一定要讓api層非常輕,基本上做成一個轉(zhuǎn)發(fā)的功能就好(接口參數(shù),傳遞給service參數(shù),返回給調(diào)用者數(shù)據(jù),這三個基本功能),然后就要在傳遞給service參數(shù)的那個方法調(diào)用上進行異常處理。

此處僅以添加地址為例:

?@Autowired
private?IAddressService?addressService;


/**
?*?添加收貨地址
?*?@param?addressDTO
?*?@return
?*/
@RequestMapping(method?=?RequestMethod.POST)
public?AddressDTO?add(@Valid?@RequestBody?AddressDTO?addressDTO){
????Address?address?=?new?Address();
????BeanUtils.copyProperties(addressDTO,address);
????Address?result;
????try?{
????????result?=?addressService.createAddress(addressDTO.getUid(),?address);
????}catch?(NotFindUserException?e){
????????throw?new?ApiNotFindUserException("找不到該用戶");
????}catch?(Exception?e){//未知錯誤
????????throw?new?ApiException(e);
????}
????AddressDTO?resultDTO?=?new?AddressDTO();
????BeanUtils.copyProperties(result,resultDTO);
????resultDTO.setUid(result.getUser().getId());

????return?resultDTO;
}

這里的處理方案是調(diào)用service時,判斷異常的類型,然后將任何service異常都轉(zhuǎn)化成api異常,然后拋出api異常,這是常用的一種異常轉(zhuǎn)化方式。相似刪除收貨地址和獲取收貨地址也類似這樣處理,在此,不在贅述。

api異常轉(zhuǎn)化

已經(jīng)講解了如何拋出異常和何如將service異常轉(zhuǎn)化為api異常,那么轉(zhuǎn)化成api異常直接拋出是否就完成了異常處理呢?答案是否定的,當(dāng)拋出api異常后,我們需要把api異常返回的數(shù)據(jù)(json or xml)讓用戶看懂,那么需要把api異常轉(zhuǎn)化成dto對象(ErrorDTO),看如下代碼:

@ControllerAdvice(annotations?=?RestController.class)
class?ApiExceptionHandlerAdvice?{

/**
?*?Handle?exceptions?thrown?by?handlers.
?*/
@ExceptionHandler(value?=?Exception.class)
@ResponseBody
public?ResponseEntity?exception(Exception?exception,HttpServletResponse?response)?{
????ErrorDTO?errorDTO?=?new?ErrorDTO();
????if(exception?instanceof?ApiException){//api異常
????????ApiException?apiException?=?(ApiException)exception;
????????errorDTO.setErrorCode(apiException.getErrorCode());
????}else{//未知異常
????????errorDTO.setErrorCode(0L);
????}
????errorDTO.setTip(exception.getMessage());
????ResponseEntity?responseEntity?=?new?ResponseEntity<>(errorDTO,HttpStatus.valueOf(response.getStatus()));return?responseEntity;
}@Setter@Getterclass?ErrorDTO{private?Long?errorCode;private?String?tip;
}
}

ok,這樣就完成了api異常轉(zhuǎn)化成用戶可以讀懂的DTO對象了,代碼中用到了@ControllerAdvice,這是spring MVC提供的一個特殊的切面處理。

當(dāng)調(diào)用api接口發(fā)生異常時,用戶也可以收到正常的數(shù)據(jù)格式了,比如當(dāng)沒有用戶(uid為2)時,卻為這個用戶添加收貨地址,postman(Google plugin 用于模擬http請求)之后的數(shù)據(jù):

{
??"errorCode":?10003,
??"tip":?"找不到該用戶"
}

總結(jié)

本文只從如何設(shè)計異常作為重點來講解,涉及到的api傳輸和service的處理,還有待優(yōu)化,比如api接口訪問需要使用https進行加密,api接口需要OAuth2.0授權(quán)或api接口需要簽名認(rèn)證等問題,文中都未曾提到,本文的重心在于異常如何處理,所以讀者只需關(guān)注涉及到異常相關(guān)的問題和處理方式就可以了。

來源 |?https://lrwinx.github.io/
  • 面試官問:MySQL的自增ID用完了,怎么辦?

  • ArrayList插入1000w條數(shù)據(jù)之后,我懷疑了jvm...

  • 螞蟻二面,面試官問我零拷貝的實現(xiàn)原理,當(dāng)場懵了…

最近面試BAT,整理一份面試資料《Java面試BAT通關(guān)手冊》,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫、數(shù)據(jù)結(jié)構(gòu)等等。

獲取方式:點“在看”,關(guān)注公眾號并回復(fù)?666?領(lǐng)取,更多內(nèi)容陸續(xù)奉上。

明天見(。・ω・。)ノ?

總結(jié)

以上是生活随笔為你收集整理的java build path entries 为空_同事的代码简直没法看,我来教你如何更优雅的设计Java异常...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

av解说在线观看 | 久久999精品 | 色小说av | 99精彩视频| 国产精品11 | 91 在线视频| 国产区在线视频 | 日本久久久久久 | 久久精品永久免费 | 日韩电影精品一区 | 亚洲区视频在线观看 | 一区二区三区高清在线 | 久久人人爽av | 国产在线无 | 成年人在线播放视频 | 日韩试看 | 13日本xxxxxⅹxxx20 | 国产理论一区二区三区 | 天天爱天天操 | 亚洲在线视频网站 | 伊人色**天天综合婷婷 | 国产精品久久在线观看 | 黄色小说在线观看视频 | 91最新视频 | 国产剧情一区二区在线观看 | 日韩在线观看三区 | 人人插人人搞 | 亚洲一区二区天堂 | 97视频在线观看免费 | 亚洲经典视频在线观看 | 91激情视频在线观看 | 在线免费观看麻豆视频 | 欧美一级性 | 日韩v在线 | 欧美影院久久 | 国产美女在线免费观看 | 国产一区自拍视频 | 午夜视频一区二区 | 中文字幕国产一区 | 韩国一区在线 | 在线网站黄 | 日韩久久精品一区二区三区下载 | 国产精品久久久久一区二区 | 999一区二区三区 | 色视频在线免费观看 | 久久国产区 | 久草久草在线观看 | 在线观看黄色的网站 | 色亚洲网 | 亚洲午夜久久久综合37日本 | 欧美性色xo影院 | 亚洲国产精品va在线看黑人 | 黄免费网站 | 99久久久久成人国产免费 | 91九色在线观看视频 | 丁香久久综合 | 天天操天天操天天操天天操天天操天天操 | 97在线看| 日韩国产精品久久久久久亚洲 | 中文字幕免费一区二区 | 国产视频精品免费 | 成人精品999 | 亚洲电影一区二区 | 欧美在线观看视频免费 | 九九免费观看视频 | 国产亚洲精品久久网站 | 国产福利91精品一区二区三区 | 亚洲手机天堂 | 天天操夜夜操 | 在线免费视频一区 | 国产精品igao视频网网址 | 麻豆成人精品 | 国产日韩在线播放 | 在线看v片成人 | 日韩丝袜在线观看 | 91九色porny蝌蚪视频 | 福利一区在线 | av播放在线 | 免费观看的黄色 | 欧美日韩99| 正在播放 国产精品 | 男女男视频 | 麻豆91在线看 | wwwwww国产| 91精品免费在线观看 | 综合激情av| 国产一级在线 | 亚洲国产高清在线观看视频 | 99精品免费在线观看 | 亚洲一区二区三区miaa149 | 婷婷激情网站 | 国产99在线免费 | 最新免费av在线 | 欧美成人基地 | 日韩视频在线观看免费 | 婷婷在线网站 | 97超碰人人干 | 国产成人资源 | 成人黄色大片在线观看 | 97超碰香蕉| 久久免费观看少妇a级毛片 久久久久成人免费 | 欧美日韩免费观看一区=区三区 | 国产精品观看在线亚洲人成网 | 精品视频国产一区 | 在线天堂中文在线资源网 | 福利视频网站 | 欧美va电影| 久久国产精品免费一区二区三区 | 91九色综合| 丁香av | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产福利91精品张津瑜 | 91亚色免费视频 | 久久国产精品99久久久久 | 三级黄在线| 91天堂影院 | 亚洲高清在线精品 | 999久久国产精品免费观看网站 | 日本在线观看视频一区 | 欧美成人按摩 | 丁香六月国产 | 91精品免费视频 | av电影免费在线看 | www日韩在线| 日韩免费播放 | 亚洲在线成人精品 | 亚洲国产精久久久久久久 | 午夜精品影院 | 十八岁以下禁止观看的1000个网站 | 国产精品久久久久免费 | 在线天堂视频 | 99精品免费久久久久久日本 | 99热最新 | 日韩欧美一区二区三区在线观看 | 91免费在线 | 国产精品视频免费观看 | 久久久久成人精品免费播放动漫 | 日韩一级电影在线 | 色综合久久中文综合久久牛 | 免费黄色激情视频 | 国产美女免费看 | 国产丝袜| 久久久国产一区 | 99久久久国产免费 | 狠狠的干 | 玖玖国产精品视频 | 亚洲精品字幕在线观看 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 韩国一区二区三区在线观看 | 99热在线这里只有精品 | 日韩久久影院 | 久久九九久久精品 | 中国一级特黄毛片大片久久 | 成人毛片在线视频 | 国精产品999国精产品岳 | 久久综合狠狠综合久久激情 | 成人av在线电影 | 久草在线视频首页 | 三上悠亚一区二区在线观看 | 麻豆精品在线视频 | 国产精品久久99精品毛片三a | 国产手机视频在线 | 狠狠色丁香婷婷综合久小说久 | 91在线播放视频 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 国产特级毛片aaaaaaa高清 | 欧美精品一级视频 | 久久久久国产精品一区 | 欧美日本中文字幕 | 亚洲黄色在线免费观看 | av在线免费网站 | 92国产精品久久久久首页 | 免费av片在线 | 99视频国产在线 | 在线亚洲激情 | 亚洲 欧美变态 另类 综合 | www.久久久com| 精品久久在线 | 在线看v片成人 | 天天插天天操天天干 | 亚洲 中文 在线 精品 | 91看片淫黄大片91 | 日韩一二区在线观看 | 久久久高清一区二区三区 | 久久国产免 | 亚洲成人av电影 | 国产精品久久久久久久久久久久久 | 午夜视频在线观看一区二区三区 | 久久国产热视频 | 精品日韩在线 | 美女久久久久久久久久 | 国内精品免费久久影院 | 99成人在线视频 | 丁香婷婷自拍 | .国产精品成人自产拍在线观看6 | 亚洲一区日韩精品 | av网站在线观看播放 | 婷婷5月色 | 日韩欧美视频 | 97超碰资源网 | 香蕉91视频 | 日韩三级免费观看 | 亚洲精品456在线播放第一页 | 欧洲视频一区 | 中文字幕在线免费 | 久久久久国产a免费观看rela | 亚洲经典视频在线观看 | 亚洲永久精品在线 | 久久久久麻豆v国产 | 五月天亚洲综合小说网 | 综合色在线观看 | av电影免费在线 | 精品美女久久久久久免费 | 麻豆久久久 | 99久精品视频 | 久久超| www.com黄| 玖玖爱在线观看 | 日韩在线观看免费 | 日本中文字幕视频 | 国产视频导航 | 国产视频中文字幕在线观看 | 国产日韩精品一区二区 | 亚洲爱爱视频 | 精品综合久久久 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | a黄色大片 | 欧美性黄网官网 | 日韩资源在线观看 | 国产一区二区视频在线 | 国产很黄很色的视频 | 69绿帽绿奴3pvideos | 亚洲免费国产视频 | 日韩在线视频二区 | 91香蕉视频 | 国产成人黄色 | 亚洲天天在线日亚洲洲精 | 字幕网在线观看 | 99视频精品在线 | 91天天操 | 久久免费在线 | 亚洲精品国产高清 | 91精品福利在线 | 亚洲日本韩国一区二区 | 337p日本大胆噜噜噜噜 | 亚州性色| 日本性高潮视频 | 国产精品久久久久aaaa九色 | av在线电影网站 | 午夜性福利 | 中文字幕在线观看网 | 深夜免费小视频 | 国产日韩欧美视频在线观看 | 中文字幕在线观看一区二区三区 | 欧美日韩一区二区三区免费视频 | 国产精品久久久久久久久费观看 | 免费看三级黄色片 | 精品久久久99| www国产亚洲 | 国产精品爽爽久久久久久蜜臀 | 日韩激情视频在线 | 不卡的av | 欧美极品少妇xxxx | 国产裸体视频网站 | 国产又黄又猛又粗 | 久草视频在线免费 | 在线观看国产永久免费视频 | 欧美日韩国产欧美 | 天天色天天色 | 91精品一区国产高清在线gif | www.午夜色.com | 视频91 | 欧美人体xx | 91精品国产99久久久久 | 国产精品亚洲片夜色在线 | 综合在线色 | 1000部国产精品成人观看 | 日韩乱理| 91女神的呻吟细腰翘臀美女 | 成人在线视频一区 | 99久久免费看 | 成人久久精品 | 国产精品欧美激情在线观看 | 色视频在线免费观看 | 日韩电影一区二区三区在线观看 | 在线a亚洲视频播放在线观看 | 日日干夜夜骑 | 午夜视频福利 | 国产日韩欧美视频 | 亚洲无毛专区 | 狠狠88综合久久久久综合网 | 欧美孕妇与黑人孕交 | 操操日| 天天色婷婷 | 国语久久 | 亚洲午夜激情网 | 最近中文字幕免费av | 91在线porny国产在线看 | 97在线观 | 国产视频二区三区 | 一区二区三区日韩精品 | 成人av在线播放网站 | 97在线免费 | 99精品视频播放 | 在线日韩一区 | 久久久精华网 | 久久热亚洲 | 91丨九色丨蝌蚪丰满 | 久久成视频 | 日韩a级黄色片 | 欧美成人h版电影 | 亚洲精品综合一区二区 | 国产男女无遮挡猛进猛出在线观看 | 免费在线播放av电影 | 国产色爽 | aaa黄色毛片| 日本一区二区免费在线观看 | 日本久久久久久久久久 | 成人久久国产 | 天天插日日射 | 久久久久女教师免费一区 | 国产免费久久av | 午夜精品福利在线 | 国产在线不卡视频 | 欧美一级在线观看视频 | 亚洲国产剧情 | 国产精品一区二区免费视频 | 国产一区二区在线免费播放 | 色欧美成人精品a∨在线观看 | 久久久久久久国产精品视频 | 五月婷婷综合在线视频 | 日本激情视频中文字幕 | 国产第一福利 | 欧美国产不卡 | 国产系列 在线观看 | 久久久久久在线观看 | 国产精品第一页在线 | 欧美一级性 | 国内精品久久久久影院日本资源 | 日韩精品在线观看视频 | 日韩在线观看视频一区二区三区 | 久久久99国产精品免费 | 91av在线免费播放 | 五月婷婷色丁香 | 亚洲国产精品va在线看黑人动漫 | 不卡电影免费在线播放一区 | 日韩一区二区在线免费观看 | 狠狠操狠狠操 | 五月亚洲婷婷 | 天天操天天操天天 | 天堂av影院| 欧美日韩国产页 | 久久 在线 | 成人在线超碰 | 久草视频在线免费播放 | 麻豆视频大全 | 国产日产精品一区二区三区四区 | 国产精品一区二区在线观看免费 | 久久久久久久电影 | 婷婷激情网站 | 午夜精品久久久久久中宇69 | 91精品亚洲影视在线观看 | 福利视频入口 | 久久99国产精品 | 亚洲国产高清在线观看视频 | 精品国产一区二区久久 | 久久情网 | 久草视频在线资源站 | 在线看日韩av | 九九在线国产视频 | 国产成人一区二区三区电影 | 欧美狠狠色 | 国产午夜精品一区二区三区在线观看 | 黄色三级在线观看 | 黄色一级网 | 国产无遮挡猛进猛出免费软件 | 国产精品永久久久久久久久久 | 欧美亚洲精品在线观看 | 亚洲国产精品99久久久久久久久 | 成人网大片 | 狠狠狠狠狠狠 | 精品欧美乱码久久久久久 | 成年人免费看片网站 | 免费在线观看国产黄 | 蜜桃av观看 | 四虎在线影视 | 成人久久久精品国产乱码一区二区 | 天天舔夜夜操 | 国产精品国内免费一区二区三区 | 免费一区在线 | www.日本色 | 国产拍揄自揄精品视频麻豆 | 在线观看中文字幕亚洲 | 一区二区欧美日韩 | 亚洲性xxxx | 日韩久久精品一区 | 天天艹 | 91av在线电影| 天天做天天爱夜夜爽 | 欧美成人一区二区 | 欧美一级片免费播放 | 免费a v观看 | av高清一区二区三区 | 午夜的福利 | 日韩网站在线观看 | 日本在线视频一区二区三区 | www视频在线免费观看 | 黄色一集片 | 亚洲天堂色婷婷 | 欧美日韩99 | 国产亲近乱来精品 | 在线观看视频h | 欧美极度另类性三渗透 | 永久免费的啪啪网站免费观看浪潮 | www.av小说| 日本aaaa级毛片在线看 | 久久综合免费 | 超级碰碰碰免费视频 | 免费看片网页 | 亚洲精品美女久久17c | 99在线热播精品免费 | 美女网站视频一区 | 91视频免费国产 | 狠狠干成人 | 久久免费国产精品 | 激情伊人五月天久久综合 | 毛片的网址 | 久久视频免费观看 | 91av免费在线观看 | 亚洲国产97在线精品一区 | 爱干视频 | 久久久国产高清 | 欧美在线91| 狠狠色伊人亚洲综合成人 | av电影在线播放 | 日韩av一区二区三区在线观看 | 99爱爱 | 久久免费视频在线 | 久久不见久久见免费影院 | 免费一区在线 | 手机看片福利 | 国产精品久久久久久久电影 | 九九免费在线看完整版 | 国内精品久久久久久久久久久久 | 久久与婷婷| 丁香六月婷婷 | 国产精品九九九九九 | 丁香五月亚洲综合在线 | 91精品91 | 国产精品视频永久免费播放 | 国产毛片在线 | 久保带人 | 久久久www成人免费精品 | 天天综合网久久综合网 | 日本中文字幕高清 | 九九99靖品 | 日日夜夜免费精品视频 | 国产精品网在线观看 | 免费在线一区二区 | 精品日韩中文字幕 | 久久久久久亚洲精品 | 黄色a视频| 日韩黄色免费在线观看 | 一级黄色大片在线观看 | 麻豆视频成人 | 日韩欧美在线国产 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 国产精品视频99 | 成人h视频 | 亚洲区精品视频 | 在线观看日韩视频 | 久草成人在线 | 国内视频在线 | 日韩大片免费观看 | 久久精品三 | 中文字幕在线观看视频一区二区三区 | 超碰激情在线 | 最新av电影网站 | 手机色站 | 国产免费看 | 国产成人专区 | 一级a毛片高清视频 | 久久99久久99精品免观看软件 | 国产 视频 高清 免费 | 日韩国产精品一区 | 波多野结衣电影久久 | 99久久精品免费看国产 | 亚洲视频免费在线观看 | 日韩精品一区二区三区中文字幕 | 欧美日韩激情网 | 91污污 | 不卡的av在线播放 | 天天天色 | 中文字幕免费观看全部电影 | 久久久国产日韩 | 欧美日韩视频观看 | 五月天综合色激情 | 午夜久久久久久久久久久 | 日韩欧美国产免费播放 | 天天操夜夜看 | 中文字幕 影院 | 日韩电影一区二区三区 | 91精品国产91久久久久福利 | 黄色av一区 | 久久国产免费看 | 日本高清中文字幕有码在线 | 日韩中午字幕 | 久久精品久久精品久久39 | 亚洲免费av一区二区 | 97精品久久人人爽人人爽 | 特级毛片在线 | 激情欧美日韩一区二区 | 一区二区三区视频 | 在线直播av | 日本h视频在线观看 | 久久久久久久久久久高潮一区二区 | 青青河边草免费视频 | 亚洲精品午夜一区人人爽 | 亚洲综合爱 | 99在线视频播放 | 亚洲电影院 | 97电影在线 | 人人澡人 | 最近中文字幕完整高清 | 91精品欧美一区二区三区 | 亚洲波多野结衣 | 日本韩国欧美在线观看 | 国产资源精品在线观看 | 一区二区三区中文字幕在线观看 | 国内视频1区 | 久久久久久国产精品久久 | 久久亚洲私人国产精品 | 免费毛片aaaaaa | 91在线在线观看 | 在线观看中文字幕视频 | 日韩二区三区在线 | www色婷婷com| 午夜在线免费观看 | 国产小视频在线免费观看视频 | 日韩大片在线看 | 欧美在线free | 国产精品自在线拍国产 | 欧美精品免费一区二区 | 国产福利在线免费 | 日韩免费在线视频观看 | 亚洲综合激情小说 | a级国产乱理论片在线观看 伊人宗合网 | 狠狠干夜夜爱 | 欧美日韩破处 | 午夜久久 | 人人草天天草 | 欧美日韩免费在线视频 | 日韩成人精品一区二区三区 | 欧美日韩免费看 | 日本成人a | 日韩丝袜在线观看 | 亚洲人人av | 亚洲综合激情 | 中文免费 | 亚洲女在线 | 久青草视频在线观看 | 在线日韩亚洲 | 91视频com| 成人免费网站在线观看 | 成人黄色小视频 | 日韩欧美成 | 懂色av懂色av粉嫩av分享吧 | 成人福利在线播放 | 亚洲一区二区高潮无套美女 | 日韩黄色一级电影 | 日韩在线观看中文 | 免费在线观看成人 | 久久精品这里热有精品 | 最近能播放的中文字幕 | 日韩在线不卡av | 五月开心婷婷 | 99久久久久久久久久 | 午夜精品视频一区二区三区在线看 | 日日夜夜狠狠干 | 天天爽网站| 久久av一区二区三区亚洲 | 色噜噜狠狠色综合中国 | 久久久久久久久免费视频 | 免费国产ww| 国内精品久久久久影院日本资源 | 免费网站黄 | 91精品国产麻豆国产自产影视 | 香蕉在线观看视频 | 韩日电影在线观看 | 欧美日韩视频在线观看免费 | 五月激情六月丁香 | 国产男女无遮挡猛进猛出在线观看 | 蜜桃av观看| 黄色国产区 | 国内精品免费久久影院 | 久久精品久久99精品久久 | 久草视频免费在线播放 | 色丁香久久| 在线看的av网站 | 2020天天干天天操 | 97在线观看 | 中文字幕在线播放日韩 | 成人三级网址 | 午夜视频福利 | 狠狠色狠狠色综合日日小说 | 日韩高清 一区 | 亚洲午夜久久久久久久久久久 | 日韩在线观看视频网站 | av电影 一区二区 | 91高清视频在线 | 99热九九这里只有精品10 | 国产亚洲视频在线观看 | 91探花国产综合在线精品 | 亚洲永久字幕 | 亚洲天堂免费视频 | 中文字幕av在线免费 | 久久久久久久久久久久久久免费看 | 国产精品videoxxxx | 亚在线播放中文视频 | 久久久久激情 | 97超碰在线免费观看 | 九九热国产| 国产美女精彩久久 | 正在播放国产一区二区 | 国产女人免费看a级丨片 | 深爱激情综合 | 久热色超碰 | 欧美日韩精品在线观看视频 | 亚在线播放中文视频 | 欧美国产日韩一区二区 | 精品一区电影国产 | 四虎成人免费观看 | 亚洲国产精品va在线看 | 久久久综合精品 | 国产视频不卡一区 | 狠狠躁夜夜躁人人爽视频 | 国产99久久久精品 | 日本中出在线观看 | 黄色小视频在线观看免费 | 日韩欧美亚洲 | 丁香六月婷婷开心 | 国产免费叼嘿网站免费 | 亚洲伊人网在线观看 | 91精品系列| 国内久久久久 | 久久精品毛片 | 美国人与动物xxxx | 日韩亚洲在线视频 | 免费黄色一区 | 久草视频免费观 | 国产一卡二卡四卡国 | 天天操福利视频 | 最近2019中文免费高清视频观看www99 | 又黄又爽免费视频 | 最新91在线视频 | 91最新在线观看 | 精品一区 在线 | 午夜电影 电影 | 99精品国产兔费观看久久99 | 九九视频在线播放 | 国产精品久久99精品毛片三a | 欧美一二三区在线观看 | 91在线观看视频 | 国产在线观看污片 | 国产亚洲精品av | 成年人看片 | 国产精品成久久久久 | www.色的 | 欧美日韩69 | 久久99久久99精品免观看软件 | 色诱亚洲精品久久久久久 | 五月开心六月伊人色婷婷 | 黄色中文字幕在线 | 狠狠狠的干 | 久久人人97超碰国产公开结果 | 久久三级毛片 | 国产看片网站 | 久久亚洲欧美日韩精品专区 | 久久国产精品久久精品国产演员表 | 91av视频在线观看免费 | 在线a人片免费观看视频 | 久久九九精品久久 | 国产成人一区在线 | 国外调教视频网站 | 国产在线播放不卡 | 成人黄色片在线播放 | 欧美日韩一区二区免费在线观看 | 色偷偷88888欧美精品久久 | 久草在线在线 | 粉嫩av一区二区三区四区 | 中文av在线天堂 | 亚洲成人精品在线 | 亚洲精品在线视频 | 亚洲午夜av电影 | 久久久久久久久久电影 | 东方av免费在线观看 | 亚洲自拍自偷 | 亚洲黄色片 | 久久久久欧美精品999 | 黄色av电影网 | 中文字幕观看在线 | 久草国产在线观看 | 在线观看av大片 | 狠狠色伊人亚洲综合网站色 | 9热精品 | 黄色免费观看视频 | 亚州av网站 | 久久久久国产一区二区三区四区 | 亚洲电影免费 | 狠狠干夜夜 | 在线免费观看国产黄色 | 久久99精品久久久久久秒播蜜臀 | 亚洲国产中文字幕在线视频综合 | 美女国产在线 | 日韩免费一级电影 | 精品国产一区二区三区久久久久久 | 五月天久久久 | v片在线播放 | 成人黄色在线看 | 国产短视频在线播放 | 97超碰免费在线观看 | 夜夜躁狠狠燥 | 久久人人爽人人爽人人 | 九七视频在线 | 91精品啪 | 久久毛片网 | 久久久精品国产一区二区 | 亚洲激情一区二区三区 | 中文不卡视频 | a视频免费在线观看 | 亚洲一区精品二人人爽久久 | 国产人成免费视频 | 91热这里只有精品 | 99tvdz@gmail.com | 久久99精品国产91久久来源 | 日本少妇高清做爰视频 | 国产一区在线观看视频 | 日本精品中文字幕 | 欧美精品少妇xxxxx喷水 | 亚洲国产资源 | 免费看成年人 | 国产精品1区2区3区在线观看 | v片在线看 | 三级av在线播放 | av中文字幕电影 | 中文字幕免费一区 | 91视频这里只有精品 | 国产97碰免费视频 | 日本不卡123| 成人污视频在线观看 | 中文字幕视频 | 天天干天天干天天操 | 久久久美女 | 欧美久久99| 最近最新mv字幕免费观看 | 夜夜爽88888免费视频4848 | 国产一二区视频 | 久亚洲 | 久久草在线免费 | 在线观看av不卡 | 美女视频a美女大全免费下载蜜臀 | 欧美另类z0zx | 国产精国产精品 | 亚洲小视频在线观看 | 久久国产精品99久久人人澡 | 91成人网在线观看 | 一级性视频| 在线观看视频福利 | 天天综合网 天天综合色 | 天天干天天做天天爱 | 黄色免费网战 | wwwwww国产 | 在线观看精品视频 | 四虎成人免费观看 | www.xxx.性狂虐| 黄色一级网 | 欧美性生活免费 | 成人97视频 | 在线免费观看羞羞视频 | 视频1区2区 | 中文字幕中文字幕在线中文字幕三区 | 看片网站黄色 | 免费在线观看不卡av | 亚洲女人天堂成人av在线 | 欧美一级专区免费大片 | 国产资源精品在线观看 | 久久精品一区二 | 免费久久精品视频 | 视频一区二区在线观看 | 日韩黄视频| 国产成人精品日本亚洲999 | 国产激情久久久 | 久久视频免费在线 | 在线看岛国av | 午夜国产在线观看 | av福利在线 | 久久美女高清视频 | 日韩精品中文字幕在线观看 | 国产在线精品一区二区 | 久久久av电影 | 国产精品国产三级国产 | 国产一级精品视频 | 精品主播网红福利资源观看 | 久久综合成人网 | 韩日av在线| 日韩免费在线播放 | 久久免费影院 | 天天躁日日 | 久久精品一区二区三区四区 | 国产精品扒开做爽爽的视频 | 久久福利电影 | 成人9ⅰ免费影视网站 | 在线观看视频在线 | 日本黄色免费大片 | 最新日韩精品 | 国产精品久久久久一区二区国产 | 国产91精品高清一区二区三区 | 亚洲蜜桃在线 | 色网站免费在线看 | 亚洲精品乱码久久久久久蜜桃欧美 | 日韩在线观看视频网站 | 天天搞天天干 | 久久视频在线 | 欧美午夜精品久久久久久浪潮 | 黄色99视频| 视频在线精品 | 天天看天天操 | 999超碰 | 97电影手机 | 精品国产自在精品国产精野外直播 | 97香蕉视频 | 五月开心六月婷婷 | 69人人| 亚洲视频在线观看免费 | 亚洲永久精品在线观看 | 91香蕉久久| 成人久久18免费网站麻豆 | 久久大视频 | 一区在线观看 | 福利视频导航网址 | 久操视频在线 | 午夜精品福利一区二区三区蜜桃 | 久久99国产综合精品 | 国产精品不卡视频 | 亚洲精品中文在线 | 中文字幕有码在线 | 97中文字幕 | 国产精品日韩在线播放 | 国内久久 | 国产偷国产偷亚洲清高 | 最新午夜 | 九色91福利 | 久要激情网 | 久草在线 | 在线看小早川怜子av | 久久综合激情 | 操操综合网 | 中文字幕av一区二区三区四区 | 国产精品美乳一区二区免费 | 亚洲专区免费观看 | 成 人 黄 色 免费播放 | 亚洲日本在线视频观看 | 在线电影日韩 | 欧美久久久久久久久 | www.午夜色.com| 久久免费久久 | 手机av观看 | 欧美a视频在线观看 | 成人蜜桃网| 麻豆视频成人 | 婷婷伊人五月天 | 97成人在线观看视频 | 看v片| 精品国产aⅴ麻豆 | 免费看黄的 | 特级片免费看 | 免费看片成年人 | 国产不卡一区二区视频 | 在线中文视频 | 在线国产黄色 | 国产丝袜美腿在线 | 日韩中文字幕在线 | 91色国产在线 | 亚洲综合色丁香婷婷六月图片 | 久久久香蕉视频 | 91精品国产高清自在线观看 | av电影av在线 | 天天综合网 天天综合色 | 丁香午夜 | 久久精品一区二区三 | 黄色在线免费观看网站 | 精品国产乱码一区二 | 伊人色综合网 | 91天堂影院 | 亚洲成年人av | 免费毛片一区二区三区久久久 | 天天干天天操天天操 | 日日干狠狠操 | 在线观看午夜 | 97精品在线观看 | 在线观看黄色小视频 | 国产精品久久久久久久久久久免费看 | 成人观看视频 | 五月天久久狠狠 | 日韩资源在线观看 | 日韩在线观看视频一区二区三区 | 亚洲国产剧情 | 免费一级片在线观看 | 日日夜夜天天干 | 国产精品久久久久久久久久了 | 黄色免费电影网站 | 国产夫妻av在线 | 黄色av一级| 久久久久女人精品毛片 | av一级片网站 | 久久高清视频免费 | 欧美成人精品三级在线观看播放 | 免费在线观看污网站 | 天天综合久久综合 | 999久久a精品合区久久久 | 中文在线天堂资源 | 日韩视频免费 | 亚洲电影自拍 | 国产手机视频精品 | 一级理论片在线观看 | 中文字幕色站 | 亚洲午夜久久久久久久久久久 | 欧美va日韩va | av超碰在线| av黄色亚洲| 欧美久久电影 | 欧美性色黄大片在线观看 | 日韩午夜精品 | 91精彩视频在线观看 | 日韩免费成人 | 一区二区三区在线视频观看58 | 精品久久久久久久久久久久久久久久久久 | 99久久久久国产精品免费 | 五月婷网 | 97在线观视频免费观看 | 黄色精品一区 | 丁香六月婷婷开心婷婷网 | 亚洲区色 | 麻豆视传媒官网免费观看 | 亚洲第二色 | 成人中文字幕在线 | 五月婷婷综合在线视频 | 欧美成年人在线视频 | 91香蕉视频720p | 亚洲国产精品久久久 | 四虎在线观看视频 | 久久免费视频8 | 久久久国产精品麻豆 | 一本之道乱码区 | 高潮久久久久久久久 | 亚洲国产精品久久 | 国产在线毛片 | 国产91在线观看 | 99在线视频播放 | 国产九色91| 五月婷婷影视 | 日本bbbb摸bbbb| 久久这里精品视频 | 婷婷激情五月综合 | 久久成年人网站 | 欧美一级电影免费观看 | 九九免费精品视频在线观看 | 欧美精品一二 | 激情久久五月天 | 久久在线影院 | 日韩在线色 | 五月天婷亚洲天综合网精品偷 | 国产在线97 | 久久这里只有精品9 | 日韩在线国产精品 | 99精品区| 日韩电影精品 | 亚州性色| 国产视频一二三 | 在线综合色| 国产成人一区二区啪在线观看 | 亚洲综合视频网 | 美女网站一区 | 国产在线中文字幕 | 婷婷丁香激情网 | 欧美成人精品欧美一级乱 | 日韩视频一 | 成 人 a v天堂 | 2018好看的中文在线观看 | 精品视频在线免费 | 欧美激情精品久久久久久 | 久久不射电影院 | 久久精品99国产精品亚洲最刺激 | 狠狠操电影网 | 成人免费网站在线观看 | 中文字幕在线播放一区二区 | 2017狠狠干 | 91麻豆精品国产91久久久无限制版 |