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

Spring Boot3.3 項(xiàng)目數(shù)據(jù)庫(kù)連接使用SM4國(guó)密加密算法進(jìn)行脫敏配置

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù)
本文通過(guò)實(shí)際案例,詳細(xì)介紹了如何在Spring Boot項(xiàng)目中使用SM4國(guó)密加密算法對(duì)數(shù)據(jù)庫(kù)連接信息和用戶數(shù)據(jù)進(jìn)行加密與脫敏處理。我們展示了如何配置加密和解密操作,結(jié)合MyBatis-Plus實(shí)現(xiàn)數(shù)據(jù)庫(kù)操作,并通過(guò)Thymeleaf和Bootstrap構(gòu)建前端頁(yè)面進(jìn)行安全展示。

在現(xiàn)代企業(yè)級(jí)應(yīng)用開(kāi)發(fā)中,數(shù)據(jù)安全問(wèn)題越來(lái)越受到重視。尤其是在處理敏感信息如數(shù)據(jù)庫(kù)連接字符串、用戶名、密碼以及用戶個(gè)人信息(如身份證號(hào))時(shí),如何在保證系統(tǒng)功能正常的前提下對(duì)這些敏感數(shù)據(jù)進(jìn)行有效的保護(hù),已經(jīng)成為了開(kāi)發(fā)人員必須面對(duì)的挑戰(zhàn)。本文將通過(guò)一個(gè)實(shí)際的Spring Boot項(xiàng)目案例,介紹如何使用國(guó)密SM4加密算法對(duì)數(shù)據(jù)庫(kù)連接中的url、username和password等信息進(jìn)行加密處理,同時(shí)對(duì)用戶表中的身份證號(hào)等敏感數(shù)據(jù)進(jìn)行脫敏顯示。

本文將詳細(xì)展示如何配置Spring Boot項(xiàng)目以支持SM4加密算法,如何編寫代碼實(shí)現(xiàn)數(shù)據(jù)加密和解密,以及如何結(jié)合MyBatis-Plus實(shí)現(xiàn)數(shù)據(jù)庫(kù)的CRUD操作,并在前端頁(yè)面進(jìn)行數(shù)據(jù)的展示與脫敏處理。我們將從配置文件的加密解密、后端服務(wù)的實(shí)現(xiàn)到前端視圖的展示,逐步引導(dǎo)讀者構(gòu)建一個(gè)完整的、注重?cái)?shù)據(jù)安全的Spring Boot項(xiàng)目。

運(yùn)行效果:

圖片圖片

若想獲取項(xiàng)目完整代碼以及其他文章的項(xiàng)目源碼,且在代碼編寫時(shí)遇到問(wèn)題需要咨詢交流,歡迎加入下方的知識(shí)星球。

表的DDL語(yǔ)句和插入數(shù)據(jù)的SQL語(yǔ)句

首先,我們需要?jiǎng)?chuàng)建一個(gè)user表,并插入10條用戶數(shù)據(jù)。

-- 創(chuàng)建user表
CREATE TABLE user (
    id BIGINT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(50) NOT NULL,
    id_number VARCHAR(18) NOT NULL,
    email VARCHAR(50) NOT NULL,
    phone VARCHAR(15) NOT NULL,
    address VARCHAR(100)
);

-- 插入10條用戶數(shù)據(jù)
INSERT INTO user (name, id_number, email, phone, address) VALUES
('張三', '110101199001011234', 'zhangsan@example.com', '13800138000', '北京市朝陽(yáng)區(qū)'),
('李四', '110102199002021234', 'lisi@example.com', '13800138001', '北京市海淀區(qū)'),
('王五', '110103199003031234', 'wangwu@example.com', '13800138002', '北京市西城區(qū)'),
('趙六', '110104199004041234', 'zhaoliu@example.com', '13800138003', '北京市東城區(qū)'),
('錢七', '110105199005051234', 'qianqi@example.com', '13800138004', '北京市豐臺(tái)區(qū)'),
('孫八', '110106199006061234', 'sunba@example.com', '13800138005', '北京市石景山區(qū)'),
('周九', '110107199007071234', 'zhoujiu@example.com', '13800138006', '北京市通州區(qū)'),
('吳十', '110108199008081234', 'wushi@example.com', '13800138007', '北京市大興區(qū)'),
('鄭十一', '110109199009091234', 'zhengshiyi@example.com', '13800138008', '北京市昌平區(qū)'),
('王十二', '110110199010101234', 'wangshier@example.com', '13800138009', '北京市房山區(qū)');

