久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

SpringBoot集成Spring security JWT實現接口權限認證

瀏覽:3日期:2023-03-18 13:27:04
1、添加依賴

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId></dependency><dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version></dependency>2、集成JWT工具類(JwtUtils)

package com.dreamteam.chdapp.utils;import io.jsonwebtoken.Jwts;import io.jsonwebtoken.SignatureAlgorithm;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import javax.servlet.http.HttpServletRequest;import java.util.Date;import java.util.HashMap;import java.util.Map;/** * @Author HeYunHui * @create 2020/11/15 14:12 */public class JwtUtils { private static final Logger logger= LoggerFactory.getLogger(JwtUtils.class); public static final long EXPIRATION_TIME=60*60*1000;// 令牌環有效期 public static final String SECRET='abc123456def';//令牌環密鑰 public static final String TOKEN_PREFIX='Bearer';//令牌環頭標識 public static final String HEADER_STRING='Passport';//配置令牌環在http heads中的鍵值 public static final String ROLE='ROLE';//自定義字段-角色字段 //生成令牌環 public static String generateToken(String userRole,String userid){HashMap<String,Object> map=new HashMap<>();map.put(ROLE,userRole);map.put('userid',userid);String jwt= Jwts.builder().setClaims(map).setExpiration(new Date(System.currentTimeMillis()+EXPIRATION_TIME)).signWith(SignatureAlgorithm.HS512,SECRET).compact();return TOKEN_PREFIX+' '+jwt; } //生成令牌環 public static String generateToken(String userRole,String userid,long exprationtime){HashMap<String,Object> map=new HashMap<>();map.put(ROLE,userRole);map.put('userid',userid);String jwt= Jwts.builder().setClaims(map).setExpiration(new Date(System.currentTimeMillis()+exprationtime)).signWith(SignatureAlgorithm.HS512,SECRET).compact();return TOKEN_PREFIX+' '+jwt; } //令牌環校驗 public static Map<String,Object> validateTokenAndGetClaims(HttpServletRequest request){String token=request.getHeader(HEADER_STRING);if(token==null){ throw new TokenValidationException('Missing Token');}else{ Map<String,Object> body= Jwts.parser() .setSigningKey(SECRET) .parseClaimsJws(token.replace(TOKEN_PREFIX,'')) .getBody(); return body;} }static class TokenValidationException extends RuntimeException{public TokenValidationException(String msg){ super(msg);} }}3、集成JWT filter(攔截器/過濾器)

package com.dreamteam.chdapp.filter;import com.dreamteam.chdapp.utils.JwtUtils;import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;import org.springframework.security.core.context.SecurityContextHolder;import org.springframework.util.AntPathMatcher;import org.springframework.util.PathMatcher;import org.springframework.web.filter.OncePerRequestFilter;import javax.servlet.FilterChain;import javax.servlet.ServletException;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;import java.util.Arrays;import java.util.Map;import static com.dreamteam.chdapp.utils.JwtUtils.ROLE;/** * @Author HeYunHui * @create 2020/11/15 14:46 */public class JwtAuthenticationFilter extends OncePerRequestFilter { private static final PathMatcher pathmatcher = new AntPathMatcher(); private String[] protectUrlPattern = {'/manage/**', '/member/**', '/auth/**'}; //哪 些請求需要進行安全校驗 public JwtAuthenticationFilter() { } @Override protected void doFilterInternal(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, FilterChain filterChain) throws ServletException, IOException {//是不是可以在這里做多種方式登錄呢try { if (isProtectedUrl(httpServletRequest)) {Map<String, Object> claims = JwtUtils.validateTokenAndGetClaims(httpServletRequest);String role = String.valueOf(claims.get(ROLE));String userid = String.valueOf(claims.get('userid'));//最關鍵的部分就是這里, 我們直接注入了SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken(userid, null, Arrays.asList(() -> role))); }} catch (Exception e) { e.printStackTrace(); httpServletResponse.sendError(HttpServletResponse.SC_UNAUTHORIZED, e.getMessage()); return;}filterChain.doFilter(httpServletRequest, httpServletResponse); } //是否是保護連接 private boolean isProtectedUrl(HttpServletRequest request) {boolean flag = false;for (int i = 0; i < protectUrlPattern.length; i++) { if (pathmatcher.match(protectUrlPattern[i], request.getServletPath())) {return true; }}return false; }}4、配置JWT config類(配置類)

跨域訪問:客戶端與服務端域名不同或是端口號不同。防止跨域攻擊

package edu.ynmd.cms.config;import edu.ynmd.cms.filter.JwtAuthenticationFilter;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity;import org.springframework.security.config.annotation.web.builders.HttpSecurity;import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;import org.springframework.security.config.http.SessionCreationPolicy;import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;import org.springframework.security.crypto.password.PasswordEncoder;import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;import org.springframework.security.web.firewall.HttpFirewall;import org.springframework.security.web.firewall.StrictHttpFirewall;@Configuration@EnableWebSecurity@EnableGlobalMethodSecurity(prePostEnabled = true)public class WebSecurityConfig extends WebSecurityConfigurerAdapter { @Bean public PasswordEncoder passwordEncoder(){return new BCryptPasswordEncoder(); } @Bean public HttpFirewall allowUrlEncodedSlashHttpFirewall() {StrictHttpFirewall firewall = new StrictHttpFirewall();firewall.setAllowUrlEncodedSlash(true);return firewall; } @Override protected void configure(HttpSecurity http) throws Exception {http.csrf().disable().cors() //允許跨域訪問.and().authorizeRequests().antMatchers('/').authenticated() //配置那些url需要進行校驗--所有請求都需要校驗'/'.antMatchers('/public/**').permitAll() //那些請求不需要校驗.anyRequest().authenticated() //自定義校驗類.and().addFilterBefore(new JwtAuthenticationFilter(),UsernamePasswordAuthenticationFilter.class).sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS)//關閉session; }}5、Action注解

在Controller類中添加

@CrossOrigin@RestController@PreAuthorize('hasAuthority(’admin’)') //配置角色,擁有該角色的用戶方可訪問@RequestMapping('/manage')

postman測試http://localhost:7070/manage/userList,不可訪問

SpringBoot集成Spring security JWT實現接口權限認證

public開頭的可以訪問

6、token令牌環,訪問需校驗的資源

public的Controller類添加

@PostMapping('/login') @ResponseBody public HashMap<String,String> login( @RequestBody Account account) throws IOException {//Users u=manageService.getUserByUserNameAndPass(account.username,account.password);if(account.username.equals('admin')&&account.password.equals('123456')){//if(u!=null){ String jwt= JwtUtils.generateToken('admin','123456789abc');// String jwt= JwtUtils.generateToken(u.getRoleid(),u.getUsersid()); return new HashMap<String,String>(){{put('msg','ok');put('token',jwt);//put('role',u.getRoleid());put('role','admin'); }};}else { //return new ResponseEntity(HttpStatus.UNAUTHORIZED); return new HashMap<String,String>(){{put('msg','error');put('token','error'); }};} } public static class Account{public String username;public String password; }

postman測試,隨便輸用戶名密碼

SpringBoot集成Spring security JWT實現接口權限認證

輸入代碼中的用戶名密碼

SpringBoot集成Spring security JWT實現接口權限認證

去JWT官網https://jwt.io/,頁面下滑,將得到的token輸入,得到

SpringBoot集成Spring security JWT實現接口權限認證

manage的Controller類中添加測試

@GetMapping('testSecurityResource') @ResponseBody public String testSecurityResource() throws Exception{return '受保護的資源'; }

用postman訪問http://localhost:7070/manage/testSecurityResource,返回結果

SpringBoot集成Spring security JWT實現接口權限認證

7、service工具類

通用請求處理

package com.dreamteam.chdapp.controller.common;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.stereotype.Controller;/** * 通用請求處理 * @Author HeYunHui * @create 2020/11/14 15:38 */@Controllerpublic class CommonController { protected static final Logger log= LoggerFactory.getLogger(CommonController.class); /** * 字符串為空 * @param value * @return */ public static boolean isNullOrSpace(String value){if(value==null){ return true;}else { if(value.equals('')){return true; } else {return false; }} }}

Service層

String getCurrentUserId();//從令牌環中獲取useridString getCurrentRole();//從令牌環中獲取角色id

ServiceImpl

/** * 獲取當前登錄用的的Id * @return */ @Override public String getCurrentUserId() {String userid= (String) SecurityContextHolder.getContext().getAuthentication() .getPrincipal();if(CommonController.isNullOrSpace(userid)){ return null;}else { return userid;} } /** * 獲取當前登錄用戶的角色 * @return */ @Override public String getCurrentRole() {String role=null;Collection<SimpleGrantedAuthority> authorities = (Collection<SimpleGrantedAuthority>) SecurityContextHolder.getContext().getAuthentication().getAuthorities();for (GrantedAuthority authority : authorities) { role = authority.getAuthority();}if(CommonController.isNullOrSpace(role)){ return null;}else{ return role;} }

修改manage的Controller類

@GetMapping('testSecurityResource') @ResponseBody public String testSecurityResource() throws Exception{String userid=userInfoService.getCurrentUserId();String role=userInfoService.getCurrentRole();return '受保護的資源,當前用戶的id是'+userid+'當前用戶的角色是'+role; }

用postman測試

SpringBoot集成Spring security JWT實現接口權限認證

這是前面自定義的

SpringBoot集成Spring security JWT實現接口權限認證

8、識別token信息

SpringBoot集成Spring security JWT實現接口權限認證

如果將下圖中的角色換掉,將不能訪問

SpringBoot集成Spring security JWT實現接口權限認證

9、自動更新令牌環

添加Controller類

package com.dreamteam.chdapp.controller;import com.dreamteam.chdapp.controller.common.CommonController;import com.dreamteam.chdapp.utils.JwtUtils;import org.springframework.security.access.prepost.PreAuthorize;import org.springframework.security.core.GrantedAuthority;import org.springframework.security.core.authority.SimpleGrantedAuthority;import org.springframework.security.core.context.SecurityContextHolder;import org.springframework.web.bind.annotation.*;import javax.servlet.http.HttpServletRequest;import java.util.Collection;import java.util.HashMap;/** * 令牌環自動更新 * @Author HeYunHui * @create 2020/11/16 17:24 * @PreAuthorize('hasAuthority(’admin’)')//只允許有admin角色的用戶訪問 hasAnyAuthority([auth1,auth2]) */@CrossOrigin@RestController@PreAuthorize('hasAnyAuthority(’admin’,’member’)')@RequestMapping('/auth')public class AuthController { /** * 更新令牌環信息 * @param request * @return */ @GetMapping('refreshToken') @ResponseBody public HashMap<String,String> refreshToken(HttpServletRequest request){String role=null;Collection<SimpleGrantedAuthority> authorities = (Collection<SimpleGrantedAuthority>) SecurityContextHolder.getContext().getAuthentication().getAuthorities();for (GrantedAuthority authority : authorities) { role = authority.getAuthority();}// UserDetails userDetails = (UserDetails) SecurityContextHolder.getContext().getAuthentication() .getPrincipal();String userid= (String)SecurityContextHolder.getContext().getAuthentication() .getPrincipal();if(CommonController.isNullOrSpace(role)){ return new HashMap<String,String>(){{put('token','error'); }};}else{ String jwt=''; //一小時 jwt= JwtUtils.generateToken(role,userid,60*60*1000); HashMap<String,String> m=new HashMap<>(); m.put('token',jwt); return m;} } /** * 獲取當前登錄用戶的角色 * @return */ @GetMapping('getRole') @ResponseBody public HashMap<String,String> getRoleByToken(){String role='';String userid='';Collection<SimpleGrantedAuthority> authorities = (Collection<SimpleGrantedAuthority>) SecurityContextHolder.getContext().getAuthentication().getAuthorities();for (GrantedAuthority authority : authorities) { role = authority.getAuthority();}if(CommonController.isNullOrSpace(role)){ return new HashMap<String,String>(){{put('role','error'); }};}else{ HashMap<String,String> m=new HashMap<>(); m.put('role',role); return m;} }}

用postman測試

SpringBoot集成Spring security JWT實現接口權限認證

10、使用數據庫存儲用戶信息

(1)實體類

package com.dreamteam.chdapp.entity;import com.baomidou.mybatisplus.annotation.IdType;import com.baomidou.mybatisplus.annotation.TableId;import com.baomidou.mybatisplus.annotation.TableName;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import org.springframework.stereotype.Component;@Component@Data@AllArgsConstructor@NoArgsConstructor/** * 表名 */@TableName('users')public class Users { @TableId(type = IdType.AUTO) private String usrId; private String usrName; private String usrTel; private String usrPwd; private String usrType; }

UserMapper

package com.dreamteam.chdapp.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;import com.dreamteam.chdapp.entity.Users;import org.apache.ibatis.annotations.Mapper;import org.apache.ibatis.annotations.Param;import org.springframework.stereotype.Repository;import java.util.List;/** * @Author HeYunHui * @create 2020/11/11 21:50 */@Repository@Mapperpublic interface UserMapper extends BaseMapper<Users> { List<Users> getUsersByUsrNameAndPwd(@Param('usrName')String usrName, @Param('usrPwd') String usrPwd);}

UsersMapper.xml

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapperPUBLIC '-//mybatis.org//DTD Mapper 3.0//EN''http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.dreamteam.chdapp.mapper.UserMapper'> <select resultType='com.dreamteam.chdapp.entity.Users'>select * from users where #{usrName}=usr_name and #{usrPwd}=usr_pwd </select></mapper>

service

Users getUsersByUsrNameAndPwd(String usrName,String usrPwd);

serviceImpl JWT獲取用戶名密碼

@Override public Users getUsersByUsrNameAndPwd(String usrName, String usrPwd) {List<Users> ul=userMapper.getUsersByUsrNameAndPwd(usrName,usrPwd);if(ul.size()>0){ return ul.get(0);}return null; }

Controller

@PostMapping('/login') @ResponseBody public HashMap<String,String> login( @RequestBody Account account) throws IOException {Users u=userInfoService.getUsersByUsrNameAndPwd(account.username,account.password);//if(account.username.equals('admin')&&account.password.equals('123456')){if(u!=null){// String jwt= JwtUtils.generateToken('admin','123456789abc'); String jwt= JwtUtils.generateToken(u.getUsrType(),u.getUsrId()); return new HashMap<String,String>(){{put('msg','ok');put('token',jwt);put('role',u.getUsrType());//put('role','admin'); }};}else { //return new ResponseEntity(HttpStatus.UNAUTHORIZED); return new HashMap<String,String>(){{put('msg','error');put('token','error'); }};} } public static class Account{public String username;public String password; }

postman測試

a.登錄,生成token

SpringBoot集成Spring security JWT實現接口權限認證

b.輸入token訪問manage下的鏈接

SpringBoot集成Spring security JWT實現接口權限認證

到此這篇關于SpringBoot集成Spring security JWT實現接口權限認證的文章就介紹到這了,更多相關SpringBoot 接口權限認證內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 国产剧情一区二区三区 | 亚洲精品www久久久久久广东 | 国产男女视频在线观看 | 欧美性v| 成人精品视频 | 亚洲日本国产 | 久久爱www. | 欧美综合一区 | 日韩欧美在线观看视频网站 | 久久国产精品精品国产 | aa毛片| 亚洲精品久久久久999中文字幕 | 成人免费视频观看 | 国产最新网站 | 超碰一区二区三区 | aaa级片| 中国特黄毛片 | 国产色播av在线 | 99成人在线视频 | 香蕉久久久久久 | 欧美日韩精 | 久久视频一区 | 国产日韩欧美一区二区 | 成年人av网站 | 一区视频在线 | 午夜无码国产理论在线 | 久久久国产一区二区三区四区小说 | 久久成人精品一区二区三区 | 黄色精品视频 | 国产一区二区视频在线观看 | 欧美精品在线免费观看 | 在线观看亚洲视频 | 色综合一区| 在线观看成人网 | 久草免费在线视频 | 久久高清毛片 | 亚洲欧美国产精品专区久久 | 日韩成人高清 | 日日夜夜草 | 欧美综合在线一区 | 99久久免费精品国产男女性高好 | 99精品国产高清一区二区麻豆 | 99精品欧美一区二区三区综合在线 | 毛片久久久 | 精品久久久久久久 | 91免费网| 青青草久久网 | av免费在线观看网站 | 一级毛片av | 99在线视频播放 | 99re免费视频精品全部 | 久久精品欧美一区二区三区不卡 | 91av在线免费看 | 国产一区2区 | 国产综合亚洲精品一区二 | 久久久久久久国产精品 | 国产成人综合一区 | 欧美一区二区三区黄色 | 久久成人一区 | 色婷婷综合久久 | 久在线视频 | 欧美性生活视频 | 中文字幕乱码一区二区三区 | 视频在线一区二区 | 日韩在线一区二区 | 亚洲品质自拍视频网站 | 久久99久久99精品 | 欧美一区二区在线视频 | 伊人春色成人 | 精品日韩一区二区 | 国产精选一区二区三区 | 日批的视频 | 99精品国产高清一区二区麻豆 | 色8久久 | 国产成人99久久亚洲综合精品 | 国产精品中文字幕在线 | 国产精品福利午夜在线观看 | 亚洲国产成人精品女人久久久 | 日韩一区二区在线视频 | 久久精品亚洲精品国产欧美kt∨ | 99pao成人国产永久免费视频 | 欧洲亚洲视频 | 亚洲精品一区中文字幕乱码 | 成人高清 | 日本久久精品 | 久久亚洲精品视频 | 亚洲电影在线观看 | www.黄网| 亚洲成人免费视频在线观看 | 国产美女高潮视频 | 亚洲男人天堂2024 | 亚洲成人av在线 | 色综合一区二区三区 | 日韩视频网 | 国产一区二区三区在线免费观看 | 日韩2020狼一二三 | xxxx免费视频 | 狠狠狠干 | 日韩高清在线 | 欧美精品在线一区 | 国产偷自视频区视频 | 国产剧情一区二区 | 亚洲国产精品一区二区三区 | 国产在线h | 午夜精品久久久久久久星辰影院 | 日本黄色片免费看 | 亚洲精品视频在线播放 | 久久久久久久91 | 亚洲欧美日韩在线 | 99久久国产 | 在线观看亚洲一区二区三区 | 欧美福利在线观看 | 国产精品第一国产精品 | 成人深夜小视频 | 欧美一区二区三 | 91精彩视频在线观看 | 久久99亚洲精品 | 日本久久久久 | 成人观看免费视频 | 亚洲精品一区二区三区 | 亚洲精品日韩精品 | 国产一区二区免费 | 成人午夜精品一区二区三区 | 久久一区二区视频 | 国产一区精品在线 | 黄色影视在线免费观看 | 久久成人国产 | 久久久999国产 | 韩日免费视频 | 欧美日韩大陆 | 久久久精品国产 | 欧美日韩在线综合 | 婷婷免费在线观看 | 欧美在线观看一区二区 | 日韩精品在线播放 | a√毛片 | 久久久久亚洲一区二区三区 | 国产剧情一区二区 | 久久久国产视频 | 久操综合 | 99在线看 | 国产精品免费观看 | 天堂中文av在线 | 欧美中文日韩 | 国产免费av在线 | 99热国产在线观看 | www视频在线观看 | 国产传媒在线视频 | 国产成人精品一区二区三区四区 | www.亚洲区 | 人人干人人干人人干 | av免费黄色 | 超碰最新网址 | 亚洲xx在线 | 91久久精品国产91久久 | 国产三级毛片 | 亚洲精品色 | 日韩在线视频观看 | 亚洲免费在线观看 | 一区二区免费在线观看 | 日韩日韩日韩日韩日韩日韩 | 国产精品视频免费观看 | julia中文字幕久久一区二区 | 欧美日韩视频 | 久久国产精品视频 | 成人一区二区三区 | 一级在线看 | 亚洲视频一区二区三区 | 欧美一级毛片日韩一级 | 老牛影视av一区二区在线观看 | 欧美一级二级三级视频 | 午夜激情在线免费观看 | 欧美精品成人一区二区在线 | 国产精品美女久久久久久久久久久 | 国模精品视频一区二区 | 一级毛片观看 | 午夜精品一区二区三区在线播放 | 国产一区二区在线看 | 精品免费一区二区 | 成年免费a级毛片 | 午夜国产在线 | 成人午夜精品 | 久久女人精品 | 亚洲天堂一区二区 | 五月激情综合 | 欧美精品一区二区在线观看 | 山岸逢花在线观看 | 丝袜+亚洲+另类+欧美+变态 | 天天亚洲 | 国产精品久久久久久二区 | 后人极品翘臀美女在线播放 | 人人干人人干人人 | 国产伦精品一区二区三区在线 | 一区二区不卡视频 | 精品国产三级 | 欧美一区 | 久久免费电影 | 成人1区2区 | 久久久国产一区二区三区 | 狠狠狠干 | 精品久 | 香蕉成人啪国产精品视频综合网 | 久在线| 中文字幕在线三区 | 久久青青视频 | 久草美女 | 可以免费看的av | 在线二区 | 天天摸夜夜操 | 欧美日韩中文字幕 | www.啪啪 | 国产一区二区欧美 | 中文字幕一区二区三区精彩视频 | 精品在线视频一区 | 国产不卡在线观看 | 日本久久综合 | 国产不卡一二三区 | 中文字幕在线观看不卡视频 | 日韩免费网站 | 精品久久中文字幕 | av免费网 | av网址在线播放 | 久久久精品国产 | 99精品国产热久久91蜜凸 | 欧美激情啪啪 | 日韩精品视频在线观看一区二区 | 亚洲精品99| 欧美成人伊人 | 亚洲精品三级 | 91网在线播放| 精品国产精品三级精品av网址 | 日韩在线国产精品 | 久草在线资源福利站 | 国产午夜精品一区二区三区 | 久久久久久久一区 | 99re视频在线播放 | 亚州精品视频 | 鲁管视频 | 日韩精品网站在线观看 | 99精品久久久久久久免费 | 在线国产一区二区 | 一区二区三区影院 | 国产乱码精品一区二区三区中文 | 男女羞羞视频在线免费观看 | 国产精品国产精品国产专区不片 | av久久 | 亚洲一区久久久 | 国产精品久久久久久久久久东京 | 亚洲狠狠爱一区二区三区 | 蜜桃精品久久久久久久免费影院 | 国产精品久久久久久久久久东京 | 精品国模一区二区三区欧美 | 在线视频国产一区 | 久久精品视 | 日韩不卡av| 中文日韩在线 | 精品久久久久久国产 | 国产一区在线观看视频 | 久久精品视频一区 | 日本免费一区二区在线观看 | 一区二区三区久久 | 亚洲中出 | 美女在线视频一区二区 | 日韩中文字幕在线免费观看 | 成人妇女免费播放久久久 | 精品久久中文 | 久久亚洲国产精品 | 精品久久久久久国产 | 久久亚洲一区 | 美女视频黄的免费 | 草草草久久久 | 亚洲精品自在在线观看 | 国产精品久久久久久久久久10秀 | 亚洲国产精品久久久 | 久久精品一区二区三区四区 | 国产成人免费视频网站高清观看视频 | 亚洲精品7777xxxx青睐 | 中文天堂av | 亚洲精品久久 | 国产精品久久久久久久美男 | 凹凸日日摸日日碰夜夜爽孕妇 | 国产精品久久久久久亚洲调教 | 亚洲精品一区二区三区蜜桃久 | 日韩精品不卡 | 国产视频中文字幕 | 午夜资源 | 日韩国产在线看 | 亚洲国产日韩在线 | 亚洲一区二区三区四区在线 | 天天综合网久久综合网 | av大片| 日韩一级二级三级 | 99久久久久久 | 国产成人精品一区二区三区 | 久久精品欧美一区二区三区麻豆 | 国产成人精品av | 一级电影在线观看 | 亚洲精彩视频在线 | 亚洲成人第一区 | 成人午夜精品 | 国产亚洲一区二区三区在线观看 | 午夜精品久久久久久99热软件 | 国产精品成人在线 | 亚洲精品久久久久国产 | 欧美性猛交xxxx黑人猛交 | 国产精品视频一二三区 | 久久国产精品视频 | 欧美日韩在线视频观看 | 成人在线观看免费 | 五月激情综合网 | 中文字幕天堂在线 | 亚洲一区日韩 | 五月婷婷丁香 | 成年人在线观看 | av看片网| 成人在线观看免费 | 一区二区在线看 | 欧美激情视频一区二区三区在线播放 | 欧美a网| 99精品99| 在线观看亚洲大片短视频 | 国产欧美在线观看 | 日韩无在线| 激情久久久 | www.日韩| 午夜免费福利在线 | 欧美成人高清视频 | 欧美wwwsss9999 | 国产精品久久久久久久一区探花 | 一区二区在线播放视频 | 久久99精品久久久久久按摩秒播 | www.国产欧美 | 国产视频福利一区 | 亚洲国产精品久久久久久 | 精品国产一区在线 | 亚洲电影一区二区 | 精品国产免费久久久久久尖叫 | 天天干天操 | 操皮视频 | 成人免费高清 | 亚洲一区二区三区四区五区中文 | 天天看片天天操 | 日韩成人久久 | 四虎永久免费 | 国产精品美女视频一区二区三区 | 国产免费自拍av | 久久9视频 | 成人欧美一区二区三区黑人孕妇 | 精品九九 | 日本乱偷中文字幕 | 国产精品久久久爽爽爽麻豆色哟哟 | 亚洲精品国产高清 | 中文在线播放 | 亚洲精品久久久久久久久久 | 国产精品美女视频 | 欧美一区免费 | 亚洲成人久久久 | 欧洲妇女成人淫片aaa视频 | 99re视频在线观看 | 欧美一区二区黄色片 | 日本三级国产 | 91麻豆精品国产91久久久更新时间 | 色猫猫国产区一区二在线视频 | 日韩在线视频资源 | 久久国产精品一区 | 国产精品久久一区 | 中文字幕在线观看 | 亚洲精品乱码久久久久久金桔影视 | 国产一区二区精品在线观看 | 精品国产91亚洲一区二区三区www | 91综合视频在线观看 | 特级毛片 | 国产一级特黄aaa | 亚州成人 | 狠狠躁日日躁夜夜躁东南亚 | 午夜视频在线 | 欧美八区| 日日夜夜爽 | 国内成人免费视频 | 中文字幕视频在线播放 | 欧美午夜一区二区三区 | 91久久国产 | 奇米影视奇米色777欧美 | 一级a性色生活片久久毛片 夜夜视频 | 亚洲中午字幕 | 国产精品黄网站在线观看 | 色婷婷国产精品久久包臀 | 亚洲一区二区三区四区五区中文 | 久久中文在线观看 | 99爱在线观看 | 毛片国产| 精品久久久久久亚洲综合网站 | 国产免费观看一区二区三区 | 欧美激情国产日韩精品一区18 | 最新国产福利在线 | 欧美.com | 国产在线一区二区三区 | 香蕉大人久久国产成人av | 小川阿佐美88av在线播放 | 国内精品视频一区国产 | 蜜臀久久99精品久久久无需会员 | 成人精品久久 | 午夜精品久久久久久久久久久久久 | 色毛片| 欧美一级一区 | 中文字幕在线日韩 | 欧美亚洲专区 | 伊人网综合在线 | 午夜精品久久久久久久久久久久 | 日韩在线免费 | 日韩精品一区二区在线观看 | 久久久久久国产精品 | www欧美| 色视频免费在线观看 | 最新日韩视频 | 欧美xxxx黑人又粗又长 | v亚洲| 在线激情网 | 99精品视频在线观看 | 欧美日在线 | 999在线观看精品免费不卡网站 | 久久久久香蕉视频 | 久久午夜视频 | 成人精品在线 | 看毛片软件 | 精品久久久久久国产 | 久草视频在线播放 | 欧美日韩亚洲在线 | 亚洲精品视频一区 | 亚洲精品久久 | 亚洲一区二区中文字幕 | 麻豆自拍偷拍 | 欧美精品久久久久久久久久丰满 | www成人精品| 呦呦在线观看 | 国产精品久久久久久久久久久免费看 | 成人免费视频在线观看 | 亚洲国产精品久久久久婷婷老年 | 久久亚洲一区 | www一区| 天天操狠狠操 | 婷婷五月色综合香五月 | 精品成人久久 | 丁香婷婷久久久综合精品国产 | 欧美日一级片 | 日韩视频在线免费观看 | 欧美一级在线观看 | 黄色成人在线网站 | 粉嫩视频在线观看 | 欧美第一区 | 久草视频在线观 | 欧美精品一区二区三区一线天视频 | 亚洲一区二区免费视频 | 久久一区二区三 | 国内自拍视频在线观看 | 日本中文字幕在线播放 | 日韩在线观看成人 | 一区二区三区四区在线 | 久久久精品久久久久久 | 日韩欧美理论片 | 精产国产伦理一二三区 | 国产视频一区二区 | 精品www| 久久国产精品视频 | 日韩爱爱视频 | 成年人在线观看视频 | 亚洲国产精品久久久久秋霞蜜臀 | 亚洲精品久久一区二区三区 | 精品视频免费在线 | 国产一区91 | 欧美成年人视频 | 久久久久久久 | 日韩精品一区在线视频 | 欧美日韩电影一区 | 热久久影院 | 国产成人影院 | 欧美精品v国产精品v日韩精品 | 免费一级毛片 | 狠狠操狠狠干 | 在线亚洲一区 | 国产精品久久久久久久久久久久久久久久 | 九色91在线| 欧美日韩亚洲一区二区 | 亚洲每日更新 | 久久精品一区二区三区四区 | 免费观看一级黄色片 | 永久免费在线 | 男人天堂999 | 国产伦精品一区二区三区照片91 | 国内精品一区二区三区 | 精品欧美日韩 | 欧美成人精品 | 黄色欧美视频 | 国产精品69久久久久水密桃 | 福利视频一区 | 巨大黑人极品videos精品 | 99久久精品国产一区二区成人 | 亚洲第一天堂无码专区 | 99热在线精品播放 | 久久精品一区二区国产 | 中文字幕在线免费看 | 99精品欧美一区二区三区综合在线 | 日韩快播电影 | 国产在线综合网 | 国产精品成人av | 色婷婷综合在线视频 | a久久 | 午夜免费一区二区播放 | 日韩国产一区二区 | 黄色一级大片视频 | 国产伦精品一区二区三区高清 | 97av | 这里精品 | 国产ts人妖另类 | 99久久国产| 婷婷丁香五 | 欧美一区二区三区在线观看视频 | 国产成人无遮挡在线视频 | 欧美成人一区二区三区片免费 | 亚洲另类视频 | 国产一区av在线 | 中文在线亚洲 | 超碰美女 | 伊人青青操 | 91精品国产91久久综合桃花 | 成人精品二区 | www.99精品 | 国产一区二区三区在线 | 久久成人国产精品 | 妹子干综合| 成人亚洲 | 日韩精品一区二区三区视频播放 | 夜本色 | 波多野结衣一区二 | 国产999精品久久久久久 | 国产乱码精品一区二区三区av | 欧美日韩在线一 | 黄色天堂在线观看 | h片在线看 | av一区在线观看 | 操久久| 国产一区二区三区在线免费 | 一区二区免费视频 | 日韩欧美一级在线 | 精品视频在线免费观看 | 一区二区在线视频免费观看 | 成人国产精品视频 | 麻豆视频国产 | 亚洲欧洲中文日韩 | 91精品国产色综合久久不卡98口 | 久久伊人久久 | 国产亚洲一区二区精品 | 成人免费福利 | 九九热这里都是精品 | 亚洲美女网址 | 久久国产精品久久久久久 | 国产成人精品高清久久 | 欧美日韩一区二区视频在线观看 | 男人阁久久 | 欧美日韩国产精品 | 久久成人综合 | 国产精品国产三级国产aⅴ9色 | 天天操夜夜拍 | 久久精品小视频 | 国产欧美一区二区视频 | 日韩av一区二区三区四区 | 国产精品视频入口 | 日韩国产在线 | 91久久久www播放日本观看 | 一区二区三区免费看 | 亚洲精品久久久 | 国产精品一二三区 | 成年人网站国产 | 国产高清免费视频 | 中文字幕第31页 | 精品久久不卡 | 国产欧美在线播放 | 亚洲中国精品精华液 | 欧美精品第一页 | 欧美一级一区 | 久久久影视 | 亚洲国产视频一区 | 欧美黄色a视频 | 自拍小电影 | 久久久综合亚洲91久久98 | 久久久国产一区二区 | 国产精品高清在线观看 | 伊人最新网址 | 中文字幕一区在线 | 国产精品久久久久久久午夜片 | 国产精品色哟哟哟 | 91免费看片| 最新高清无码专区 | 中文视频一区 | 香蕉大人久久国产成人av | 日韩国伦理久久一区 | 成人 在线 | 神马电影午夜 | 国精品一区 | 欧美日韩国产中文字幕 | 国产一区二区三区久久久久久 | 色视频在线免费观看 | 久久视频免费在线 | 成人免费一区二区三区视频网站 | 日韩性精品| 一区二区亚洲 | 午夜在线观看视频网站 | 国产一区二区三区四区 | 手机久久看片 | 中文一区 | 韩日精品视频 | 日韩一区三区 | 日韩视频在线播放 | 亚洲精品第一区在线观看 | 狠狠色综合色综合网络 |