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

輕松搞定分布式 Token 校驗(yàn),完美!

開發(fā) 前端
問題背景就是在分布式微服務(wù)的場景下,如何去更好地校驗(yàn)token。并且通過我們的token我們可以做到單點(diǎn)登錄。

1前言

問題背景就是在分布式微服務(wù)的場景下,如何去更好地校驗(yàn)token。并且通過我們的token我們可以做到單點(diǎn)登錄。

如果全部都在GateWay去做的話,我是真的懶得去寫那些啥配置了,到時(shí)候放行哪些接口都會搞亂。

2token存儲

既然我們要校驗(yàn),那么我們要做的就是拿到這個(gè)token,那么首先要做的就是生成token,然后存儲token,我們的流程是這樣的:

圖片圖片

那么在這里的話,和以往不一樣的是,由于咱們的這個(gè)其實(shí)是一個(gè)多端的,所以的話咱們不僅僅有PC端還有移動端,所以token的話也是要做到多端的。

Token 存儲實(shí)體

這里新建了一個(gè)token的實(shí)體,用來存儲到redis里面。

@Data  
@AllArgsConstructor  
@NoArgsConstructor  
public class LoginToken {  
    //這個(gè)是我們的存儲Redis里面的Token  
    private String PcLoginToken;  
    private String MobileLoginToken;  
    private String LoginIP;  
}

login 業(yè)務(wù)代碼

主要是做多端的token。

@Service  
public class loginServiceImpl implements LoginService {  
  
    @Autowired  
    UserService userService;  
    @Autowired  
    RedisUtils redisUtils;  
    //為安全期間這里也做一個(gè)20防刷  
    @Override  
    public R Login(LoginEntity entity) {  
  
        String username = entity.getUsername();  
        String password = entity.getPassword();  
        password=password.replaceAll(" ","");  
        if(redisUtils.hasKey(RedisTransKey.getLoginKey(username))){  
            return R.error(BizCodeEnum.OVER_REQUESTS.getCode(),BizCodeEnum.OVER_REQUESTS.getMsg());  
        }  
        redisUtils.set(RedisTransKey.setLoginKey(username),1,20);  
        UserEntity User = userService.getOne(  
                new QueryWrapper<UserEntity>().eq("username", username)  
        );  
        if(User!=null){  
            if(SecurityUtils.matchesPassword(password,User.getPassword())){  
                //登錄成功,簽發(fā)token,按照平臺類型去簽發(fā)不同的Token  
                String token = JwtTokenUtil.generateToken(User);  
                //登錄成功后,將userid--->token存redis,便于做登錄驗(yàn)證  
                String ipAddr = GetIPAddrUtils.GetIPAddr();  
                if(entity.getType().equals(LoginType.PcType)){  
                    LoginToken loginToken = new LoginToken(token,null,ipAddr);  
                    redisUtils.set(RedisTransKey.setTokenKey(User.getUserid()+":"+LoginType.PcType)  
                            ,loginToken,7, TimeUnit.DAYS  
                    );  
                    return Objects.requireNonNull(R.ok(BizCodeEnum.SUCCESSFUL.getMsg())  
                                    .put(LoginType.PcLoginToken, token))  
                                    .put("userid",User.getUserid());  
                }else if (entity.getType().equals(LoginType.MobileType)){  
                    LoginToken loginToken = new LoginToken(null,token,ipAddr);  
                    redisUtils.set(RedisTransKey.setTokenKey(User.getUserid()+":"+LoginType.MobileType)  
                            ,loginToken,7, TimeUnit.DAYS  
                    );  
                    return Objects.requireNonNull(R.ok(BizCodeEnum.SUCCESSFUL.getMsg())  
                                    .put(LoginType.PcLoginToken, token))  
                                    .put("userid",User.getUserid());  
                } else {  
                    return R.error(BizCodeEnum.NUNKNOW_LGINTYPE.getCode(),BizCodeEnum.NUNKNOW_LGINTYPE.getMsg());  
                }  
            }else {  
                return R.error(BizCodeEnum.BAD_PUTDATA.getCode(),BizCodeEnum.BAD_PUTDATA.getMsg());  
            }  
        }else {  
            return R.error(BizCodeEnum.NO_SUCHUSER.getCode(),BizCodeEnum.NO_SUCHUSER.getMsg());  
        }  
    }  
}

