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

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot中整合Shiro實(shí)現(xiàn)權(quán)限管理的示例代碼

瀏覽:2日期:2023-04-26 14:58:24

之前在 SSM 項(xiàng)目中使用過 shiro,發(fā)現(xiàn) shiro 的權(quán)限管理做的真不錯,但是在 SSM 項(xiàng)目中的配置太繁雜了,于是這次在 SpringBoot 中使用了 shiro,下面一起看看吧

一、簡介

Apache Shiro是一個強(qiáng)大且易用的Java安全框架,執(zhí)行身份驗(yàn)證、授權(quán)、密碼和會話管理。使用Shiro的易于理解的API,您可以快速、輕松地獲得任何應(yīng)用程序,從最小的移動應(yīng)用程序到最大的網(wǎng)絡(luò)和企業(yè)應(yīng)用程序。

三個核心組件:

1、Subject

即“當(dāng)前操作用戶”。但是,在 Shiro 中,Subject 這一概念并不僅僅指人,也可以是第三方進(jìn)程、后臺帳戶(Daemon Account)或其他類似事物。它僅僅意味著“當(dāng)前跟軟件交互的東西”。Subject 代表了當(dāng)前用戶的安全操作,SecurityManager 則管理所有用戶的安全操作。

2、SecurityManager

它是Shiro 框架的核心,典型的 Facade 模式,Shiro 通過 SecurityManager 來管理內(nèi)部組件實(shí)例,并通過它來提供安全管理的各種服務(wù)。

3、Realm

Realm 充當(dāng)了 Shiro 與應(yīng)用安全數(shù)據(jù)間的“橋梁”或者“連接器”。也就是說,當(dāng)對用戶執(zhí)行認(rèn)證(登錄)和授權(quán)(訪問控制)驗(yàn)證時,Shiro 會從應(yīng)用配置的 Realm 中查找用戶及其權(quán)限信息。從這個意義上講,Realm 實(shí)質(zhì)上是一個安全相關(guān)的 DAO:它封裝了數(shù)據(jù)源的連接細(xì)節(jié),并在需要時將相關(guān)數(shù)據(jù)提供給 Shiro。當(dāng)配置 Shiro 時,你必須至少指定一個 Realm,用于認(rèn)證和(或)授權(quán)。配置多個 Realm 是可以的,但是至少需要一個。Shiro 內(nèi)置了可以連接大量安全數(shù)據(jù)源(又名目錄)的 Realm,如 LDAP、關(guān)系數(shù)據(jù)庫(JDBC)、類似 INI 的文本配置資源以及屬性文件等。如果缺省的 Realm 不能滿足需求,你還可以插入代表自定義數(shù)據(jù)源的自己的 Realm 實(shí)現(xiàn)。

二、整合 shiro

1、引入 maven 依賴

<!-- web支持 --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!-- thymeleaf 模板引擎 --><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId></dependency><!-- Shiro 權(quán)限管理 --><dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-spring</artifactId> <version>1.2.4</version></dependency><!-- 為了能夠在 html 中使用 shiro 的標(biāo)簽引入 --><dependency> <groupId>com.github.theborakompanioni</groupId> <artifactId>thymeleaf-extras-shiro</artifactId> <version>2.0.0</version></dependency>

我使用的 SpringBoot 版本是 2.3.1,其它依賴自己看著引入吧

2、創(chuàng)建 shiro 配置文件

關(guān)于 shiro 的配置信息,我們都放在 ShiroConfig.java 文件中