引入SM4國(guó)密加密算法的依賴

在Spring Boot項(xiàng)目中,我們首先需要在pom.xml文件中引入必要的依賴。

<?xml versinotallow="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>3.3.3</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.icoderoad</groupId>
	<artifactId>SM4Encryption</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>SM4Encryption</name>
	<description>Demo project for Spring Boot</description>
	
	<properties>
		<java.version>17</java.version>
		<mybatis-spring.version>3.0.3</mybatis-spring.version>
		<mybatis-plus-boot-starter.version>3.5.7</mybatis-plus-boot-starter.version>
		<aliyun-java-sdk-cor.version>4.5.0</aliyun-java-sdk-cor.version>
		<bootstrap.version>5.1.3</bootstrap.version>
		<jquery.version>3.6.0</jquery.version>
	</properties>
	<dependencies>
		<!-- Spring Boot 依賴 -->
	    <dependency>
	        <groupId>org.springframework.boot</groupId>
	        <artifactId>spring-boot-starter-web</artifactId>
	    </dependency>
	   <!-- 數(shù)據(jù)庫(kù)驅(qū)動(dòng)依賴 -->
	    <dependency>
	        <groupId>com.mysql</groupId>
	        <artifactId>mysql-connector-j</artifactId>
	        <scope>runtime</scope>
	    </dependency>
	     <!-- MyBatis-Plus 依賴 -->
	    <dependency>
	        <groupId>com.baomidou</groupId>
	        <artifactId>mybatis-plus-boot-starter</artifactId>
	        <version>${mybatis-plus-boot-starter.version}</version>
	    </dependency>
	     <dependency>
	          <groupId>org.mybatis</groupId>
	          <artifactId>mybatis-spring</artifactId>
	          <version>${mybatis-spring.version}</version>
	      </dependency>
	    <!-- SM4 加密算法依賴 -->
	    <dependency>
	        <groupId>com.aliyun</groupId>
	        <artifactId>aliyun-java-sdk-core</artifactId>
	        <version>${aliyun-java-sdk-cor.version}</version>
	    </dependency>
	  	<dependency>
		        <groupId>org.projectlombok</groupId>
		        <artifactId>lombok</artifactId>
		        <optional>true</optional>
		    </dependency>
	    <!-- Thymeleaf 依賴 -->
	    <dependency>
	        <groupId>org.springframework.boot</groupId>
	        <artifactId>spring-boot-starter-thymeleaf</artifactId>
	    </dependency>
	    <!-- Bootstrap 和 jQuery -->
	    <dependency>
	        <groupId>org.webjars</groupId>
	        <artifactId>bootstrap</artifactId>
	        <version>${bootstrap.version}</version>
	    </dependency>
	    <dependency>
	        <groupId>org.webjars</groupId>
	        <artifactId>jquery</artifactId>
	        <version>${jquery.version}</version>
	    </dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

配置SM4加密算法

在application.yml文件中,我們可以配置SM4加密的相關(guān)參數(shù)。

sm4:
  key: "37507d4cb936fdfb5dbb12a9a3983733" # SM4加密的密鑰
  iv: "a7ae2a65d41fa7f98aec3579b8ec5a3c"   # SM4的初始化向量
  algorithm: "SM4"      # 加密算法
  mode: "CBC"           # 工作模式
  padding: "PKCS5Padding" # 填充模式