枚舉類

public enum BizCodeEnum {  
    UNKNOW_EXCEPTION(10000,"系統(tǒng)未知異常"),  
    VAILD_EXCEPTION(10001,"參數(shù)格式校驗(yàn)失敗"),  
    HAS_USERNAME(10002,"已存在該用戶"),  
    OVER_REQUESTS(10003,"訪問頻次過多"),  
    OVER_TIME(10004,"操作超時(shí)"),  
    BAD_DOING(10005,"疑似惡意操作"),  
    BAD_EMAILCODE_VERIFY(10007,"郵箱驗(yàn)證碼錯(cuò)誤"),  
    REPARATION_GO(10008,"請重新操作"),  
    NO_SUCHUSER(10009,"該用戶不存在"),  
    BAD_PUTDATA(10010,"信息提交錯(cuò)誤,請重新檢查"),  
    NOT_LOGIN(10011,"用戶未登錄"),  
    BAD_LOGIN_PARAMS(10012,"請求異常!觸發(fā)5次以上賬號將保護(hù)性封禁"),  
    NUNKNOW_LGINTYPE(10013,"平臺識別異常"),  
    BAD_TOKEN(10014,"token校驗(yàn)失敗"),  
    SUCCESSFUL(200,"successful");  
  
    private int code;  
    private String msg;  
    BizCodeEnum(int code,String msg){  
        this.code = code;  
        this.msg = msg;  
    }  
  
    public int getCode() {  
        return code;  
    }  
  
    public String getMsg() {  
        return msg;  
    }  
}

異常處理

/**  
 * 校驗(yàn)用戶登錄時(shí),參數(shù)不對的情況,此時(shí)可能是惡意爬蟲  
 * */  
public class BadLoginParamsException extends Exception{  
    public BadLoginParamsException(){}  
    public BadLoginParamsException(String message){  
        super(message);  
    }  
  
}  
public class BadLoginTokenException extends Exception{  
    public BadLoginTokenException(){}  
    public BadLoginTokenException(String message){  
        super(message);  
    }  
}  
public class NotLoginException extends Exception{  
    public NotLoginException(){}  
    public NotLoginException(String message){  
        super(message);  
    }  
}

那么到此我們在登錄部分完成了對token的存儲(服務(wù)端):

圖片圖片

客戶端存儲

現(xiàn)在我們服務(wù)端已經(jīng)存儲好了,那么接下來就是要在客戶端進(jìn)行存儲。這個(gè)也好辦,我們直接來看到完整的用戶登錄代碼就知道了。

<template>  
  <div>  
    <el-form :model="formLogin" :rules="rules" ref="ruleForm" label-width="0px" >  
      <el-form-item prop="username">  
        <el-input v-model="formLogin.username" placeholder="賬號">  
          <i slot="prepend" class="el-icon-s-custom"/>  
        </el-input>  
      </el-form-item>  
      <el-form-item prop="password">  
        <el-input type="password" placeholder="密碼" v-model="formLogin.password">  
          <i slot="prepend" class="el-icon-lock"/>  
        </el-input>  
      </el-form-item>  
      <el-form-item prop="code">  
        <el-row :span="24">  
          <el-col :span="12">  
            <el-input v-model="formLogin.code" auto-complete="off"  placeholder="請輸入驗(yàn)證碼" size=""></el-input>  
          </el-col>  
          <el-col :span="12">  
            <div class="login-code" @click="refreshCode">  
              <!--驗(yàn)證碼組件-->  
              <s-identify :identifyCode="identifyCode"></s-identify>  
            </div>  
          </el-col>  
        </el-row>  
      </el-form-item>  
      <el-form-item>  
        <div class="login-btn">  
          <el-button type="primary" @click="submitForm()" style="margin-left: auto;width: 35%">登錄</el-button>  
          <el-button type="primary" @click="goRegister" style="margin-left: 27%;width: 35%" >注冊</el-button>  
        </div>  
      </el-form-item>  
    </el-form>  
  </div>  