import at.pollux.thymeleaf.shiro.dialect.ShiroDialect;import org.apache.shiro.authc.credential.HashedCredentialsMatcher;import org.apache.shiro.mgt.SecurityManager;import org.apache.shiro.spring.LifecycleBeanPostProcessor;import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;import org.apache.shiro.spring.web.ShiroFilterFactoryBean;import org.apache.shiro.web.mgt.DefaultWebSecurityManager;import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.DependsOn;import java.util.LinkedHashMap;import java.util.Map;/** * shiro配置類 */@Configurationpublic class ShiroConfig { /** * 注入這個是是為了在thymeleaf中使用shiro的自定義tag。 */ @Bean(name = 'shiroDialect') public ShiroDialect shiroDialect() { return new ShiroDialect(); } /** * 地址過濾器 * @param securityManager * @return */ @Bean public ShiroFilterFactoryBean shiroFilterFactoryBean(SecurityManager securityManager) { ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); // 設(shè)置securityManager shiroFilterFactoryBean.setSecurityManager(securityManager); // 設(shè)置登錄url shiroFilterFactoryBean.setLoginUrl('/login'); // 設(shè)置主頁url shiroFilterFactoryBean.setSuccessUrl('/'); // 設(shè)置未授權(quán)的url shiroFilterFactoryBean.setUnauthorizedUrl('/unauthorized'); Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>(); // 開放登錄接口 filterChainDefinitionMap.put('/doLogin', 'anon'); // 開放靜態(tài)資源文件 filterChainDefinitionMap.put('/css/**', 'anon'); filterChainDefinitionMap.put('/img/**', 'anon'); filterChainDefinitionMap.put('/js/**', 'anon'); filterChainDefinitionMap.put('/layui/**', 'anon'); // 其余url全部攔截,必須放在最后 filterChainDefinitionMap.put('/**', 'authc'); shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap); return shiroFilterFactoryBean; } /** * 自定義安全管理策略 */ @Bean public SecurityManager securityManager() { DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); /** 設(shè)置自定義的relam */ securityManager.setRealm(loginRelam()); return securityManager; } /** * 登錄驗(yàn)證 */ @Bean public LoginRelam loginRelam() { return new LoginRelam(); } /** * 以下是為了能夠使用@RequiresPermission()等標(biāo)簽 */ @Bean @DependsOn({'lifecycleBeanPostProcessor'}) public DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator() { DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator = new DefaultAdvisorAutoProxyCreator(); advisorAutoProxyCreator.setProxyTargetClass(true); return advisorAutoProxyCreator; } @Bean public static LifecycleBeanPostProcessor lifecycleBeanPostProcessor() { return new LifecycleBeanPostProcessor(); } @Bean public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor() { AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor(); authorizationAttributeSourceAdvisor.setSecurityManager(securityManager()); return authorizationAttributeSourceAdvisor; }}

上面開放靜態(tài)資源文件,其它博客說的是 **filterChainDefinitionMap.put('/static/**', 'anon');** ,但我發(fā)現(xiàn),我們在 html 文件中引入靜態(tài)文件時,請求路徑根本沒有經(jīng)過 static,thymeleaf 自動默認(rèn)配置 **static/** 下面就是靜態(tài)資源文件,所以,我們開放靜態(tài)資源文件需要指定響應(yīng)的目錄路徑

2、登錄驗(yàn)證管理

關(guān)于登錄驗(yàn)證的一些邏輯,以及賦權(quán)等操作,我們都放在 LoginRelam.java 文件中

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;import com.zyxx.sbm.entity.UserInfo;import com.zyxx.sbm.service.RolePermissionService;import com.zyxx.sbm.service.UserInfoService;import com.zyxx.sbm.service.UserRoleService;import org.apache.shiro.authc.*;import org.apache.shiro.authc.credential.CredentialsMatcher;import org.apache.shiro.authz.AuthorizationInfo;import org.apache.shiro.authz.SimpleAuthorizationInfo;import org.apache.shiro.realm.AuthorizingRealm;import org.apache.shiro.subject.PrincipalCollection;import org.apache.shiro.util.ByteSource;import org.springframework.beans.factory.annotation.Autowired;import java.util.Set;/** * 登錄授權(quán) */public class LoginRelam extends AuthorizingRealm { @Autowired private UserInfoService userInfoService; @Autowired private UserRoleService userRoleService; @Autowired private RolePermissionService rolePermissionService; /** * 身份認(rèn)證 * * @param authenticationToken * @return * @throws AuthenticationException */ @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException { // 獲取基于用戶名和密碼的令牌:實(shí)際上這個authcToken是從LoginController里面currentUser.login(token)傳過來的 UsernamePasswordToken token = (UsernamePasswordToken) authenticationToken; //根據(jù)用戶名查找到用戶信息 QueryWrapper<UserInfo> queryWrapper = new QueryWrapper<>(); queryWrapper.eq('account', token.getUsername()); UserInfo userInfo = userInfoService.getOne(queryWrapper); // 沒找到帳號 if (null == userInfo) { throw new UnknownAccountException(); } // 校驗(yàn)用戶狀態(tài) if ('1'.equals(userInfo.getStatus())) { throw new DisabledAccountException(); } // 認(rèn)證緩存信息 return new SimpleAuthenticationInfo(userInfo, userInfo.getPassword(), ByteSource.Util.bytes(userInfo.getAccount()), getName()); } /** * 角色授權(quán) * * @param principalCollection * @return */ @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) { UserInfo authorizingUser = (UserInfo) principalCollection.getPrimaryPrincipal(); if (null != authorizingUser) { //權(quán)限信息對象info,用來存放查出的用戶的所有的角色(role)及權(quán)限(permission) SimpleAuthorizationInfo simpleAuthorizationInfo = new SimpleAuthorizationInfo(); //獲得用戶角色列表 Set<String> roleSigns = userRoleService.listUserRoleByUserId(authorizingUser.getId()); simpleAuthorizationInfo.addRoles(roleSigns); //獲得權(quán)限列表 Set<String> permissionSigns = rolePermissionService.listRolePermissionByUserId(authorizingUser.getId()); simpleAuthorizationInfo.addStringPermissions(permissionSigns); return simpleAuthorizationInfo; } return null; } /** * 自定義加密規(guī)則 * * @param credentialsMatcher */ @Override public void setCredentialsMatcher(CredentialsMatcher credentialsMatcher) { // 自定義認(rèn)證加密方式 CustomCredentialsMatcher customCredentialsMatcher = new CustomCredentialsMatcher(); // 設(shè)置自定義認(rèn)證加密方式 super.setCredentialsMatcher(customCredentialsMatcher); }}

以上就是登錄時,需要指明 shiro 對用戶的一些驗(yàn)證、授權(quán)等操作,還有自定義密碼驗(yàn)證規(guī)則,在第3步會講到,獲取角色列表,權(quán)限列表,需要獲取到角色與權(quán)限的標(biāo)識,每一個角色,每一個權(quán)限都有唯一的標(biāo)識,裝入 Set 中

3、自定義密碼驗(yàn)證規(guī)則

密碼的驗(yàn)證規(guī)則,我們放在了 CustomCredentialsMatcher.java 文件中

import org.apache.shiro.authc.AuthenticationInfo;import org.apache.shiro.authc.AuthenticationToken;import org.apache.shiro.authc.UsernamePasswordToken;import org.apache.shiro.authc.credential.SimpleCredentialsMatcher;import org.apache.shiro.crypto.hash.SimpleHash;/** * @ClassName CustomCredentialsMatcher * 自定義密碼加密規(guī)則 * @Author Lizhou * @Date 2020-07-10 16:24:24 **/public class CustomCredentialsMatcher extends SimpleCredentialsMatcher { @Override public boolean doCredentialsMatch(AuthenticationToken authcToken, AuthenticationInfo info) { UsernamePasswordToken token = (UsernamePasswordToken) authcToken; //加密類型,密碼,鹽值,迭代次數(shù) Object tokenCredentials = new SimpleHash('md5', token.getPassword(), token.getUsername(), 6).toHex(); // 數(shù)據(jù)庫存儲密碼 Object accountCredentials = getCredentials(info); // 將密碼加密與系統(tǒng)加密后的密碼校驗(yàn),內(nèi)容一致就返回true,不一致就返回false return equals(tokenCredentials, accountCredentials); }}

我們采用的密碼加密方式為 MD5 加密,加密 6 次,使用登錄賬戶作為加密密碼的鹽進(jìn)行加密

4、密碼加密工具

上面我們自定義了密碼加密規(guī)則,我們創(chuàng)建一個密碼加密的工具類 PasswordUtils.java 文件

import org.apache.shiro.crypto.hash.Md5Hash;/** * 密碼加密的處理工具類 */public class PasswordUtils { /** * 迭代次數(shù) */ private static final int ITERATIONS = 6; private PasswordUtils() { throw new AssertionError(); } /** * 字符串加密函數(shù)MD5實(shí)現(xiàn) * * @param password 密碼 * @param loginName 用戶名 * @return */ public static String getPassword(String password, String loginName) { return new Md5Hash(password, loginName, ITERATIONS).toString(); }}

三、開始登錄

上面,我們已經(jīng)配置了 shiro 的一系列操作,從登錄驗(yàn)證、密碼驗(yàn)證規(guī)則、用戶授權(quán)等等,下面我們就開始登錄,登錄的操作,放在了 LoginController.java 文件中

import com.zyxx.common.consts.SystemConst;import com.zyxx.common.enums.StatusEnums;import com.zyxx.common.kaptcha.KaptchaUtil;import com.zyxx.common.shiro.SingletonLoginUtils;import com.zyxx.common.utils.PasswordUtils;import com.zyxx.common.utils.ResponseResult;import com.zyxx.sbm.entity.UserInfo;import com.zyxx.sbm.service.PermissionInfoService;import io.swagger.annotations.Api;import io.swagger.annotations.ApiImplicitParam;import io.swagger.annotations.ApiImplicitParams;import io.swagger.annotations.ApiOperation;import org.apache.shiro.SecurityUtils;import org.apache.shiro.authc.*;import org.apache.shiro.subject.Subject;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.PostMapping;import org.springframework.web.bind.annotation.ResponseBody;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/** * @ClassName LoginController * @Description * @Author Lizhou * @Date 2020-07-02 10:54:54 **/@Api(tags = '后臺管理端--登錄')@Controllerpublic class LoginController { @Autowired private PermissionInfoService permissionInfoService; @ApiOperation(value = '請求登錄頁面', notes = '請求登錄頁面') @GetMapping('login') public String init() { return 'login'; } @ApiOperation(value = '請求主頁面', notes = '請求主頁面') @GetMapping('/') public String index() { return 'index'; } @ApiOperation(value = '登錄驗(yàn)證', notes = '登錄驗(yàn)證') @ApiImplicitParams({ @ApiImplicitParam(name = 'account', value = '賬號', required = true), @ApiImplicitParam(name = 'password', value = '密碼', required = true), @ApiImplicitParam(name = 'resCode', value = '驗(yàn)證碼', required = true), @ApiImplicitParam(name = 'rememberMe', value = '記住登錄', required = true) }) @PostMapping('doLogin') @ResponseBody public ResponseResult doLogin(String account, String password, String resCode, Boolean rememberMe, HttpServletRequest request, HttpServletResponse response) throws Exception { // 驗(yàn)證碼 if (!KaptchaUtil.validate(resCode, request)) { return ResponseResult.getInstance().error(StatusEnums.KAPTCH_ERROR); } // 驗(yàn)證帳號和密碼 Subject subject = SecurityUtils.getSubject(); UsernamePasswordToken token = new UsernamePasswordToken(account, password); // 記住登錄狀態(tài) token.setRememberMe(rememberMe); try { // 執(zhí)行登錄 subject.login(token); // 將用戶保存到session中 UserInfo userInfo = (UserInfo) subject.getPrincipal(); request.getSession().setAttribute(SystemConst.SYSTEM_USER_SESSION, userInfo); return ResponseResult.getInstance().success(); } catch (UnknownAccountException e) { return ResponseResult.getInstance().error('賬戶不存在'); } catch (DisabledAccountException e) { return ResponseResult.getInstance().error('賬戶已被凍結(jié)'); } catch (IncorrectCredentialsException e) { return ResponseResult.getInstance().error('密碼不正確'); } catch (ExcessiveAttemptsException e) { return ResponseResult.getInstance().error('密碼連續(xù)輸入錯誤超過5次,鎖定半小時'); } catch (RuntimeException e) { return ResponseResult.getInstance().error('未知錯誤'); } } @ApiOperation(value = '登錄成功,跳轉(zhuǎn)主頁面', notes = '登錄成功,跳轉(zhuǎn)主頁面') @PostMapping('success') public String success() { return 'redirect:/'; } @ApiOperation(value = '初始化菜單數(shù)據(jù)', notes = '初始化菜單數(shù)據(jù)') @GetMapping('initMenu') @ResponseBody public String initMenu() { return permissionInfoService.initMenu(); } @ApiOperation(value = '退出登錄', notes = '退出登錄') @GetMapping(value = 'loginOut') public String logout() { Subject subject = SecurityUtils.getSubject(); subject.logout(); return 'login'; }}

當(dāng)執(zhí)行 subject.login(token); 時,就會進(jìn)入我們在 第二步中第二條登錄驗(yàn)證中,對用戶密碼、狀態(tài)進(jìn)行檢查,對用戶授權(quán)等操作,登錄的密碼,一定是通過密碼加密工具得到的,不然驗(yàn)證不通過

四、頁面權(quán)限控制

我們本次使用的是 thymeleaf 模板引擎,我們需要在 html 文件中加入以下內(nèi)容

<!DOCTYPE html><html xmlns='http://www.w3.org/1999/xhtml' xmlns:th='http://www.thymeleaf.org' xmlns:shiro='http://www.pollix.at/thymeleaf/shiro'>

引入了 thymeleaf 的依賴,以及 shiro 的依賴,這樣我們就能在 html 文件中使用 thymeleaf、shiro 的標(biāo)簽了

例如:

1、判斷當(dāng)前用戶有無此權(quán)限,通過權(quán)限標(biāo)識

<button shiro:hasPermission='user_info_add'><i class='layui-icon'>&#xe654;</i> 新增 </button>

2、與上面相反,判斷當(dāng)前用戶無此權(quán)限,通過權(quán)限標(biāo)識,沒有時驗(yàn)證通過

<button shiro:lacksPermission='user_info_add'><i class='layui-icon'>&#xe654;</i> 新增 </button>

3、判斷當(dāng)前用戶有無以下全部權(quán)限,通過權(quán)限標(biāo)識

<button shiro:hasAllPermissions='user_info_add'><i class='layui-icon'>&#xe654;</i> 新增 </button>

4、判斷當(dāng)前用戶有無以下任一權(quán)限,通過權(quán)限標(biāo)識

<button shiro:hasAnyPermissions='user_info_add'><i class='layui-icon'>&#xe654;</i> 新增 </button>

5、判斷當(dāng)前用戶有無此角色,通過角色標(biāo)識

<a shiro:hasRole='admin' href='http://www.gepszalag.com/bcjs/admin.html' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' >Administer the system</a>

6、與上面相反,判斷當(dāng)前用戶無此角色,通過角色標(biāo)識,沒有時驗(yàn)證通過

<a shiro:lacksRole='admin' href='http://www.gepszalag.com/bcjs/admin.html' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' >Administer the system</a>

7、判斷當(dāng)前用戶有無以下全部角色,通過角色標(biāo)識

<a shiro:hasAllRoles='admin,role1,role2' href='http://www.gepszalag.com/bcjs/admin.html' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' >Administer the system</a>

8、判斷當(dāng)前用戶有無以下任一角色,通過角色標(biāo)識

<a shiro:hasAnyRoles='admin,role1,role2' href='http://www.gepszalag.com/bcjs/admin.html' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' >Administer the system</a>

到此這篇關(guān)于SpringBoot中整合Shiro實(shí)現(xiàn)權(quán)限管理的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot整合Shiro權(quán)限內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 久久久.com| 亚洲精彩视频在线观看 | 亚洲国产精品成人综合色在线婷婷 | 国产成人精品久久二区二区91 | 国内精品一区二区三区 | 亚洲日本韩国在线观看 | 91精品国产自产91精品 | 深夜福利亚洲 | 五月婷婷综合激情网 | 国产午夜久久 | 一区二区影院 | 黄色一级视 | 91精品一区二区三区久久久久久 | 午夜在线电影 | 成人一二三区 | 久久久久久这里只有精品 | 日韩视频―中文字幕 | 一区二区免费在线视频 | 国产乱码精品一区二区三区忘忧草 | 欧美中文字幕在线 | 亚洲精品国产区 | 日本福利网站 | 五月婷婷色| 天天干天天操 | 欧美日韩国产综合在线 | 97超碰自拍| 91在线精品一区二区三区 | 中文字幕视频免费观看 | 美女一区二区三区四区 | 日韩高清中文字幕 | 久久亚洲一区二区 | 亚洲啊v在线 | 亚洲伦理 | 国产大片aaa | 久久一二 | 国产高清在线a视频大全 | 亚洲一区二区三区观看 | 99re热精品视频国产免费 | 视频一区免费观看 | 欧美韩国日本一区 | 日韩精品一区二区三区视频播放 | 国产精品国产成人国产三级 | 91aiai| av成人在线观看 | 久久综合久色欧美综合狠狠 | 一级电影院| 国产欧美日韩成人 | 真人一级毛片 | 国产日韩欧美在线 | 欧美日韩综合视频 | 一区二区亚洲 | 婷婷伊人| 国产午夜视频 | 国产一级黄色 | 啪啪免费网站 | 中文字幕国产 | 精品久久一区二区三区 | 青青草免费在线视频 | 久久国产亚洲精品 | 国产黄色大片免费看 | 中文字幕在线观看av | 日韩三区| 欧美精品欧美精品系列 | 91手机精品视频 | 国产亚洲一区二区三区 | 一区二区免费视频 | 国产亚洲一区二区三区 | 91精品久久久久久久久久 | 亚洲一区在线日韩在线深爱 | 久久久久亚洲精品 | 中文字幕亚洲第一 | 精品欧美黑人一区二区三区 | 国产视频福利一区 | 免费激情网站 | 91精品国产综合久久婷婷香蕉 | 神马久久久久久久久 | 日本成年人免费网站 | 国产一区二区三区四区视频 | 国产专区一区 | 日韩av电影网| 日韩一区在线播放 | 国产美女永久免费无遮挡 | 国产精品99久久 | 久久免费视频观看 | 国产精品视频 | 久久国产精品99久久久久久牛牛 | 国产亚洲精品综合一区91555 | 国产成人午夜精品影院游乐网 | 真人一级毛片 | 欧美日本国产一区 | 青青草av电影 | 久久av一区二区三区 | 蜜桃精品久久久久久久免费影院 | 欧美精品免费在线观看 | 国产91福利视频 | 精品国产乱码一区二区三区 | 国产精品无码专区在线观看 | 久久久久久久久99精品 | 91精品国产综合久久久久久丝袜 | 国产精品无码久久久久 | 精品久久久久久久久久久久久久 | 黄色一级毛片在线观看 | 成人在线免费小视频 | 日夜夜精品 | 一区二区三区在线不卡 | 亚洲国产高清在线 | 久久激情视频 | 国产综合区 | 久久夜色精品 | 久久99深爱久久99精品 | 日韩久久影院 | 日韩超级大片免费看国产国产播放器 | 日韩精品免费在线观看 | 亚洲欧美一区二区三区四区 | 成人在线一区二区三区 | 二区视频 | 久久国产精品一区 | 97国产精品视频人人做人人爱 | 精品无码久久久久国产 | 激情五月综合网 | 久久久久国产精品午夜一区 | 国产黄色一级片 | 91精品在线播放 | 国产伦精品一区二区三区在线 | 亚洲乱码国产乱码精品精98午夜 | 黄色片网站 | 亚洲一区二区三区高清 | 国产精品久久免费视频在线 | 这里精品| 久久国产精品99久久久久久牛牛 | 日韩精品一区二区三区中文字幕 | 国产精品毛片久久久久久久 | 叶山小百合av一区二区 | 精品久久久久久久久久久久久久 | 欧美3区 | 日韩欧美自拍 | 精品国产一区二区三区久久久 | 欧美一区| 99精品欧美一区二区三区综合在线 | 精品久久久久久久久久久久 | 色爱综合网 | 免费黄网视频 | 久久99国产精品久久99大师 | 91精品亚洲 | 欧美激情在线精品一区二区三区 | 在线视频不卡一区 | 久久久高清 | 久久视频免费 | 亚洲高清视频在线 | 91观看| 欧美激情欧美激情在线五月 | 热re99久久精品国产99热 | 国产精品一区二区视频 | √8天堂资源地址中文在线 成人欧美一区二区三区白人 | 91视频入口 | 久久99精品国产麻豆婷婷洗澡 | a级毛片免费高清视频 | 亚洲欧美一区二区三区久久 | 久久久久久日产精品 | 老牛嫩草一区二区三区眼镜 | 久久人人网 | 亚洲人在线播放 | 国产精品自产av一区二区三区 | 精品久久国产 | 欧美一级在线观看视频 | 日韩在线精品视频 | 精品国产乱码久久久久久影片 | 久久久久亚洲 | 亚洲精品视频在线 | 国产乱xxxxx97国语对白 | 久久99精品国产.久久久久 | 中文字幕亚洲区 | 欧美乱码久久久久久蜜桃 | 亚洲毛片 | 久久精品一区视频 | 久草天堂| 99re99| 97国产精品视频人人做人人爱 | 欧美一级片在线 | 欧美午夜一区二区三区免费大片 | 国产欧美精品一区二区 | 亚洲国产精品久久久久 | 久草久草久草 | 亚洲欧美日韩精品久久奇米色影视 | 人人插| 精品九九久久 | 久久福利 | 免费观看一级视频 | 伊人欧美在线 | 国产精品久久久久久 | 天天干天天草 | 国产精品久久久久久久免费大片 | 亚洲国产精品自拍 | 91精品国产自产91精品 | 噜噜噜视频在线观看 | 欧美高清视频一区 | 国产福利在线观看 | 国产三级自拍 | 黄色免费观看 | 日本一区二区不卡 | 国产免费网址 | 欧美一级片在线 | 日本久久精品一区 | 国产精品三级在线 | 国产a视频 | 国产浪潮av色综合久久超碰 | www.久久| 国产二区三区 | 天堂在线网 | 日韩美女爱爱 | 欧美三级在线视频 | 91午夜激情 | 亚洲人成人一区二区在线观看 | 成人av免费观看 | 欧美a区 | 在线亚洲不卡 | 999在线观看视频 | 欧美污污 | 国产美女久久 | 中文字幕免费看 | 成人不卡| 龙珠z中文版普通话 | 精品国产乱码久久久久久1区2区 | 国产成人av一区二区 | 精品在线一区二区 | 国产人体视频 | 狠狠久 | 亚洲成人精品在线 | 97视频在线 | 日韩欧美成人一区二区三区 | 国产日韩精品一区二区在线观看播放 | 国产伦精品一区二区三区在线 | 国产精品免费看 | 久久高清国产 | 欧美精品成人 | 久久一区二区三区四区 | 麻豆成人在线 | 免费视频一区 | 久久青草国产 | 亚洲精品久久久久久久久久久 | 亚洲精品久久久久久久久久久 | 久久久综合色 | 日韩中文字幕国产 | 成人片免费看 | 亚洲欧美国产一区二区 | 午夜视频网站 | 久久综合电影 | 成人亚洲精品久久久久 | 久久av网 | 欧美猛交ⅹxxx乱大交视频 | 久久久久久艹 | 亚洲人成在线播放 | 91免费版在线观看 | 日韩美女av在线 | 国家aaa的一级看片 h片在线看 | 成人做爰69片免费 | a级毛片基地| 中文字幕日韩一区二区不卡 | 一区二区三区不卡视频 | 国产九九精品 | 人人爽视频 | 亚洲大片一区 | 91精品国产综合久久福利软件 | 欧美午夜精品久久久久久人妖 | 久久九 | 九九精品视频在线 | www国产亚洲 | 午夜影院在线观看免费 | 亚洲午夜精品一区二区三区 | 精品国产一区二区三区久久久久久 | 另类中文字幕 | 精品久久久久一区二区三区 | 四虎最新入口 | 久久se精品一区精品二区 | 卡通动漫第一页 | 亚洲综合首页 | 国产精彩视频 | 国产欧美日韩综合精品 | 久久久精品网 | 91久久国产综合久久 | 欧美一区| 色免费视频 | 久久爱综合 | 日韩一区二区三区在线 | 91午夜在线 | 欧美精品成人一区二区三区四区 | 日本天天操 | 黄色成人免费看 | 国产xxx在线观看 | 国产精品综合久久 | 免费在线日本 | 欧美日韩精品一区二区在线播放 | 99视频精品在线 | 国产成人一区 | 羞羞在线观看视频免费观看hd | 中文字幕免费观看 | 一区二区三区日韩 | 亚洲网站在线观看 | 久久不卡日韩美女 | 黄色一级大片视频 | 国产精品45p | 午夜大片在线观看 | www..99re| 综合久久综合久久 | 国产视频中文字幕 | 国产精品乱码人人做人人爱 | 伊人久久综合 | 久久久久久国产免费视网址 | 自拍偷拍精品 | 欧日韩在线视频 | 国产高清精品一区 | 精品视频一区二区三区 | 午夜一级毛片 | 久久视频在线 | 久久精彩视频 | av成人在线观看 | 亚洲欧美日韩精品久久奇米色影视 | 成人激情视频在线免费观看 | 中文字幕久久精品 | 日韩爽妇网 | 亚洲国产精品99久久久久久久久 | 91一级| 亚洲第一区在线 | 日韩在线视频一区 | 亚洲免费在线播放 | 蜜桃免费一区二区三区 | 国产一区二区三区免费 | 99久久国产综合精品女不卡 | 欧美日韩黄色一区二区 | 亚洲成人精品视频 | 一级在线观看 | 日批免费在线观看 | 亚洲成人看片 | 亚洲免费观看视频 | 欧美国产精品一区 | 亚洲午夜一区 | 欧美一级二级视频 | 精品国产乱码久久久久久久软件 | 亚洲高清网 | 成人免费视频播放 | 久久人人av | 国产精品国产成人国产三级 | 国产欧美精品在线 | 国产视频精品视频 | 日韩在线观看三区 | 自拍偷拍欧美 | 久久久成人精品 | 夜夜艹 | 黄色一级毛片 | 亚洲网在线 | 欧美精品亚洲 | 91午夜在线 | 中文字幕 国产精品 | 毛片免费观看 | 日韩国产二区 | 国产亚洲精品美女久久久久久久久久 | 福利精品在线观看 | 超碰一区 | eeuss国产一区二区三区四区 | av网站观看| 色黄视频在线观看 | 亚洲成人av在线播放 | 国产欧美精品 | 丁香亚洲| 视频在线一区二区 | 中文在线一区二区 | 日日摸夜夜添夜夜添亚洲女人 | 日韩免费一级 | 亚洲精品久久久久久久久久久 | 亚洲精品电影网在线观看 | 91九色麻豆| 日本久久精品电影 | 精品日韩| 国产一区二区精品 | 天天操网址 | 亚洲欧洲日本国产 | www.亚洲| 一二三四在线视频观看社区 | 久久综合久久综合久久 | 日韩一区二区在线观看视频 | 久久国产成人 | 91在线观看视频 | 免费看h| av一区在线观看 | 三级日韩 | 精品日韩一区二区三区 | 日韩精品一二区 | 国产精品毛片在线 | 亚洲成av人片在线观看无码 | 国产精品久久久久久久一区探花 | 视频一区在线播放 | 免费看的黄色 | 小情侣高清国产在线播放 | 台湾佬成人 | 蜜桃一区二区 | 欧美日韩视频在线第一区 | 深夜福利1000| 国产一区二区三区在线 | 精品一区二区三区免费视频 | 中文字幕一区二区三区乱码图片 | 久久综合久久综合久久 | 可以在线观看的av网站 | 欧美精产国品一二三区 | 成人欧美一区二区三区黑人孕妇 | 久草热8精品视频在线观看 黄色片网站视频 | 一区二区三区高清不卡 | 99精品国产高清一区二区麻豆 | 野狼在线社区2017入口 | 国产一页| 亚洲综合视频一区 | 欧美日韩精品 | 久久久91精品国产一区二区三区 | 亚洲精品一区国产精品 | 国产成人在线一区二区 | 日韩欧美一二三区 | 海外中文字幕在线观看 | 成人国产在线观看 | 久久精品a级毛片 | 中文精品在线 | 中国一级免费毛片 | 精国产品一区二区三区四季综 | 一区二区三区在线免费 | 一级片在线播放 | 欧美日韩不卡合集视频 | 久久久成人精品 | 黄在线看v| 91看片免费 | 在线观看免费成人av | 亚洲成a | aaa在线观看 | 欧美日产国产成人免费图片 | 二区欧美 | 午夜男人的天堂 | 91资源在线观看 | 亚洲国产成人精品久久 | 一级电影免费在线观看 | 日日久| 国产日韩一区二区 | 狠狠插天天干 | 国产精品久久久久久吹潮 | 欧美在线亚洲 | 国产乱码精品一区二区三区五月婷 | 精品99久久久久久 | 国产精品99久久久久久动医院 | 国产日韩欧美在线 | 一区二区三区免费在线 | a欧美| 欧洲免费毛片 | 亚洲欧美日韩另类精品一区二区三区 | 亚洲社区在线观看 | 久久精品国产99精品国产亚洲性色 | 久久2018| 久久精品久久久久 | 欧美a区 | 99久久日韩精品视频免费在线观看 | 日韩在线观看中文字幕 | 精品少妇一区二区三区 | 久久成人18免费网站 | 精品国产一区二区三区日日嗨 | 范冰冰一级做a爰片久久毛片 | 国产精品欧美久久久久一区二区 | 国产成人看片 | 小情侣高清国产在线播放 | www.99久久久 | 久久三区 | 国产真实乱全部视频 | 国产人成精品一区二区三 | 国产精品久久久久久久久久10秀 | 久久久久国产一区 | 国产亚洲一区二区三区 | 亚洲成人在线网站 | 欧美精品久久久 | 欧美一区二区三区国产精品 | 人人精久 | 久久久久综合 | 成人亚洲视频 | 欧美中文在线 | 毛片视频观看 | 欧美日韩在线播放 | 99免费精品 | 99精品网站 | 国产黄色免费小视频 | 亚洲二区在线观看 | 国产精品久久精品 | 日日摸夜夜添夜夜添高潮视频 | 国产精品一区在线观看 | 国产探花在线看 | 亚洲成人一区二区三区 | 国产一级片免费观看 | 精品国产91亚洲一区二区三区www | 欧美日韩一区二区视频在线观看 | 一区二区三区亚洲 | 91成人在线免费视频 | 日韩免费视频 | 久久六月 | 国产高清视频在线 | 亚洲国产成人av好男人在线观看 | 日本久久久久久久久久久久 | 久久成人一区 | 成人国产在线观看 | 精品国产成人 | 久久久国产一区二区三区 | 国产日韩精品一区二区在线观看播放 | 日韩免费一区二区 | 久久精品2 | 99精品全国免费观看视频软件 | 日日操夜夜 | 中文字幕 国产精品 | 日韩av免费在线观看 | 欧美一级毛片免费看 | 亚洲一区二区在线看 | 久久久看片 | 综合久久99 | 欧美激情a∨在线视频播放 中文字幕网在线 | 久久成人18免费网站 | 国产精品久久国产精品 | 在线中文 | 久久精品一区二区三区四区 | 日本一级毛片视频 | 免费成人在线视频网站 | 欧美日韩第一页 | 爱啪导航一精品导航站 | 日韩福利一区 | 丁香亚洲| 亚洲国产婷婷香蕉久久久久久99 | 色婷婷av一区二区三区大白胸 | 81精品国产乱码久久久久久 | 日韩一区二区在线观看 | 高清一区二区三区 | 日韩精品在线一区 | 自拍偷拍99 | 亚洲视频观看 | 国产一区 | 国产日韩欧美综合 | 国外成人在线视频网站 | 日韩精品在线视频 | 欧日韩不卡在线视频 | 欧美日韩一区二区在线观看 | 美女一区 | 久久视频国产 | 国产二区在线播放 | 99热新| 国产一区二区免费 | 亚洲日本欧美日韩高观看 | 亚洲人在线播放 | 国产精品一区二区久久久 | av性色 | 免费国产视频 | 激情欧美一区二区三区中文字幕 | 精品国产成人 | 国产毛片在线 | 亚洲精品在线观看免费 | 午夜精品视频在线观看 | 亚洲精品视频免费 | 亚洲精品亚洲人成人网 | 亚洲男人天堂网 | 欧美精品一区在线观看 | 久久精品99| 欧美精品欧美精品系列 | 91电影在线观看 | 日韩中文字幕免费视频 | 欧美日韩视频在线观看一区 | 欧美国产91 | 97视频精品 | 欧美日黄 | 91av爱爱 | 欧美日韩综合精品 | 亚洲精品日韩精品 | 中文字幕av黄色 | 欧美日一区二区 | 久久精品国产亚洲blacked | 日韩一区中文 | 欧美视频在线一区 | 黄色毛片在线看 | 国产伦精品一区二区 | 天堂中文在线视频 | 欧美一a一片一级一片 | 日日骚视频 | 日韩三级视频 | 精品亚洲一区二区三区四区五区 | 国产精品99久久久久 | 欧美中文字幕在线 | 久久亚洲精品国产一区 | 久久99久久99精品 | 一区二区日韩精品 | 亚洲精品在线免费播放 | www.99精品| 国产激情偷乱视频一区二区三区 | 日b片| 好看毛片 | 天堂中文网官网 | 欧美精品一区二区三区一线天视频 | 人人玩人人添人人澡97 | 日日久 | 精品国产乱码久久久久久88av | 国产在线观看一区二区 | 国产在线第一页 | 亚洲一区| 女同videos另类 | 亚洲一区二区在线电影 | 国产欧美精品一区二区 | 蜜桃av在线播放 | 成年人网站免费在线观看 | 91视频一88av | 国产性色av | 国产黄色精品 | 在线免费毛片 | 一区二区三区四区在线 | 日韩在线不卡 | 日韩一区二区免费视频 | av网址在线播放 | 国产欧美日韩精品一区二区三区 | 欧美日韩精品久久久久 | 99pao成人国产永久免费视频 | 日韩视频在线免费播放 |