激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java實現獲取小程序帶參二維碼并保存到本地

Java實現獲取小程序帶參二維碼并保存到本地

2022-02-20 12:06Moshow鄭鍇 Java教程

這篇文章主要介紹了Java實現獲取小程序帶參二維碼并保存到本地,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

 

獲取小程序帶參二維碼并保存到本地

 

業務場景

下載并保存帶參數的小程序二維碼,用戶直接掃描帶參二維碼就進入小程序,自動根據參數完成部分業務。這個時候就需要用到微信小程序提供的二維碼接口 wxacode.getUnlimited ,官方文檔地址

網上介紹的很多方法有些過時了,有些不科學,調用起來不方便,所以自己也總結了一份出來。雖然很久之前直接用jfinal+jfinal-wx寫的,幾句代碼就搞定了,但是最近需要遷移項目到SpringBoot2,所以就踩了個坑順便總結一下,確實找了大半天。

 

POSTMAN調試

如果一個借口postman都調用不通,那就更別說用java代碼去寫了,調用接口第一步就是熟悉接口請求方式 method、請求格式 Content-Type和接口參數 Body/Param以及返回的內容,POSTMAN調用參數過程

url https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token={{access_token}}
json raw { "scene":"EGAG-SAL**-******"}

Java實現獲取小程序帶參二維碼并保存到本地

 

WxUtil封裝:下載帶參數的小程序二維碼

import cn.hutool.http.HttpUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
/**
 * 微信小程序輔助工具類 https://developers.weixin.qq.com/miniprogram/dev/api-backend/
 * @Author zhengkai.blog.csdn.net
 * */
@Slf4j
public class WxUtil {
    public static String GET_MINICODE_URL="https://api.weixin.qq.com/wxa/getwxacodeunlimit";
    public static String APPID="你的APPID";
    public static String APPSECRET="你的APPSECRET";
    public static String getAccessTokenAsUrl(){
        String tokenStr=HttpUtil.get("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="+APPID+"&secret="+APPSECRET+"");
        log.info(tokenStr);
        JSONObject jsonObject = JSONObject.parseObject(tokenStr);
        return "?access_token="+jsonObject.getString("access_token");
    }
    /**
     * 下載帶參數的小程序二維碼
     * https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/qr-code/wxacode.getUnlimited.html
     * by zhengkai.blog.csdn.net
     * @param pathStr 保存圖片的的path
     * @param certNumber 帶過去小程序的參數,一般為你的業務參數,建議是id或者number
     * */
    public static String downloadMiniCode(String pathStr , String certNumber){
        Map<String,Object> paramMap = new HashMap<>();
        paramMap.put("scene",certNumber);
        paramMap.put("is_hyaline",true);
        String imgFilePath = pathStr+"/certificate/"+certNumber+".png";// 新生成的圖片
        try
        {
            URL url = new URL(GET_MINICODE_URL+getAccessTokenAsUrl());
            HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
            httpURLConnection.setRequestMethod("POST");// 提交模式
            httpURLConnection.setConnectTimeout(10000);//連接超時 單位毫秒
            httpURLConnection.setReadTimeout(10000);//讀取超時 單位毫秒
            // 發送POST請求必須設置如下兩行
            httpURLConnection.setDoOutput(true);
            httpURLConnection.setDoInput(true);
            // 獲取URLConnection對象對應的輸出流
            PrintWriter printWriter = new PrintWriter(httpURLConnection.getOutputStream());
            printWriter.write(JSON.toJSONString(paramMap));
            // flush輸出流的緩沖
            printWriter.flush();
            //開始獲取數據
            BufferedInputStream bis = new BufferedInputStream(httpURLConnection.getInputStream());
            OutputStream os = new FileOutputStream(new File(imgFilePath));
            int len;
            //設置緩沖寫入
            byte[] arr = new byte[2048];
            while ((len = bis.read(arr)) != -1)
            {
                os.write(arr, 0, len);
                os.flush();
            }
            os.close();
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
        return imgFilePath;
    }
}

 

Controller調用

傳入保存的 path地址 和 scene參數

WxUtil.downloadMiniCode(storageService.getPathString(),certCompany.getCertNumber());

 

下載驗證

之前試過很多方法就是保存后的png圖片無法使用,可能是保存的姿勢、方法不對。用這個方法親測可行。

Java實現獲取小程序帶參二維碼并保存到本地

 

微信小程序碼的生成及保存到阿里云oss

官方文檔:獲取二維碼

這里使用其中的接口B:適用于需要的碼數量極多的業務場景(無限次數)

Java實現獲取小程序帶參二維碼并保存到本地

參數按照接口說明來傳,請求成功的話接口會返回輸入流,這里將輸入流上傳至阿里云OSS

以下是部分JAVA代碼(有問題可以留言):

public class UploadTest {
    