</template>  
  
<script>  
import SIdentify from "../../components/SIdentify/SIdentify";  
export default {  
  name: "loginbyUserName",  
  components: { SIdentify },  
  data() {  
    return{  
      formLogin: {  
        username: "",  
        password: "",  
        code: ""  
      },  
      identifyCodes: '1234567890abcdefjhijklinopqrsduvwxyz',//隨機(jī)串內(nèi)容  
      identifyCode: '',  
      // 校驗(yàn)  
      rules: {  
        username:  
          [  
            { required: true, message: "請輸入用戶名", trigger: "blur" }  
          ],  
        password: [  
          { required: true, message: "請輸入密碼(區(qū)分大小寫)", trigger: "blur" }  
        ],  
        code: [  
          { required: true, message: "請輸入驗(yàn)證碼", trigger: "blur" }  
        ]  
      }  
  
    }  
  },  
  mounted () {  
    // 初始化驗(yàn)證碼  
    this.identifyCode = ''  
    this.makeCode(this.identifyCodes, 4)  
  },  
  methods:{  
    refreshCode () {  
      this.identifyCode = ''  
      this.makeCode(this.identifyCodes, 4)  
    },  
    makeCode (o, l) {  
      for (let i = 0; i < l; i++) {  
        this.identifyCode += this.identifyCodes[this.randomNum(0, this.identifyCodes.length)]  
      }  
    },  
    randomNum (min, max) {  
      return Math.floor(Math.random() * (max - min) + min)  
    },  
  
    submitForm(){  
  
      if (this.formLogin.code.toLowerCase() !== this.identifyCode.toLowerCase()) {  
        this.$message.error('請?zhí)顚懻_驗(yàn)證碼')  
        this.refreshCode()  
  
      }  
      else {  
        //這邊后面做一個(gè)提交,服務(wù)器驗(yàn)證,通過之后獲得token  
        this.axios({  
          url: "/user/user/login",  
          method: 'post',  
          data:{  
            "username":this.formLogin.username,  
            "password":this.formLogin.password,  
            "type": "PcType",  
          }  
        }).then((res)=>{  
            res = res.data  
          if (res.code===10001){  
            alert("請將對應(yīng)信息填寫完整!")  
          }else if(res.code===0){  
            alert("登錄成功")  
            localStorage.setExpire("LoginToken",res.PcLoginToken,this.OverTime)  
            localStorage.setExpire("userid",res.userid,this.OverTime)  
            this.$router.push({ path: '/userinfo', query: {'userid':res.userid} });  
          }else {  
            alert(res.msg);  
          }  
        })  
      }  
    },  
    goRegister(){  
      this.$router.push("/register")  
    }  
  },  
}  
</script>  
  
<style scoped>  
</style>

這里的話,咱們對localStorage做了一點(diǎn)優(yōu)化:

Storage.prototype.setExpire=(key, value, expire) =>{  
  let obj={  
    data:value,  
    time:Date.now(),  
    expire:expire  
  };  
  localStorage.setItem(key,JSON.stringify(obj));  
}  
//Storage優(yōu)化  
Storage.prototype.getExpire= key =>{  
  let val =localStorage.getItem(key);  
  if(!val){  
    return val;  
  }  
  val =JSON.parse(val);  
  if(Date.now()-val.time>val.expire){  
    localStorage.removeItem(key);  
    return null;  
  }  
  return val.data;  
}