spring:
  datasource:
    url: ENC(sXjrlmJi+pBmt5ViI6uLAJ+teKmEfIPoJ5INkHEO2NtWcQ53zdATRyC4X+jru45oiaPjE74e+uLPgY/jHFy21iCVRnNpOFh5fHxn6NgF+04=)
    username: ENC(vB/qydt/80xm7Dxu48i/mA==)
    password: ENC(vB/qydt/80xm7Dxu48i/mA==)

實(shí)現(xiàn)SM4加密和解密工具類

package com.icoderoad.SM4Encryption.util;

import java.security.Security;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.springframework.util.Base64Utils;

public class SM4Util {
	
	static {
        Security.addProvider(new BouncyCastleProvider());
    }

    private static final String ALGORITHM_NAME = "SM4";
    private static final String ALGORITHM_NAME_CBC_PADDING = "SM4/CBC/PKCS5Padding";

    /**
     * SM4加密
     * @param plainText 明文
     * @param key 密鑰
     * @param iv 向量
     * @return 加密后的密文
     */
    public static String encrypt(String plainText, String key, String iv) throws Exception {
        Cipher cipher = Cipher.getInstance(ALGORITHM_NAME_CBC_PADDING);
        SecretKeySpec keySpec = createKey(key);
        IvParameterSpec ivSpec = createIv(iv);
        cipher.init(Cipher.ENCRYPT_MODE, keySpec, ivSpec);
        byte[] encrypted = cipher.doFinal(plainText.getBytes());
        return Base64.getEncoder().encodeToString(encrypted);
    }

    /**
     * SM4解密
     * @param cipherText 密文
     * @param key 密鑰
     * @param iv 向量
     * @return 解密后的明文
     */
    public static String decrypt(String cipherText, String key, String iv) throws Exception {
        Cipher cipher = Cipher.getInstance(ALGORITHM_NAME_CBC_PADDING);
        if (cipherText.startsWith("ENC(") && cipherText.endsWith(")")) {
        	cipherText = cipherText.substring(4, cipherText.length() - 1);
        }
       
        SecretKeySpec keySpec = createKey(key);
        IvParameterSpec ivSpec = createIv(iv);
        cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);
        byte[] decrypted = cipher.doFinal(Base64.getDecoder().decode(cipherText));
        return new String(decrypted);
    }
    
    private static SecretKeySpec createKey(String key) {
        byte[] keyBytes = key.getBytes();
        byte[] finalKey = new byte[16];
        System.arraycopy(keyBytes, 0, finalKey, 0, Math.min(keyBytes.length, 16));
        return new SecretKeySpec(finalKey, "SM4");
    }

    private static IvParameterSpec createIv(String iv) {
        byte[] ivBytes = iv.getBytes();
        byte[] finalIv = new byte[16];
        System.arraycopy(ivBytes, 0, finalIv, 0, Math.min(ivBytes.length, 16));
        return new IvParameterSpec(finalIv);
    }
}

在項(xiàng)目中應(yīng)用SM4加密

生成加密后的值

為了生成加密后的url、username和password,可以使用以下測(cè)試代碼來(lái)生成這些值。

package com.icoderoad.SM4Encryption;

import com.icoderoad.SM4Encryption.util.SM4Util;

public class SM4EncryptionTest {

	 public static void main(String[] args) throws Exception {
	        String url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=false";
	        String username = "root";
	        String password = "root";

	        String key = "37507d4cb936fdfb5dbb12a9a3983733";
	        String iv = "a7ae2a65d41fa7f98aec3579b8ec5a3c";

	        System.out.println("加密后的URL: " + SM4Util.encrypt(url, key, iv));
	        System.out.println("加密后的用戶名: " + SM4Util.encrypt(username, key, iv));
	        System.out.println("加密后的密碼: " + SM4Util.encrypt(password, key, iv));
	    }
	 
}

運(yùn)行上述代碼后,得到加密后的url、username和password,將這些值更新到application.yml中。