    @Test
    public void upload(){        
        try {
            URL url = new URL("https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=你的access_token");
            HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
            httpURLConnection.setRequestMethod("POST");// 提交模式
            // conn.setConnectTimeout(10000);//連接超時 單位毫秒
            // conn.setReadTimeout(2000);//讀取超時 單位毫秒
            // 發送POST請求必須設置如下兩行
            httpURLConnection.setDoOutput(true);
            httpURLConnection.setDoInput(true);
            // 獲取URLConnection對象對應的輸出流
            PrintWriter printWriter = new PrintWriter(httpURLConnection.getOutputStream());
            // 發送請求參數
            JSONObject paramJson = new JSONObject();
            paramJson.put("scene", "p=1234567890");
            paramJson.put("page", "pages/index/index");
            paramJson.put("width", 430);
            paramJson.put("auto_color", true);
            /**
             * line_color生效
             * paramJson.put("auto_color", false);
             * JSONObject lineColor = new JSONObject();
             * lineColor.put("r", 0);
             * lineColor.put("g", 0);
             * lineColor.put("b", 0);
             * paramJson.put("line_color", lineColor);
             * */
            printWriter.write(paramJson.toString());
            // flush輸出流的緩沖
            printWriter.flush();
            //開始獲取數據
            //注意 這里上傳時文件大小用 HttpResponse.getEntity().getContentLength() 
            //用  is.available()生成圖片會不全,具體參考InputStream.available
 AliyunOSSClientUtil.uploadAcode2OSS(httpURLConnection.getInputStream(),"app/demo.png", httpURLConnection.getContentLengthLong()) ;
         } catch (Exception e) {
            e.printStackTrace();
         }        
    }    
}

 

阿里云oss工具類

import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.net.URL;
import java.util.Date;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.multipart.MultipartFile;
import com.aliyun.oss.OSSClient;
import com.aliyun.oss.model.Bucket;
import com.aliyun.oss.model.OSSObject;
import com.aliyun.oss.model.ObjectMetadata;
import com.aliyun.oss.model.PutObjectResult;
/**
 * 
 * @ClassName: AliyunOSSClientUtil
 * @Description: 阿里云OSS上傳文件模塊
 * @author 張日天
 * @date 2018年7月02日 下午23:01:46
 * 
 */
public class AliyunOSSClientUtil {
    private static Logger logger = LoggerFactory
            .getLogger(AliyunOSSClientUtil.class);
    // 阿里云API的內或外網域名
    private static String ENDPOINT;
    // 阿里云API的密鑰Access Key ID
    private static String ACCESS_KEY_ID;
    // 阿里云API的密鑰Access Key Secret
    private static String ACCESS_KEY_SECRET;
    // 阿里云API的bucket名稱
    private static String BACKET_NAME;
    //
    private static String FORMATS = OSSClientConstants.FORMATS;
    static {
        ENDPOINT = SysPropUtils.getPropValue("aliyun.endPoint",
                "properties/aliyun.properties");
        ACCESS_KEY_ID = SysPropUtils.getPropValue("aliyun.accessKeyId",
                "properties/aliyun.properties");
        ACCESS_KEY_SECRET = SysPropUtils.getPropValue("aliyun.accessKeySecret",
                "properties/aliyun.properties");
        BACKET_NAME = SysPropUtils.getPropValue("aliyun.bucketName",
                "properties/aliyun.properties");
    }
    