這個(gè)this.OverTime 就是一個(gè)全局變量,就是7天過期的意思。

3token驗(yàn)證

前端提交

那么現(xiàn)在咱們來看看前端的代碼:

<script>  
export default {  
  name: "myspace",  
  data() {  
  
    return {  
  
    }  
  },  
  created() {  
    //先對token再進(jìn)行驗(yàn)證  
    let loginToken = localStorage.getExpire("LoginToken");  
    let userid = localStorage.getExpire("userid");  
    //這個(gè)只有用戶自己才能進(jìn)入,自己只能進(jìn)入自己對應(yīng)的MySpace  
    if(loginToken==null && userid==null){  
      alert("檢測到您未登錄,請先登錄")  
      this.$router.push({path: "/login"});  
    }else {  
        //發(fā)送token驗(yàn)證token是否正常,否則一樣不給過  
      this.axios({  
        url: "/user/user/space/isLogin",  
        method: 'get',  
        headers: {  
          "userid": userid,  
          "loginType": "PcType",  
          "loginToken": loginToken,  
        },  
        params: {  
          'userid': userid,  
        }  
      }).then((res)=>{  
        res = res.data;  
        if (!(res.code === 0)) {  
          alert(res.msg)  
          this.$router.push({path: "/login"});  
        }  
      }).catch((err)=>{  
        alert("未知異常,請重新登錄")  
        this.$router.push({path: "/login"});  
      });  
  
    }  
  }  
}  
</script>

后端校驗(yàn)

現(xiàn)在咱們可以來聊聊這個(gè)后端的校驗(yàn)了,這個(gè)還是很重要的,也是咱們今天的主角。

那么在開始的時(shí)候咱們說了這個(gè)使用攔截器的方案并不是可行的,而且在后面我們可能還需要在業(yè)務(wù)處理的時(shí)候拿到token去解析里面的東西,完成一些處理,到時(shí)候在攔截器的時(shí)候也不好處理。

而且重點(diǎn)是并不是所有的接口都要的,但是也不是少部分的接口不要,這就尷尬了,那么如何破局。此時(shí)我們就需要定位到每一個(gè)具體的方法上面,那么問題不就解決了,這個(gè)咋搞,誒嘿,搞個(gè)切面+注解不就完了。

自定義注解

先定義一個(gè)注解:

@Target(ElementType.METHOD)  
@Retention(RetentionPolicy.RUNTIME)  
public @interface NeedLogin {  
    String value() default "";  
}

切面處理

那么之后就是咱們的切面了,我們剛剛定義的異常處理類都是在這個(gè)切面上處理的。

public class VerificationAspect {  
  
    @Autowired  
    RedisUtils redisUtils;  
  
    @Pointcut("@annotation(com.huterox.common.holeAnnotation.NeedLogin)")  
    public void verification() {}  
  
    /**  
     * 環(huán)繞通知 @Around ,當(dāng)然也可以使用 @Before (前置通知)  @After (后置通知)就算了  
     * @param proceedingJoinPoint  
     * @return  
     * 我們這里再直接拋出異常,反正有那個(gè)誰統(tǒng)一異常類  
     */  
  