我們可以在Spring Boot項(xiàng)目中使用@Value注解將加密后的數(shù)據(jù)庫(kù)密碼解密并應(yīng)用于數(shù)據(jù)源配置。

package com.icoderoad.SM4Encryption.conf;

import javax.sql.DataSource;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import com.icoderoad.SM4Encryption.util.SM4Util;
import com.zaxxer.hikari.HikariDataSource;

@Configuration
public class DataSourceConfig {

    @Value("${spring.datasource.url}")
    private String encryptedUrl;

    @Value("${spring.datasource.username}")
    private String encryptedUsername;

    @Value("${spring.datasource.password}")
    private String encryptedPassword;

    @Value("${sm4.key}")
    private String key;

    @Value("${sm4.iv}")
    private String iv;

    @Bean
    public DataSource dataSource() throws Exception {
        HikariDataSource dataSource = new HikariDataSource();
        dataSource.setJdbcUrl(SM4Util.decrypt(encryptedUrl, key, iv));
        dataSource.setUsername(SM4Util.decrypt(encryptedUsername, key, iv));
        dataSource.setPassword(SM4Util.decrypt(encryptedPassword, key, iv));
        return dataSource;
    }
}

User實(shí)體類

package com.icoderoad.SM4Encryption.entity;

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;

@Data
@TableName("user")
public class User {
    @TableId
    private Long id;
    private String name;
    private String idNumber;
    private String email;
    private String phone;
    private String address;
    
    @TableField(exist = false)
    private String sensitiveIdNumber;

    public String getSensitiveIdNumber() {
        return idNumber.replaceAll("(\\d{6})\\d{8}(\\d{4})", "$1****$2");
    }
}

UserMapper接口

package com.icoderoad.SM4Encryption.mapper;

import org.apache.ibatis.annotations.Mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.icoderoad.SM4Encryption.entity.User;

@Mapper
public interface UserMapper extends BaseMapper<User> {
}

UserService接口

package com.icoderoad.SM4Encryption.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.icoderoad.SM4Encryption.entity.User;

public interface UserService extends IService<User> {
}

UserServiceImpl類

package com.icoderoad.SM4Encryption.service.impl;

import org.springframework.stereotype.Service;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.icoderoad.SM4Encryption.entity.User;
import com.icoderoad.SM4Encryption.mapper.UserMapper;
import com.icoderoad.SM4Encryption.service.UserService;

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
}

我們需要?jiǎng)?chuàng)建一個(gè)控制器類來(lái)處理前端視圖頁(yè)面的請(qǐng)求,并將數(shù)據(jù)傳遞給視圖頁(yè)面進(jìn)行展示。

UserController類

package com.icoderoad.SM4Encryption.controller;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;

import com.icoderoad.SM4Encryption.entity.User;
import com.icoderoad.SM4Encryption.service.UserService;

@Controller
public class UserController {

    @Autowired
    private UserService userService;

    @GetMapping("/")
    public String listUsers(Model model) {
        List<User> users = userService.list();
        model.addAttribute("users", users);
        return "index";
    }
}

前端展示頁(yè)面與數(shù)據(jù)脫敏

前端頁(yè)面使用Thymeleaf模板引擎,并結(jié)合Bootstrap進(jìn)行數(shù)據(jù)展示和脫敏處理。

在 src/main/resources/templates/index.html 中創(chuàng)建一個(gè)簡(jiǎn)單的前端頁(yè)面:

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>用戶數(shù)據(jù)</title>
    <link href="/webjars/bootstrap/css/bootstrap.min.css" rel="stylesheet">
    <script src="/webjars/jquery/jquery.min.js"></script>
    <script src="/webjars/bootstrap/js/bootstrap.bundle.min.js"></script>
     <style>
     	.container{
     		text-align: center;
     	}
         thead th {
             background-color: #007bff;
             color: white;
         }
         tbody tr:nth-child(even) {
             background-color: #f8f9fa;
         }
         .table {
         	margin: 20px auto;
         	width: 80%;
         }
         tr{
         	height: 30px;
         }
     </style>