    /**
     * 上傳文件 至 OSS
     * 
     * @param ossClient
     * @param is
     * @param bucketName
     * @param remotePath
     * @return
     */
    public static String[] uploadObject2OSS(InputStream is, String remotePath) {
        String resultStr = null;
        String[] fo = new String[] { "", "" };
        try {
            long start = new Date().getTime();
            OSSClient ossClient = getOSSClient();
            // 文件大小
            // Long fileSize = file.length();
            // 創建上傳Object的Metadata
            ObjectMetadata metadata = new ObjectMetadata();
            // 上傳的文件的長度
            //metadata.setContentLength(is.available());
            //System.out.println(is.available());
            // 指定該Object被下載時的網頁的緩存行為
            metadata.setCacheControl("no-cache");
            // 指定該Object下設置Header
            metadata.setHeader("Pragma", "no-cache");
            // 指定該Object被下載時的內容編碼格式
            metadata.setContentEncoding("utf-8");
            // 文件的MIME,定義文件的類型及網頁編碼,決定瀏覽器將以什么形式、什么編碼讀取文件。如果用戶沒有指定則根據Key或文件名的擴展名生成,
            // 如果沒有擴展名則填默認值application/octet-stream
            // metadata.setContentType(getContentType(fileName));
            // 指定該Object被下載時的名稱(指示MINME用戶代理如何顯示附加的文件,打開或下載,及文件名稱)
            // metadata.setContentDisposition("filename/filesize=" + fileName +
            // "/" + fileSize + "Byte.");
            // 上傳文件 (上傳文件流的形式)
            PutObjectResult putResult = ossClient.putObject(BACKET_NAME,
                    remotePath, is, metadata);
            // 解析結果
            resultStr = putResult.getETag();
            fo[1] = remotePath;
            fo[0] = resultStr;
            // 文件名
            logger.info("文件上傳成功,上傳耗時:"+(new Date().getTime()-start)+"ms,路徑為:" + remotePath);
            ossClient.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
            logger.error("上傳阿里云OSS服務器異常." + e.getMessage(), e);
        }
        return fo;
    }
    