    @Around("verification()")  
    public Object verification(ProceedingJoinPoint proceedingJoinPoint) throws Throwable{  
  
        RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();  
        ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) requestAttributes;  
        assert servletRequestAttributes != null;  
        HttpServletRequest request = servletRequestAttributes.getRequest();  
        //分登錄的設(shè)備進(jìn)行驗(yàn)證  
        String loginType = request.getHeader("loginType");  
        String userid = request.getHeader("userid");  
        String tokenUser = request.getHeader("loginToken");  
        String tokenKey = RedisTransKey.getTokenKey(userid + ":" + loginType);  
        if(tokenUser==null || userid==null || loginType==null){  
            throw new BadLoginParamsException();  
        }  
        if(redisUtils.hasKey(tokenKey)){  
            if(loginType.equals(LoginType.PcType)){  
                Object o = redisUtils.get(tokenKey);  
                LoginToken loginToken = JSON.parseObject(o.toString(), LoginToken.class);  
                if(!loginToken.getPcLoginToken().equals(tokenUser)){  
                    throw new BadLoginTokenException();  
                }  
            }else if (loginType.equals(LoginType.MobileType)){  
                Object o = redisUtils.get(tokenKey);  
                LoginToken loginToken = JSON.parseObject(o.toString(), LoginToken.class);  
                if(!loginToken.getMobileLoginToken().equals(tokenUser)){  
                    throw new BadLoginTokenException();  
                }  
            }  
        }else {  
            throw new NotLoginException();  
        }  
  
        return proceedingJoinPoint.proceed();  
    }  
}
使用

那么接下來就是使用了。我們來看到這個(gè):

圖片圖片

這個(gè)是我們的controller,作用就是用來檢驗(yàn)這個(gè)用戶本地的token對不對的,那么實(shí)現(xiàn)的服務(wù)類啥也沒有:

圖片圖片

之后我們來看到咱們的一個(gè)效果:

圖片圖片

可以看到在進(jìn)入頁面的時(shí)候,鉤子函數(shù)會請求咱們的這個(gè)接口,然后的話,咱們通過這個(gè)接口的話可以看到驗(yàn)證的效果。這里驗(yàn)證通過了。

責(zé)任編輯:武曉燕 來源: 一安未來
相關(guān)推薦

2025-03-24 11:30:05

2024-09-12 14:50:08

2022-06-27 08:36:27

分布式事務(wù)XA規(guī)范

2023-11-01 18:02:33

RayPython分布式

2023-07-26 07:28:55

WebSocket服務(wù)器方案

2021-03-03 08:13:23

程序員分布式網(wǎng)絡(luò)

2021-03-08 09:56:24

存儲分布式Session

2019-10-10 09:16:34

Zookeeper架構(gòu)分布式

2023-05-29 14:07:00

Zuul網(wǎng)關(guān)系統(tǒng)

2019-06-19 15:40:06

分布式鎖RedisJava

2017-09-01 05:35:58

分布式計(jì)算存儲

2025-05-12 08:50:38

SpringBoot分布式事務(wù)

2022-08-16 18:52:20

分布式容錯(cuò)架構(gòu)

2024-06-13 09:34:35

JWTTokenSpring

2017-10-27 08:40:44

分布式存儲剪枝系統(tǒng)

2023-10-26 18:10:43

分布式并行技術(shù)系統(tǒng)

2024-03-01 09:53:34

2018-07-17 08:14:22

分布式分布式鎖方位

2024-06-07 08:06:36

2023-05-12 08:23:03

分布式系統(tǒng)網(wǎng)絡(luò)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