</head>
<body>
    <div class="container  mt-5">
        <h2>用戶數(shù)據(jù)</h2>
        <table class="table table-bordered">
            <thead>
                <tr>
                    <th>ID</th>
                    <th>姓名</th>
                    <th>身份證號(hào)</th>
                    <th>郵箱</th>
                    <th>電話</th>
                    <th>地址</th>
                </tr>
            </thead>
            <tbody>
                <tr th:each="user : ${users}">
                    <td th:text="${user.id}"></td>
                    <td th:text="${user.name}"></td>
                    <td th:text="${user.sensitiveIdNumber}"></td>
                    <td th:text="${user.email}"></td>
                    <td th:text="${user.phone}"></td>
                    <td th:text="${user.address}"></td>
                </tr>
            </tbody>
        </table>
    </div>
</body>
</html>

總結(jié)

本文通過(guò)實(shí)際案例,詳細(xì)介紹了如何在Spring Boot項(xiàng)目中使用SM4國(guó)密加密算法對(duì)數(shù)據(jù)庫(kù)連接信息和用戶數(shù)據(jù)進(jìn)行加密與脫敏處理。我們展示了如何配置加密和解密操作,結(jié)合MyBatis-Plus實(shí)現(xiàn)數(shù)據(jù)庫(kù)操作,并通過(guò)Thymeleaf和Bootstrap構(gòu)建前端頁(yè)面進(jìn)行安全展示。

通過(guò)本文,大家可以掌握如何在Spring Boot中集成加密算法,并將其應(yīng)用于實(shí)際項(xiàng)目中,提升數(shù)據(jù)安全性。希望本文為大家在處理敏感信息時(shí)提供了實(shí)用的指導(dǎo),幫助構(gòu)建更安全的企業(yè)級(jí)應(yīng)用程序。

責(zé)任編輯:武曉燕 來(lái)源: 路條編程
相關(guān)推薦

2025-03-28 04:10:00

2023-06-26 00:30:51

2024-08-26 09:15:55

RedissonMyBatisSpring

2024-12-31 08:00:00

SpringBoot開(kāi)發(fā)加密

2025-04-17 03:33:00

SpringSQL動(dòng)態(tài)查詢

2025-02-20 08:21:36

2024-09-02 08:12:32

Spring策略MyBatis

2024-08-29 08:23:22

EasyOCRSpring文字識(shí)別

2025-01-26 00:00:35

2020-10-26 19:20:08

Linux國(guó)密算法加密

2023-10-16 19:05:20

2024-10-14 13:26:42

2015-02-26 09:21:42

Jenkins數(shù)據(jù)庫(kù)加密

2023-08-01 07:24:05

2009-08-13 18:12:11

C#數(shù)據(jù)加密

2015-06-23 11:11:55

2025-06-04 02:15:00

數(shù)據(jù)庫(kù)連接方式JDBC

2013-10-17 13:20:34

2017-12-27 15:16:35

Spring BootFlyway數(shù)據(jù)庫(kù)

2009-08-04 11:08:33

ASP.NET數(shù)據(jù)加密
點(diǎn)贊
收藏

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