   /**
    * 上傳微信小程序碼 至 OSS
    * @param is
    * @param remotePath
    * @param length
    * @return
    */
    public static String[] uploadAcode2OSS(InputStream is, String remotePath,long length) {
        String resultStr = null;
        String[] fo = new String[] { "", "" };
        try {
            long start = new Date().getTime();
            OSSClient ossClient = getOSSClient();
            // 文件大小
            // Long fileSize = file.length();
            // 創建上傳Object的Metadata
            ObjectMetadata metadata = new ObjectMetadata();
            // 上傳的文件的長度
            metadata.setContentLength(length);
            //System.out.println(is.available());
            // 指定該Object被下載時的網頁的緩存行為
            metadata.setCacheControl("no-cache");
            // 指定該Object下設置Header
            metadata.setHeader("Pragma", "no-cache");
            // 指定該Object被下載時的內容編碼格式
            metadata.setContentEncoding("utf-8");
            // 文件的MIME,定義文件的類型及網頁編碼,決定瀏覽器將以什么形式、什么編碼讀取文件。如果用戶沒有指定則根據Key或文件名的擴展名生成,
            // 如果沒有擴展名則填默認值application/octet-stream
            // metadata.setContentType(getContentType(fileName));
            // 指定該Object被下載時的名稱(指示MINME用戶代理如何顯示附加的文件,打開或下載,及文件名稱)
            // metadata.setContentDisposition("filename/filesize=" + fileName +
            // "/" + fileSize + "Byte.");
            // 上傳文件 (上傳文件流的形式)
            PutObjectResult putResult = ossClient.putObject(BACKET_NAME,
                    remotePath, is, metadata);
            // 解析結果
            resultStr = putResult.getETag();
            fo[1] = remotePath;
            fo[0] = resultStr;
            // 文件名
            logger.info("文件上傳成功,上傳耗時:"+(new Date().getTime()-start)+"ms,路徑為:" + remotePath);
            ossClient.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
            logger.error("上傳阿里云OSS服務器異常." + e.getMessage(), e);
        }
        return fo;
    }
    /**
     * 上傳文件 至 OSS
     * 
     * @param ossClient
     * @param is
     * @param bucketName
     * @param remotePath
     * @return
     */
    public static String[] uploadObject2OSS(OSSClient ossClient,
            InputStream is, String bucketName, String remotePath) {
        String resultStr = null;
        String[] fo = new String[] { "", "" };
        try {
            // 文件大小
            // Long fileSize = file.length();
            // 創建上傳Object的Metadata
            ObjectMetadata metadata = new ObjectMetadata();
            // 上傳的文件的長度
            metadata.setContentLength(is.available());
            // 指定該Object被下載時的網頁的緩存行為
            metadata.setCacheControl("no-cache");
            // 指定該Object下設置Header
            metadata.setHeader("Pragma", "no-cache");
            // 指定該Object被下載時的內容編碼格式
            metadata.setContentEncoding("utf-8");
            // 文件的MIME,定義文件的類型及網頁編碼,決定瀏覽器將以什么形式、什么編碼讀取文件。如果用戶沒有指定則根據Key或文件名的擴展名生成,
            // 如果沒有擴展名則填默認值application/octet-stream
            // metadata.setContentType("image/jpeg");
            // 指定該Object被下載時的名稱(指示MINME用戶代理如何顯示附加的文件,打開或下載,及文件名稱)
            // metadata.setContentDisposition("filename/filesize=" + fileName +
            // "/" + fileSize + "Byte.");
            // 上傳文件 (上傳文件流的形式)
            PutObjectResult putResult = ossClient.putObject(bucketName,
                    remotePath, is, metadata);
            // 解析結果
            resultStr = putResult.getETag();
            fo[1] = remotePath;
            fo[0] = resultStr;
            // 文件名
            logger.info("文件上傳成功,路徑為:" + remotePath);
            ossClient.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
            logger.error("上傳阿里云OSS服務器異常." + e.getMessage(), e);
        }
        return fo;
    }
    /**
     * 上傳圖片至OSS 文件流
     * 
     * @param ossClient
     *            oss連接
     * @param file
     *            上傳文件(文件全路徑如:D:imagecake.jpg)
     * @param bucketName
     *            存儲空間
     * @param folder
     *            模擬文件夾名 如"qj_nanjing/"
     * @return String 返回的唯一MD5數字簽名
     */
    public static String[] uploadObject2OSS(OSSClient ossClient, File file,
            String bucketName, String folder) {
        String resultStr = null;
        String[] fo = new String[] { "", "" };
        try {
            // 以輸入流的形式上傳文件
            InputStream is = new FileInputStream(file);
            // 文件名
            String timefile = FORMATS;
            String fileName = file.getName();
            fileName = timefile + fileName.substring(fileName.lastIndexOf("."));
            logger.info("上傳到路徑" + folder + fileName);
            // 文件大小
            Long fileSize = file.length();
            // 創建上傳Object的Metadata
            ObjectMetadata metadata = new ObjectMetadata();
            // 上傳的文件的長度
            metadata.setContentLength(is.available());
            // 指定該Object被下載時的網頁的緩存行為
            metadata.setCacheControl("no-cache");
            // 指定該Object下設置Header
            metadata.setHeader("Pragma", "no-cache");
            // 指定該Object被下載時的內容編碼格式
            metadata.setContentEncoding("utf-8");
            // 文件的MIME,定義文件的類型及網頁編碼,決定瀏覽器將以什么形式、什么編碼讀取文件。如果用戶沒有指定則根據Key或文件名的擴展名生成,
            // 如果沒有擴展名則填默認值application/octet-stream
            metadata.setContentType(getContentType(fileName));
            // 指定該Object被下載時的名稱(指示MINME用戶代理如何顯示附加的文件,打開或下載,及文件名稱)
            metadata.setContentDisposition("filename/filesize=" + fileName
                    + "/" + fileSize + "Byte.");
            // 上傳文件 (上傳文件流的形式)
            PutObjectResult putResult = ossClient.putObject(bucketName, folder
                    + fileName, is, metadata);
            // 解析結果
            resultStr = putResult.getETag();
            fo[1] = folder + fileName;
            fo[0] = resultStr;
            ossClient.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
            logger.error("上傳阿里云OSS服務器異常." + e.getMessage(), e);
        }
        return fo;
    }
    /**
     * 獲取阿里云OSS客戶端對象
     * 
     * @return ossClient
     */
    public static OSSClient getOSSClient() {
        return new OSSClient(ENDPOINT, ACCESS_KEY_ID, ACCESS_KEY_SECRET);
    }
    /**
     * 獲取阿里云OSS客戶端對象
     * 
     * @param endPoint
     * @param accessKeyId
     * @param accessKeySecret
     * @return
     */
    public static OSSClient getOSSClient(String endPoint, String accessKeyId,
            String accessKeySecret) {
        return new OSSClient(endPoint, accessKeyId, accessKeySecret);
    }
    /**
     * 創建存儲空間
     * 
     * @param ossClient
     *            OSS連接
     * @param bucketName
     *            存儲空間
     * @return
     */
    public static String createBucket(OSSClient ossClient, String bucketName) {
        // 存儲空間
        String bucketNames = bucketName;
        if (!ossClient.doesBucketExist(bucketName)) {
            // 創建存儲空間
            Bucket bucket = ossClient.createBucket(bucketName);
            logger.info("創建存儲空間成功");
            return bucket.getName();
        } else {
            logger.info("名為 " + bucketName + " 存儲空間已經存在");
        }
        return bucketNames;
    }
    /**
     * 刪除存儲空間buckName
     * 
     * @param ossClient
     *            oss對象
     * @param bucketName
     *            存儲空間
     */
    public static void deleteBucket(OSSClient ossClient, String bucketName) {
        ossClient.deleteBucket(bucketName);
        logger.info("刪除" + bucketName + "Bucket成功");
    }
    /**
     * 刪除存儲空間buckName
     * 
     * @param bucketName
     *            存儲空間
     */
    public static void deleteBucket(String bucketName) {
        getOSSClient().deleteBucket(bucketName);
        logger.info("刪除" + bucketName + " Bucket成功");
    }
    /**
     * 創建模擬文件夾
     * 
     * @param ossClient
     *            oss連接
     * @param bucketName
     *            存儲空間
     * @param folder
     *            模擬文件夾名如"anhui/hefei/"
     * @return 文件夾名
     */
    public static String createFolder(OSSClient ossClient, String bucketName,
            String folder) {
        // 文件夾名
        String keySuffixWithSlash = folder;
        // 判斷文件夾是否存在,不存在則創建
        if (!ossClient.doesObjectExist(bucketName, keySuffixWithSlash)) {
            // 創建文件夾
            ossClient.putObject(bucketName, keySuffixWithSlash,
                    new ByteArrayInputStream(new byte[0]));
            logger.info("創建文件夾成功");
            // 得到文件夾名
            OSSObject object = ossClient.getObject(bucketName,
                    keySuffixWithSlash);
            String fileDir = object.getKey();
            return fileDir;
        }
        return keySuffixWithSlash;
    }
    /**
     * 根據key刪除OSS服務器上的文件
     * 
     * @param ossClient
     *            oss連接
     * @param bucketName
     *            存儲空間
     * @param folder
     *            模擬文件夾名 如"anhui/hefei/"
     * @param key
     *            Bucket下的文件的路徑名+文件名 如:"demo.jpg"
     */
    public static void deleteFile(OSSClient ossClient, String bucketName,
            String folder, String key) {
        ossClient.deleteObject(bucketName, folder + key);
        logger.info("刪除" + bucketName + "下的文件" + folder + key + "成功");
    }
    /**
     * 根據key刪除OSS服務器上的文件
     * 
     * @param ossClient
     *            oss連接
     * @param bucketName
     *            存儲空間
     * @param filePath
     *            Bucket下的文件的路徑名+文件名 如:"beijing/demo.jpg"
     */
    public static void deleteFile(OSSClient ossClient, String bucketName,
            String filePath) {
        ossClient.deleteObject(bucketName, filePath);
        logger.info("刪除" + bucketName + "下的文件 " + filePath + " 成功");
    }
    /**
     * 獲得url鏈接
     * 
     * @param key
     * @return
     */
    public static String getUrl(OSSClient ossClient, String bucketName,
            String fileName) {
        // 設置URL過期時間為10年 3600l*60*24*365*10
        Date expiration = new Date(new Date().getTime() + 3600l * 1000 * 24
                * 365 * 10);
        // 生成URL
        // ossClient.gen
        URL url = ossClient.generatePresignedUrl(bucketName, fileName,
                expiration);
        if (url != null) {
            return url.toString();
        }
        return "獲網址路徑出錯";
    }
    /**
     * 通過文件名判斷并獲取OSS服務文件上傳時文件的contentType
     * 
     * @param fileName
     *            文件名
     * @return 文件的contentType
     */
    public static String getContentType(String fileName) {
        // 文件的后綴名
        String fileExtension = fileName.substring(fileName.lastIndexOf("."));
        if (".bmp".equalsIgnoreCase(fileExtension)) {
            return "image/bmp";
        }
        if (".gif".equalsIgnoreCase(fileExtension)) {
            return "image/gif";
        }
        if (".jpeg".equalsIgnoreCase(fileExtension)
                || ".jpg".equalsIgnoreCase(fileExtension)
                || ".png".equalsIgnoreCase(fileExtension)) {
            return "image/jpeg";
        }
        if (".html".equalsIgnoreCase(fileExtension)) {
            return "text/html";
        }
        if (".txt".equalsIgnoreCase(fileExtension)) {
            return "text/plain";
        }
        if (".vsd".equalsIgnoreCase(fileExtension)) {
            return "application/vnd.visio";
        }
        if (".ppt".equalsIgnoreCase(fileExtension)
                || "pptx".equalsIgnoreCase(fileExtension)) {
            return "application/vnd.ms-powerpoint";
        }
        if (".doc".equalsIgnoreCase(fileExtension)
                || "docx".equalsIgnoreCase(fileExtension)) {
            return "application/msword";
        }
        if (".xml".equalsIgnoreCase(fileExtension)) {
            return "text/xml";
        }
        if (".mp4".equalsIgnoreCase(fileExtension)) {
            return "video/mp4";
        }
        // 默認返回類型
        return "image/jpeg";
    }
} 

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://zhengkai.blog.csdn.net/article/details/107586571

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产一区二区三区久久久狼牙 | 国产精品午夜小视频观看 | 国产69精品久久久久久久久久 | 毛片毛片 | 国产精品久久久久永久免费 | 日韩毛片在线看 | 日本娇小18xxxⅹhd | 成人午夜天堂 | 久久国产成人精品国产成人亚洲 | 国产精品午夜在线 | 92看片淫黄大片欧美看国产片 | 日本一区二区免费在线观看 | 欧美重口另类videos人妖 | 日产精品一区二区三区在线观看 | 九草视频 | 最新中文在线视频 | 国产成人高清在线观看 | 欧美精品一区二区视频 | 久久精品久久精品国产大片 | 日本xxxx色视频在线观看免费, | 国产精品久久久毛片 | 国产成人午夜高潮毛片 | 欧美激情性色生活片在线观看 | 日本一区二区高清不卡 | 毛片在线视频观看 | 欧美中文日韩 | 超碰97在线人人 | 国产精品成人一区 | 福利一区二区三区视频在线观看 | 美女毛片儿 | chinese18 xxxx videos | 91短视频网址 | 国产免费福利视频 | 毛片视频网站在线观看 | 欧美成人影院 | 韩国精品视频在线观看 | 午夜生活理论片 | av在线免费观看中文字幕 | 91色琪琪电影亚洲精品久久 | 黄色大片免费网站 | 国产免费看片 |