亚洲国产精品自拍| 成人av在线电影| 久久精品视频播放| 国产精品无码自拍| 成人免费影院| 国产精品免费视频一区| 不卡视频一区| 波多野结衣电车痴汉| 91精品蜜臀一区二区三区在线| 亚洲成人免费网站| 天天天干夜夜夜操| 精品精品导航| 欧美国产一区视频在线观看| 亚洲伊人久久综合| 日韩久久中文字幕| 欧美激情aⅴ一区二区三区| 亚洲人av在线影院| 精人妻一区二区三区| 成人做爰视频www| 欧美日韩激情视频| 久久最新免费视频| 精品三级久久久久久久电影聊斋| 国产成人啪午夜精品网站男同| 日韩av电影在线播放| 强行糟蹋人妻hd中文| 欧美色图一区| 精品在线小视频| 好吊操视频这里只有精品| 激情久久一区二区| 色八戒一区二区三区| 97在线免费视频观看| 成人精品一区二区三区免费 | 人妻一区二区三区四区| 毛片不卡一区二区| 国产成人精品综合久久久| 日本一区二区三区免费视频| 91精品二区| 最近2019中文字幕在线高清 | 久久不见久久见中文字幕免费| 91精品国产高清一区二区三区蜜臀| 成人一区二区三| 中日韩脚交footjobhd| 亚洲国产精品嫩草影院| 欧美性猛交内射兽交老熟妇| 日本电影全部在线观看网站视频| 久久久国产一区二区三区四区小说 | 成人免费播放器| 国产美女av在线| 国产精品国产三级国产专播品爱网| 欧美日韩三区四区| 婷婷国产在线| 91香蕉视频污在线| 久久99久久精品国产| 人妻精品无码一区二区| 国产电影一区在线| 999热视频在线观看| 国产色在线视频| 国产一区二区在线视频| 91青草视频久久| 国产精品国产av| 国产主播一区二区三区| 91久久久久久久久久久| 国产免费黄色大片| 国产精品综合一区二区| caoporen国产精品| 亚洲另类第一页| 欧美xxxhd| 欧美日韩免费一区| 欧美一级片中文字幕| 九九热线视频只有这里最精品| 色狠狠综合天天综合综合| 激情综合网俺也去| 日韩三级影视| 欧美日本韩国一区| 亚洲综合中文网| 豆花视频一区二区| 精品一区二区三区四区| 男人的天堂官网| 欧美激情欧美| 欧美国产在线视频| 在线视频一区二区三区四区| 日韩精品电影一区亚洲| 国产日韩精品在线观看| 性猛交xxxx乱大交孕妇印度| jlzzjlzz亚洲日本少妇| 欧洲一区二区日韩在线视频观看免费 | 9999在线视频| 色哟哟亚洲精品| 加勒比av中文字幕| 国产成人精品福利| 亚洲新声在线观看| 欧美黄色aaa| 亚洲一区免费| 成人写真福利网| 人妻妺妺窝人体色www聚色窝 | 日韩在线导航| 日韩精品分区| 精品视频1区2区| 无码人妻一区二区三区免费n鬼沢| 日韩大尺度在线观看| 日韩在线欧美在线| 成年人免费看毛片| 久久99深爱久久99精品| 狠狠色综合色区| 免费a在线看| 色综合久久天天| 最好看的中文字幕| 国产亚洲欧美日韩在线观看一区二区| 久久精品视频在线| 日本免费在线观看视频| 国产精品资源网| 日韩av一区二区三区在线| 欧美人与动牲性行为| 欧美性做爰猛烈叫床潮| 少妇精品无码一区二区三区| 国产电影一区二区在线观看| 欧美专区国产专区| 亚洲av无码国产综合专区| 中文字幕av在线一区二区三区| 日韩欧美精品免费| 亚洲美女色播| 亚洲午夜精品视频| 久久国产精品系列| 国产成人免费视| 在线播放 亚洲| 国产综合色区在线观看| 亚洲福利小视频| 99热精品免费| 国产一区二区精品久久99| 日韩精品一线二线三线| 中文字幕在线免费观看视频| 精品国产乱码久久久久久老虎| 亚洲区一区二区三| 日韩不卡一区二区| 日本免费一区二区三区| 小草在线视频免费播放| 亚洲精品91美女久久久久久久| 国产又黄又爽又无遮挡| 寂寞少妇一区二区三区| 亚洲精品在线免费看| 日韩电影大全网站| 亚洲色图国产精品| 黄色片中文字幕| 久久免费看少妇高潮| 69堂免费视频| 色狼人综合干| 青青在线视频一区二区三区| 飘雪影视在线观看免费观看| 欧美性猛交xxxx免费看漫画| 日本丰满少妇裸体自慰| 国产日韩免费| 青青草成人网| 美女色狠狠久久| 日韩中文字幕在线看| 亚洲天堂中文在线| 椎名由奈av一区二区三区| 免费在线观看污网站| 99久久久久国产精品| 成人日韩在线电影| 特级毛片在线| 精品88久久久久88久久久| 国产精品111| 91亚洲精品一区二区乱码| 免费观看日韩毛片| 久久99国内| 国产精品日韩av| 欧美极品视频| 日韩网站在线看片你懂的| 久久久久久久久99| va亚洲va日韩不卡在线观看| 成人三级视频在线播放| 成人国产精品一级毛片视频| 国产美女高潮久久白浆| 成人毛片av在线| 亚洲第一综合天堂另类专| 黄色在线观看国产| 国产目拍亚洲精品99久久精品| 色91精品久久久久久久久| 永久91嫩草亚洲精品人人| 国产91aaa| 日韩国产激情| 欧美刺激性大交免费视频| 欧美视频在线观看一区二区三区| 欧美日韩免费观看中文| www中文在线| 成人av在线一区二区| 日韩av一二三四| 亚洲欧美综合久久久| 国产一区二区黄色| 日本午夜精品久久久久| 久久人人爽人人爽人人片av高请| 青青草在线视频免费观看| 欧美三级韩国三级日本一级| 免费在线观看亚洲| 久久精品水蜜桃av综合天堂| 中文字幕在线视频一区二区| 亚洲永久免费| mm131午夜| 深爱激情综合网| 9a蜜桃久久久久久免费| 高清电影一区| 国产69精品久久久久99| 91精品国产91久久久久游泳池| 日韩欧美国产午夜精品| 自拍偷拍第八页| 午夜精品久久久久久久久久久| 精品日韩在线视频| 99久久精品国产网站| 天堂中文av在线| 天堂va蜜桃一区二区三区漫画版| 中文字幕色呦呦| 欧美自拍偷拍| 玖玖玖精品中文字幕| 日韩在线亚洲| 国产日本欧美视频| 免费观看欧美大片| 久久久久五月天| 超碰在线免费公开| 中文字幕av一区中文字幕天堂| 色婷婷av一区二区三区之e本道| 在线观看91av| 日本欧美www| 欧美午夜激情小视频| 日韩欧美中文字幕视频| 国产精品国产精品国产专区不蜜| 国精品无码人妻一区二区三区| 国产91精品一区二区| 亚洲综合激情视频| 毛片av一区二区| 日本爱爱免费视频| 亚洲一区二区动漫| 777777av| 一本色道久久综合亚洲精品不卡 | 三级外国片在线观看视频| 日韩麻豆第一页| 欧洲精品久久一区二区| 日韩女优制服丝袜电影| 国产视频在线观看视频| 欧美久久久一区| 这里只有精品9| 欧美乱妇15p| 国产精品欧美综合亚洲| 欧美日韩一级片在线观看| 亚洲图片欧美日韩| 一本色道**综合亚洲精品蜜桃冫| 日本高清www免费视频| 性做久久久久久免费观看 | 视频免费一区| 中文字幕视频一区二区在线有码 | 国产一区视频免费观看| 亚洲免费精品| 久久久久久久久久久福利| 一本色道久久综合亚洲精品高清| 精品视频免费在线播放| 亚洲一区二区伦理| 欧美xxxxx在线视频| 久久综合九色综合欧美狠狠| 青青在线视频免费| 蜜桃久久久久久久| 成人黄色一级大片| 国产精品一区三区| 韩国三级视频在线观看| 不卡在线视频中文字幕| 中文人妻一区二区三区| 久久精品视频在线看| www.4hu95.com四虎| 亚洲欧美在线视频观看| 在线免费日韩av| 午夜av一区二区| 中文字幕一区在线播放| 在线观看中文字幕不卡| 一级黄色录像大片| 欧美一区二区视频免费观看| 好吊视频一区二区三区| 亚洲美女性生活视频| av电影在线播放高清免费观看| 久久精品99国产精品酒店日本| 四虎影院观看视频在线观看| 97超级碰在线看视频免费在线看| 涩涩av在线| 国产在线观看一区二区三区| 97视频一区| 日本一区美女| 欧美+日本+国产+在线a∨观看| 国产一区二区在线视频播放| 日本系列欧美系列| 日韩精品国产一区| 国产亚洲婷婷免费| 国产精品白嫩白嫩大学美女| 日韩欧美成人免费视频| 国产精品乱码久久久| 亚洲精品福利资源站| 999在线视频| 久久免费精品日本久久中文字幕| 在线成人视屏| 99re6热在线精品视频播放速度| 亚洲人成精品久久久 | 午夜精品一区二区在线观看| 亚洲最新av| 成年人黄色片视频| 国产福利精品一区二区| 色婷婷在线影院| 亚洲最大的成人av| 亚洲 小说区 图片区| 欧美不卡视频一区| wwwxxx在线观看| 97色在线视频观看| 不卡一区视频| 日本不卡一区二区三区在线观看| 欧美福利专区| 亚洲欧美久久久久| 91丨国产丨九色丨pron| 破处女黄色一级片| 欧美亚洲图片小说| 香蕉国产在线视频| 欧美激情视频网站| 最新亚洲国产| 日韩三级电影| 亚洲女优在线| 亚洲婷婷在线观看| 亚洲卡通动漫在线| 一区二区www| 亚洲视频欧洲视频| 密臀av在线播放| 国产经品一区二区| 欧美黄色aaaa| 在线播放免费视频| 一区在线中文字幕| 一区二区日韩在线观看| 国产一区二区三区精品久久久 | 国产色在线观看| 国产欧美一区二区三区久久| 精品国产一区二区三区久久久樱花 | 3d蒂法精品啪啪一区二区免费| 成人aaaa| 视频二区在线播放| 国产精品三级久久久久三级| 中文字幕在线观看视频免费| 亚洲欧美日韩精品| 成人av免费电影网站| 精品一区二区三区国产| 日韩视频二区| 少妇毛片一区二区三区| 欧美日韩国产综合新一区| 天堂网在线资源| 韩国精品久久久999| 美女呻吟一区| 狠狠97人人婷婷五月| 91一区在线观看| 四虎影院在线免费播放| 亚洲欧美精品中文字幕在线| 成人免费影院| 亚洲欧美丝袜| 精品一区二区在线免费观看| 亚洲视频重口味| 欧美一区二区三区免费在线看 | 欧美色就是色| 一道本在线免费视频| 国产精品久久久久久户外露出| 在线视频免费观看一区| 欧美插天视频在线播放| 97青娱国产盛宴精品视频| 日韩免费视频播放| 久久久国产午夜精品| 在线亚洲欧美日韩| 久久99热精品| 日韩欧美黄色| 蜜臀av免费观看| 亚洲欧美日韩久久| 成人小说亚洲一区二区三区 | 女人色极品影院| av亚洲精华国产精华| 免费黄色片视频| 久久成年人视频| 嫩草国产精品入口| 国产精品天天av精麻传媒| 日韩久久一区二区| 色一情一乱一乱一区91av| 青草成人免费视频| 97精品国产一区二区三区| a级大片免费看| 欧美日韩中文字幕在线| 1pondo在线播放免费| 国产精品久久久久久久久久久久午夜片| 免费日韩av片| 精品国产精品国产精品| 日韩电影免费在线观看中文字幕 | 欧美激情精品久久久久久免费 | 免费观看污网站| 色天天综合色天天久久| 亚洲欧美成人影院| 日韩精品成人一区二区在线观看| 国产一区二区三区免费| 在线观看免费av片| 久久影视电视剧免费网站清宫辞电视| 荡女精品导航| 天天干天天玩天天操| 五月天激情综合| 老司机精品影院| 热re99久久精品国99热蜜月|