国产黄色免费观看| 一区二区xxx| 少妇高潮一区二区三区69| 极品少妇一区二区三区| 日韩av在线看| 动漫av免费观看| 精品自拍一区| 成人激情小说网站| 国产成人精品优优av| 糖心vlog免费在线观看| 久久久久观看| 欧美色倩网站大全免费| 日本福利视频网站| 黄色免费在线播放| 国产福利91精品| 日本成人免费在线| 久久r这里只有精品| 亚洲国产合集| 日韩一区二区精品| 久久精品网站视频| 日本aa在线| 9色在线观看| 国产91亚洲精品久久久| 亚洲麻豆国产自偷在线| 麻豆一区区三区四区产品精品蜜桃| 亚洲中文字幕无码爆乳av| 亚洲国产精品成人| 怡红院精品视频| 丰满少妇xbxb毛片日本| 免费一区二区三区四区| 天天综合天天做天天综合| 亚洲综合网中心| 亚洲 精品 综合 精品 自拍| 国产一区二区视频在线| 国产精品扒开腿做| 久久夜靖品2区| 最新欧美人z0oozo0| 亚洲人成自拍网站| 亚洲一级av无码毛片精品| 95精品视频| 欧美自拍偷拍午夜视频| 精品中文字幕av| 亚洲小说区图片| 中文字幕日韩精品一区 | 久久久久久久国产视频| 日韩精品首页| 国产午夜精品全部视频在线播放| 男男一级淫片免费播放| 一区中文字幕电影| 91精品国产综合久久久久久久久久| 日韩精品免费播放| 大胆人体一区二区| 欧美日韩国产激情| 男女猛烈激情xx00免费视频| av文字幕在线观看| 成人欧美一区二区三区| 亚洲精品一区二区三| 久久这里精品| 久久久久久亚洲综合| 精品国产乱码久久久久| 色噜噜一区二区三区| 成人精品鲁一区一区二区| 成人黄视频免费| 亚洲精品18p| 成人免费av网站| 国产亚洲自拍偷拍| 天天干免费视频| 99精品视频中文字幕| 九色91国产| 欧美一区二区三区少妇| 国产三级精品视频| 亚洲免费久久| 麻豆视频在线免费观看| 亚洲伦在线观看| 男人添女荫道口喷水视频| 久久香蕉一区| 欧美日韩在线视频首页| 91av俱乐部| 黄色成人在线观看网站| 欧美麻豆精品久久久久久| 两性午夜免费视频| 国产精品久久久久av蜜臀| 亚洲黄色av网站| 波多野在线播放| 99精品美女| 久久久久久久一区二区| 国产精品视频一区在线观看| 日韩av在线播放中文字幕| 国产精品中文字幕在线观看| 99国产精品久久久久久久成人 | 国产精品久久久久久久久久东京 | 免费的av网站| 欧美日韩激情| 久精品免费视频| 中文字幕亚洲高清| 久久国产精品色婷婷| 波多野结衣成人在线| 日本午夜在线| 亚洲人一二三区| 18岁网站在线观看| 99综合久久| 日韩国产精品一区| 少妇高潮一区二区三区喷水| 影音先锋中文字幕一区| 国产精品福利片| 成人免费一级视频| 中文av字幕一区| 日本男女交配视频| 福利精品一区| 亚洲福利在线播放| 蜜桃av.com| 国产免费成人| 99九九视频| caoporn国产精品免费视频| 一二三区精品视频| 欧美成人黄色网址| 熟妇女人妻丰满少妇中文字幕| 久久久人成影片一区二区三区在哪下载| 欧美日韩国产高清一区| 中文文字幕文字幕高清| 久久精品亚洲人成影院| 日本亚洲欧美三级| 午夜精品久久久久久久99| 国产欧美一区二区精品性色超碰| 国产一区二区片| 天堂综合在线播放| 亚洲免费伊人电影在线观看av| 成人性生活毛片| 日本在线播放一区二区三区| 国产美女在线精品免费观看| 免费观看成人高潮| 欧美在线看片a免费观看| 一区二区三区四区影院| 91欧美国产| 国产成人综合久久| 日本福利在线观看| 亚洲成人激情av| 性生交大片免费看l| 99久久www免费| 国产精品久久久久久亚洲影视 | 亚洲少妇在线| 超碰97在线资源| 成人在线视频亚洲| 欧美夫妻性生活| 99久久久无码国产精品不卡| 日韩国产精品大片| 日本婷婷久久久久久久久一区二区 | 日韩大陆毛片av| 男人的天堂一区| 成人免费视频caoporn| 青青青在线观看视频| 午夜日韩影院| 久久久久亚洲精品| 欧美视频一二区| 亚洲国产欧美一区二区三区丁香婷| 国产人妻精品久久久久野外| av在线电影观看| 日韩精品诱惑一区?区三区| 4438全国亚洲精品在线观看视频| 理论片中文字幕| 亚洲第一精品在线| 欧美一级片黄色| 国产情侣久久| 欧美日韩一区综合| 777a∨成人精品桃花网| 一本一道久久久a久久久精品91 | 久久激情五月丁香伊人| 一区二区精品视频在线观看| 国产精品九色蝌蚪自拍| www.日本一区| 91tv官网精品成人亚洲| 999国内精品视频在线| 51xtv成人影院| 欧美一二三四区在线| 久久久国产成人| 不卡一卡二卡三乱码免费网站| 美女扒开大腿让男人桶| 亚洲精品一区在线| 91精品国产沙发| 狠狠v欧美ⅴ日韩v亚洲v大胸| 欧美亚洲国产一区在线观看网站 | 97久久精品国产| 神马精品久久| 欧美无乱码久久久免费午夜一区| 五月婷婷综合激情网| 国产成人综合自拍| 波多野结衣家庭教师在线播放| 久草成人在线| 亚洲同性gay激情无套| 8x海外华人永久免费日韩内陆视频| 手机看片一区二区| 色久综合一二码| 最新黄色av网址| 粉嫩嫩av羞羞动漫久久久| 欧美 日韩 国产在线观看| 精品国内自产拍在线观看视频| 成人久久久久爱| 1区2区3区在线| 亚洲天堂免费在线| av av片在线看| 精品久久久久久久久久久| 色综合99久久久无码国产精品| 国产一区二区在线电影| 国产成人精品视频免费看| 第一sis亚洲原创| 99视频免费观看| 激情亚洲影院在线观看| 欧美www在线| 国产一级网站视频在线| 日韩丝袜美女视频| 福利网址在线观看| 亚洲精品亚洲人成人网在线播放| 欧美 日本 国产| 激情五月婷婷综合| 十八禁视频网站在线观看| 中文字幕免费一区二区| 日本一区视频在线| 豆花视频一区二区| 成人激情视频在线播放| 免费观看亚洲| 久久久久国产精品www| 春暖花开成人亚洲区| 精品国产99国产精品| 在线免费观看视频网站| 美美哒免费高清在线观看视频一区二区| 日韩电影中文字幕av| 中文在线a天堂| 亚洲 欧美综合在线网络| 午夜精品久久久久99蜜桃最新版| 久久亚洲一级片| 欧洲熟妇的性久久久久久| 久久99精品久久久久久久久久久久| 欧美日韩在线视频一区二区三区| 欧美在线三区| 亚洲视频欧美在线| 国产一区二区电影在线观看| 国产专区一区二区三区| aiai久久| 91视频99| 精品国产亚洲一区二区三区大结局| 国产激情视频一区| 免费观看一级欧美片| 97精品视频在线播放| 污视频网站在线免费| 久久亚洲精品网站| av在线电影免费观看| 亚洲视频在线观看免费| 欧美大片aaa| 亚洲男人av在线| 亚洲人妻一区二区| 亚洲国产91精品在线观看| 好吊视频一区二区三区| 精品少妇一区二区三区视频免付费 | 日韩一卡二卡在线| 精品久久久久99| 亚洲av无码一区二区乱子伦| 日韩欧美电影一二三| 精品欧美在线观看| 日韩一区二区免费视频| 精品人妻午夜一区二区三区四区 | 国产主播中文字幕| 人人爽香蕉精品| 一道本视频在线观看| 久久99国产精品成人| 久久6免费视频| 国产福利91精品一区二区三区| 中文字幕一区二区三区人妻在线视频 | 999久久精品| 国产女人水真多18毛片18精品| 国产精品22p| 久久青青草综合| 国产精品亚洲二区| 亚洲午夜精品一区二区三区| 亚洲aⅴ在线观看| 久久99九九99精品| 在线免费看v片| 丁香一区二区三区| 亚洲精品乱码久久久久久久| 久久久久久久久岛国免费| 国产在线观看h| 亚洲欧洲日韩综合一区二区| 麻豆视频在线观看| 精品免费在线视频| 波多野结衣一本一道| 欧美猛男gaygay网站| 超碰免费在线97| 日韩精品在线私人| 尤物视频在线免费观看| 久久成人精品电影| 久草免费在线视频| 国产精品欧美一区二区| 视频一区视频二区欧美| 久久久99爱| 色综合蜜月久久综合网| 国产精品www在线观看| 日本成人在线电影网| 午夜影院免费版| 91麻豆视频网站| 天天操夜夜操av| 精品国产成人av| 国产又粗又猛又爽又黄的| 精品国产污网站| www.在线视频.com| 久久久久久久激情视频| 成人全视频免费观看在线看| 91传媒视频在线观看| 国产91久久精品一区二区| 7777在线视频| 久久精选视频| 久久久精品人妻一区二区三区| 久久精品亚洲精品国产欧美| 四虎免费在线视频| 欧美色区777第一页| 天堂av在线7| 欧美床上激情在线观看| 欧美不卡高清一区二区三区| 国产99在线播放| 国产精品久久久久无码av| 欧美日韩国产精品激情在线播放| 国产揄拍国内精品对白| 丰满少妇高潮一区二区| 亚洲成人自拍网| 国产口爆吞精一区二区| 亚洲视频日韩精品| 国模精品视频| 7777精品久久久大香线蕉小说| 欧美日韩在线二区| 日韩中文字幕在线视频观看| 国产不卡视频一区| 夫妻性生活毛片| 欧美综合一区二区| 天天做夜夜爱爱爱| 精品日韩一区| 男女裸体影院高潮| 精品午夜久久福利影院| 午夜精品爽啪视频| 性少妇videosexfreexxx片| 色777狠狠综合秋免鲁丝| 欧美成人精品三级网站| 国产自产精品| 伊人成人在线| 在线播放av网址| 亚洲精品国产精品乱码不99 | av免费在线观看网址| 国产日韩亚洲欧美| 日韩国产欧美一区二区| 日本熟妇人妻中出| 久久精品水蜜桃av综合天堂| 天天操夜夜操视频| 亚洲乱码一区av黑人高潮| 少妇在线看www| 久久久婷婷一区二区三区不卡| 99在线精品免费视频九九视| 精品影片一区二区入口| 亚洲电影一区二区| 熟妇高潮一区二区高潮| 性欧美办公室18xxxxhd| 欧美三级午夜理伦三级小说| 欧美,日韩,国产在线| 91丨九色丨蝌蚪丨老版| 国产www在线| 亚洲视频axxx| 国产精品一区二区免费福利视频| 一本一道久久a久久精品综合| 精品一区二区三区欧美| 男人的天堂久久久| 欧美r级电影在线观看| 久久青草伊人| 日本黑人久久| 另类小说一区二区三区| 国产精品嫩草影院俄罗斯| 日韩欧美国产一区二区三区 | 成人欧美一区二区三区1314| 国产浮力第一页| 久久男人av资源网站| 亚洲人成网77777色在线播放 | 三级中文字幕在线观看| 欧美一区二区视频在线| 久久99精品久久久久久动态图| 国产大学生自拍| 亚洲精品久久久久久久久久久久久| 成人线上视频| 亚洲精品欧洲精品| 丁香婷婷综合五月| 国产一区二区视频网站| 日韩在线激情视频| 国产精品网站在线看| 久久精品一区二| 99国产精品| 国产免费亚洲高清| 色综合久久中文| 鲁一鲁一鲁一鲁一av| 一区二区三区色| 深夜视频在线免费| 国产在线视频91| 日韩网站在线| 91动漫免费网站| 亚洲成人久久一区| 粉嫩91精品久久久久久久99蜜桃| 日韩久久久久久久久久久久|