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

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

android 日志文件LogUtils實例

瀏覽:113日期:2022-09-22 18:14:24

背景

這是好久之前在網上找的一個常用類,已經忘記原文鏈接了,但是覺得很好用一直都在用,可以將日志寫到file里面也可以定位你是在哪個類哪一行打印的日志,保存到文件的路徑就是android/data/你的包名/files/目錄下,然后我們就可以愉快的找問題了

import android.text.TextUtils;import android.util.Log;import com.smartlink.suixing.App;import com.smartlink.suixing.BuildConfig;import java.io.BufferedWriter;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.OutputStreamWriter;import java.text.SimpleDateFormat;import java.util.Date;import java.util.Formatter;import java.util.Locale;public class LogUtils {public static StringcustomTagPrefix= 'log';// 自定義Tag的前綴,可以是作者名private static final booleanisSaveLog= true;// 是否把保存日志到SD卡中private static StringcacheDirPath;private LogUtils() {}// 容許打印日志的類型,默認是true,設置為false則不打印public static booleanallowD= BuildConfig.DEBUG;public static booleanallowE= BuildConfig.DEBUG;public static booleanallowI= BuildConfig.DEBUG;public static booleanallowV= BuildConfig.DEBUG;public static booleanallowW= BuildConfig.DEBUG;public static booleanallowWtf= BuildConfig.DEBUG;// public static boolean allowD = true;// public static boolean allowE = true;// public static boolean allowI = true;// public static boolean allowV = true;// public static boolean allowW = true;// public static boolean allowWtf = true;private static String generateTag(StackTraceElement caller) {String tag = '%s.%s(Line:%d)'; // 占位符String callerClazzName = caller.getClassName(); // 獲取到類名callerClazzName = callerClazzName.substring(callerClazzName.lastIndexOf('.') + 1);tag = String.format(tag, callerClazzName, caller.getMethodName(), caller.getLineNumber()); // 替換tag = TextUtils.isEmpty(customTagPrefix) ? tag : customTagPrefix + ':' + tag;return tag;}/*** * 打印控制臺顯示不了那么長的日志問題 * * @param msg */public static void logE(String msg) { // 信息太長,分段打印if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);// 因為String的length是字符數量不是字節數量所以為了防止中文字符過多,// 把4*1024的MAX字節打印長度改為2001字符數int max_str_length = 2001 - tag.length();// 大于4000時while (msg.length() > max_str_length) {// Log.e(tag, msg.substring(0, max_str_length));LogUtils.e(msg.substring(0, max_str_length));msg = msg.substring(max_str_length);}// 剩余部分// Log.e(tag, msg);LogUtils.e(msg);}/** * 自定義的logger */public static CustomLogger customLogger;public interface CustomLogger {void d(String tag, String content);void d(String tag, String content, Throwable tr);void e(String tag, String content);void e(String tag, String content, Throwable tr);void i(String tag, String content);void i(String tag, String content, Throwable tr);void v(String tag, String content);void v(String tag, String content, Throwable tr);void w(String tag, String content);void w(String tag, String content, Throwable tr);void w(String tag, Throwable tr);void wtf(String tag, String content);void wtf(String tag, String content, Throwable tr);void wtf(String tag, Throwable tr);}public static void d(String content) {if (!allowD) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.d(tag, content);} else {Log.d(tag, content);}}public static void d(String content, Throwable tr) {if (!allowD) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.d(tag, content, tr);} else {Log.d(tag, content, tr);}}public static void e(String content) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, content);} else {Log.e(tag, content);}if (isSaveLog) {point(cacheDirPath, tag, content);}}public static void e(String content, Throwable tr) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, content, tr);} else {Log.e(tag, content, tr);}if (isSaveLog) {point(cacheDirPath, tag, tr.getMessage());}}public static void e(Throwable tr) {if (!allowE) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.e(tag, '', tr);} else {Log.e(tag, '', tr);}if (isSaveLog) {point(cacheDirPath, tag, tr.getMessage());}}public static void i(String content) {if (!allowI) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.i(tag, content);} else {Log.i(tag, content);}}public static void i(String content, Throwable tr) {if (!allowI) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.i(tag, content, tr);} else {Log.i(tag, content, tr);}}public static void v(String content) {if (!allowV) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.v(tag, content);} else {Log.v(tag, content);}}public static void v(String content, Throwable tr) {if (!allowV) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.v(tag, content, tr);} else {Log.v(tag, content, tr);}}public static void w(String content) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, content);} else {Log.w(tag, content);}}public static void w(String content, Throwable tr) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, content, tr);} else {Log.w(tag, content, tr);}}public static void w(Throwable tr) {if (!allowW) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.w(tag, tr);} else {Log.w(tag, tr);}}public static void wtf(String content) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, content);} else {Log.wtf(tag, content);}}public static void wtf(String content, Throwable tr) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, content, tr);} else {Log.wtf(tag, content, tr);}}public static void wtf(Throwable tr) {if (!allowWtf) return;StackTraceElement caller = getCallerStackTraceElement();String tag = generateTag(caller);if (customLogger != null) {customLogger.wtf(tag, tr);} else {Log.wtf(tag, tr);}}private static StackTraceElement getCallerStackTraceElement() {return Thread.currentThread().getStackTrace()[4];}public static void point(String path, String tag, String msg) {if (isSDAva()) {path = cacheDirPath;Date date = new Date();SimpleDateFormat dateFormat = new SimpleDateFormat('', Locale.SIMPLIFIED_CHINESE);dateFormat.applyPattern('yyyy');path = path + dateFormat.format(date) + '/';dateFormat.applyPattern('MM');path += dateFormat.format(date) + '/';dateFormat.applyPattern('dd');path += dateFormat.format(date) + '.log';dateFormat.applyPattern('[yyyy-MM-dd HH:mm:ss]');String time = dateFormat.format(date);File file = new File(path);if (!file.exists()) createDipPath(path);BufferedWriter out = null;try {out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(file, true)));out.write(time + ' ' + tag + ' ' + msg + 'rn');} catch (Exception e) {e.printStackTrace();} finally {try {if (out != null) {out.close();}} catch (IOException e) {e.printStackTrace();}}}}/** * 根據文件路徑 遞歸創建文件 * * @param file */public static void createDipPath(String file) {String parentFile = file.substring(0, file.lastIndexOf('/'));File file1 = new File(file);File parent = new File(parentFile);if (!file1.exists()) {parent.mkdirs();try {file1.createNewFile();LogUtils.e('日志文件的路徑是' + file1.getAbsolutePath());} catch (IOException e) {e.printStackTrace();}}}/** * A little trick to reuse a formatter in the same thread */private static class ReusableFormatter {private Formatterformatter;private StringBuilderbuilder;public ReusableFormatter() {builder = new StringBuilder();formatter = new Formatter(builder);}public String format(String msg, Object... args) {formatter.format(msg, args);String s = builder.toString();builder.setLength(0);return s;}}private static final ThreadLocal<ReusableFormatter> thread_local_formatter = new ThreadLocal<ReusableFormatter>() {protected ReusableFormatter initialValue() {return new ReusableFormatter();}};public static String format(String msg, Object... args) {ReusableFormatter formatter = thread_local_formatter.get();return formatter.format(msg, args);}public static boolean isSDAva() {if (cacheDirPath == null) cacheDirPath = App.getAppContext().getExternalFilesDir('log').getAbsolutePath();if (!TextUtils.isEmpty(cacheDirPath)) {return true;} else {return false;}}}

補充知識:Android日志打印類LogUtils,能夠定位到類名,方法名以及出現錯誤的行數并保存日志文件

在開發中,我們常常用打印log的方式來調試我們的應用。在Java中我們常常使用方法System.out.println()來在控制臺打印日志,以便我們的調試。Android中有一個專門的類Log來實現在Android系統下日志的打印,更加方便我們定位程序出現問題的地方。

但是Android官方提供的Log類在實際項目使用中,也不是非常方便。當程序出現錯誤時,我們最希望的就是這個Log類能幫我們定位到是哪個類的哪個方法,甚至于是那一行出現了錯誤。這樣就能給我們的調試帶來很大的便利。

同時我們也應該想到為了應用程序的安全起見,在app正式上線之前,我們應該要把打印日志的功能關閉掉,以防別人通過Log來破解你的應用。生產模式的下打印Log,正式模式就把打印日志的功能關閉掉,要做到Log的靈活關閉與打開,也需要在原生的Log類上進行一些封裝。

還有一種時候,當我們的程序出現問題崩潰了,我們希望能夠收集到出現異常的原因進行分析,所以可以把Log日志保存到一個文件中,放在SD卡程序創建的目錄下。也可以在用戶聯網的情況下,在程序的后臺把出異常的Log日志文件上傳到服務端,方便程序員進行分析,解決bug。

今天就給大家分享一個做項目中很實用的一個Log類LogUtils,這個類是從xUtils中提取出來,稍作修改的,有注釋。

示例:

我們在MainActivity中調用一些LogUtils中的方法,注意看行數。 1

接著看看控制臺打印的日志是不是像MainActivity調用的那樣,Log中有這個類的名字和oncreate方法名,已及當前行數;  2

看到上圖中的Log日志是不是很方便定位程序中的問題了,出現異常也能快速的定位到。然后把下面的Log類型在程序的任何地方設置為false則不會打印日志,使用起來相當的方便。 

 // 容許打印日志的類型,默認是true,設置為false則不打印 public static boolean allowD = true; public static boolean allowE = true; public static boolean allowI = true; public static boolean allowV = true; public static boolean allowW = true; public static boolean allowWtf = true;

代碼貼在下面:

package com.finddreams.log;import java.io.BufferedWriter;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.OutputStreamWriter;import java.text.SimpleDateFormat;import java.util.Date;import java.util.Formatter;import java.util.Locale;import android.os.Environment;import android.text.TextUtils;import android.util.Log;/** * Log工具,類似android.util.Log。 tag自動產生,格式: * customTagPrefix:className.methodName(Line:lineNumber), * customTagPrefix為空時只輸出:className.methodName(Line:lineNumber)。 */public class LogUtils { public static String customTagPrefix = 'finddreams'; // 自定義Tag的前綴,可以是作者名 private static final boolean isSaveLog = false; // 是否把保存日志到SD卡中 public static final String ROOT = Environment.getExternalStorageDirectory() .getPath() + '/finddreams/'; // SD卡中的根目錄 private static final String PATH_LOG_INFO = ROOT + 'info/'; private LogUtils() { } // 容許打印日志的類型,默認是true,設置為false則不打印 public static boolean allowD = true; public static boolean allowE = true; public static boolean allowI = true; public static boolean allowV = true; public static boolean allowW = true; public static boolean allowWtf = true; private static String generateTag(StackTraceElement caller) { String tag = '%s.%s(Line:%d)'; // 占位符 String callerClazzName = caller.getClassName(); // 獲取到類名 callerClazzName = callerClazzName.substring(callerClazzName .lastIndexOf('.') + 1); tag = String.format(tag, callerClazzName, caller.getMethodName(), caller.getLineNumber()); // 替換 tag = TextUtils.isEmpty(customTagPrefix) ? tag : customTagPrefix + ':' + tag; return tag; } /** * 自定義的logger */ public static CustomLogger customLogger; public interface CustomLogger { void d(String tag, String content); void d(String tag, String content, Throwable tr); void e(String tag, String content); void e(String tag, String content, Throwable tr); void i(String tag, String content); void i(String tag, String content, Throwable tr); void v(String tag, String content); void v(String tag, String content, Throwable tr); void w(String tag, String content); void w(String tag, String content, Throwable tr); void w(String tag, Throwable tr); void wtf(String tag, String content); void wtf(String tag, String content, Throwable tr); void wtf(String tag, Throwable tr); } public static void d(String content) { if (!allowD) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.d(tag, content); } else { Log.d(tag, content); } } public static void d(String content, Throwable tr) { if (!allowD) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.d(tag, content, tr); } else { Log.d(tag, content, tr); } } public static void e(String content) { if (!allowE) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.e(tag, content); } else { Log.e(tag, content); } if (isSaveLog) { point(PATH_LOG_INFO, tag, content); } } public static void e(String content, Throwable tr) { if (!allowE) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.e(tag, content, tr); } else { Log.e(tag, content, tr); } if (isSaveLog) { point(PATH_LOG_INFO, tag, tr.getMessage()); } } public static void i(String content) { if (!allowI) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.i(tag, content); } else { Log.i(tag, content); } } public static void i(String content, Throwable tr) { if (!allowI) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.i(tag, content, tr); } else { Log.i(tag, content, tr); } } public static void v(String content) { if (!allowV) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.v(tag, content); } else { Log.v(tag, content); } } public static void v(String content, Throwable tr) { if (!allowV) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.v(tag, content, tr); } else { Log.v(tag, content, tr); } } public static void w(String content) { if (!allowW) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.w(tag, content); } else { Log.w(tag, content); } } public static void w(String content, Throwable tr) { if (!allowW) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.w(tag, content, tr); } else { Log.w(tag, content, tr); } } public static void w(Throwable tr) { if (!allowW) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.w(tag, tr); } else { Log.w(tag, tr); } } public static void wtf(String content) { if (!allowWtf) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.wtf(tag, content); } else { Log.wtf(tag, content); } } public static void wtf(String content, Throwable tr) { if (!allowWtf) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.wtf(tag, content, tr); } else { Log.wtf(tag, content, tr); } } public static void wtf(Throwable tr) { if (!allowWtf) return; StackTraceElement caller = getCallerStackTraceElement(); String tag = generateTag(caller); if (customLogger != null) { customLogger.wtf(tag, tr); } else { Log.wtf(tag, tr); } } private static StackTraceElement getCallerStackTraceElement() { return Thread.currentThread().getStackTrace()[4]; } public static void point(String path, String tag, String msg) { if (isSDAva()) { Date date = new Date(); SimpleDateFormat dateFormat = new SimpleDateFormat('', Locale.SIMPLIFIED_CHINESE); dateFormat.applyPattern('yyyy'); path = path + dateFormat.format(date) + '/'; dateFormat.applyPattern('MM'); path += dateFormat.format(date) + '/'; dateFormat.applyPattern('dd'); path += dateFormat.format(date) + '.log'; dateFormat.applyPattern('[yyyy-MM-dd HH:mm:ss]'); String time = dateFormat.format(date); File file = new File(path); if (!file.exists()) createDipPath(path); BufferedWriter out = null; try { out = new BufferedWriter(new OutputStreamWriter( new FileOutputStream(file, true))); out.write(time + ' ' + tag + ' ' + msg + 'rn'); } catch (Exception e) { e.printStackTrace(); } finally { try { if (out != null) { out.close(); } } catch (IOException e) { e.printStackTrace(); } } } } /** * 根據文件路徑 遞歸創建文件 * * @param file */ public static void createDipPath(String file) { String parentFile = file.substring(0, file.lastIndexOf('/')); File file1 = new File(file); File parent = new File(parentFile); if (!file1.exists()) { parent.mkdirs(); try { file1.createNewFile(); } catch (IOException e) { e.printStackTrace(); } } } /** * A little trick to reuse a formatter in the same thread */ private static class ReusableFormatter { private Formatter formatter; private StringBuilder builder; public ReusableFormatter() { builder = new StringBuilder(); formatter = new Formatter(builder); } public String format(String msg, Object... args) { formatter.format(msg, args); String s = builder.toString(); builder.setLength(0); return s; } } private static final ThreadLocal<ReusableFormatter> thread_local_formatter = new ThreadLocal<ReusableFormatter>() { protected ReusableFormatter initialValue() { return new ReusableFormatter(); } }; public static String format(String msg, Object... args) { ReusableFormatter formatter = thread_local_formatter.get(); return formatter.format(msg, args); } public static boolean isSDAva() { if (Environment.getExternalStorageState().equals( Environment.MEDIA_MOUNTED) || Environment.getExternalStorageDirectory().exists()) { return true; } else { return false; } }}

以上這篇android 日志文件LogUtils實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Android
相關文章:
主站蜘蛛池模板: 亚洲视频免费在线观看 | 久久久www | 国产精品一区二区三区久久 | 成人网av| 国产精品久久久久久久久久久久久 | 精品久 | 欧美成亚洲 | 伊人一区 | 国产精品一区二区av | 中文一区 | 亚洲综合精品 | 日韩中文字幕在线免费 | 亚洲人成网站999久久久综合 | 欧美精品在线一区二区三区 | 欧美日韩不卡合集视频 | 天天舔夜夜 | 日韩免费在线观看视频 | 草草视频在线播放 | 国产黄网 | 青青草超碰在线 | 国产精品成人一区二区 | 国产毛片精品 | 亚洲成人免费影院 | 91激情视频 | 性人久久久 | www国产成人免费观看视频 | 看片久久 | xx视频在线观看 | 成人一区二区在线 | 亚洲精品一二三四五区 | 97色在线视频 | 国产精品久久久久久久久久东京 | 99国产精品一区 | 亚洲国产精品视频 | 精品国产一区二区三区久久久蜜月 | 在线视频91| 草草精品视频 | 色天天综合久久久久综合片 | 成年人在线看 | 伊人色综合久久天天五月婷 | 欧美麻豆 | 免费一级欧美在线观看视频 | 精品国产乱码久久久久久久软件 | 亚洲成av人片在线观看无码 | 国产乱码久久久久久一区二区 | 操久久 | 日韩电影在线 | 精品国产乱码久久久久久1区2区 | 欧美日韩在线视频一区 | jizz在线看片 | 伊人网在线视频观看 | 色播久久久 | 精品免费久久久久 | 伊人99| 欧美性猛片 | 在线第一页 | 成人久久久 | 亚洲第一av | 欧美日韩一级电影 | 欧美一区在线视频 | 亚洲黄色区 | 成人在线一区二区 | 91极品在线| 亚洲精品免费视频 | 欧美日韩一区二区三区免费视频 | 一区久久 | 中文字幕_第2页_高清免费在线 | 国产一区二区三区免费看 | 午夜精品一区二区三区在线观看 | 国产精品人人做人人爽人人添 | 欧美日韩亚洲高清 | 久热精品在线视频 | 国产成年人小视频 | 国产精品色婷婷久久58 | 日韩欧美在线观看视频网站 | 久久国产精品视频 | 欧美片网站免费 | а_天堂中文最新版地址 | 伊人青青久 | 老熟女毛片 | 欧美激情一区二区三区在线视频 | 91久久久久久久久久久久久 | 久久久精品国产 | 色噜噜在线 | 国产一区二区三区av在线 | 中文字字幕在线观看 | 国产精品入口久久 | 亚洲aⅴ天堂av在线电影软件 | 一区二区三区国产亚洲网站 | 国产精品久久久久久久一区探花 | 成年人网站在线免费看 | 日韩成人一区二区 | 一区不卡 | 亚洲精品在线免费看 | 亚洲欧美精品一区二区三区 | 成人高清视频在线观看 | 精品美女在线观看视频在线观看 | 欧美激情视频一区二区三区 | 亚洲一区二区三区爽爽爽爽爽 | 在线看一区 | 日本一级毛片视频 | 午夜视频福利 | 我看午夜视频 | 亚洲第一福利视频 | 午夜天堂精品久久久久 | 国产乱a视频在线 | 81精品国产乱码久久久久久 | 91在线视频观看 | 亚洲激情欧美 | 亚洲区一区二 | 韩国一区二区视频 | 国产精品欧美一区二区三区 | 国产二区视频 | 精品国产一区二区三区在线观看 | 天天舔夜夜操 | 操操操操操 | 亚洲啪啪网站 | 色爱av | 中文字幕 在线观看 | 国产xxx护士爽免费看 | 国产精品日产欧美久久久久 | 成人久久18免费观看 | 国产欧精精久久久久久久 | 久久久久久毛片免费观看 | 亚洲成人影院在线观看 | 欧美a在线 | 亚洲午夜精品片久久www慈禧 | 日韩在线不卡 | 久久久久久久久99精品 | 日韩五月 | 国产精品视频导航 | 久久99精品久久久久久青青日本 | 国产99精品 | 一本岛在线视频 | 日韩欧美在线视频 | 午夜欧美一区二区三区在线播放 | 91精品国产色综合久久不卡98 | 亚洲精品福利网站 | 精品国产黄a∨片高清在线 日韩一区二 | 婷婷综合一区 | 亚洲精品一区中文字幕乱码 | 日韩精品免费在线观看 | 日韩a在线 | 日本免费三片免费观看 | 国产精品视屏 | 日本黄色影片在线观看 | 成人免费高清 | 国产乱码精品一区二区三区手机版 | 香蕉婷婷 | 国产精品国产精品国产专区不片 | 日韩在线欧美 | 日韩精品在线一区 | 国产精品亚洲区 | 亚洲国产成人av好男人在线观看 | 天天操天天草 | 久久精品免费观看 | 成人看片免费网站 | 538在线精品 | 能免费看av的网站 | 成人高清网站 | 亚洲黄色一级毛片 | 中文精品在线 | 日韩中文久久 | 国产欧美在线观看 | 日韩2区 | 亚洲成人精品在线 | 欧美午夜一区二区三区免费大片 | 欧美日韩一区二区三区四区 | 亚洲精品一区二区三区在线观看 | 天天躁人人躁人人躁狂躁 | 日韩高清在线播放 | 成人免费视频网站在线看 | 国产免费一区二区三区 | 亚洲午夜精品在线观看 | 久久精品久久久 | 久久这里只有国产精品 | 福利视频一区 | 天天操天天操 | 国产一二在线 | 久色91| 欧美成人综合在线 | 青青久久 | 午夜视频在线观看网站 | 日韩一级在线免费观看 | 国产欧美一区二区三区在线看 | 欧美一级片在线观看 | 一区二区三区视频 | 欧美午夜在线观看 | 国产一区2区 | 欧美在线一区二区三区 | 午夜影视 | 国产黄色网址在线观看 | 国产视频中文字幕 | 成人精品视频99在线观看免费 | 亚洲精品一区二三区 | 在线观看你懂的网站 | 午夜视频在线观看网站 | 精品国产精品 | 狠狠躁日日躁夜夜躁东南亚 | 午夜免费小视频 | 国产成人精品久久二区二区 | 综合五月网 | www.成人.com| 91麻豆精品国产91久久久久 | 黄色片免费看. | 国产精品亚洲天堂 | 欧美福利网 | 97爱爱爱 | 伊人网综合视频 | 国产精品久久久爽爽爽麻豆色哟哟 | 国产一区二区高潮 | 亚洲精品一区二区三区四区高清 | 欧美性猛交一区二区三区精品 | 久久亚洲二区 | 人人干美女| 99这里只有精品 | 精品成人av | 黄色成人在线 | 国产欧美久久久久久 | 九九热在线视频免费观看 | 毛片视频观看 | 91免费在线播放 | 亚洲区一区二 | 午夜久久久 | 亚洲精品乱码久久久久久花季 | 久草美女 | 欧美日韩国产一区二区在线观看 | a毛片 | 激情视频网站 | 久久伊人中文字幕 | 日日骚视频 | 日韩高清一区 | 黄色骚片| 中文字幕乱码一区二区三区 | 综合在线视频 | 国产三级在线观看 | 精品无码久久久久久国产 | 欧美日本韩国一区二区 | 色婷婷影院 | 成人天堂资源www在线 | 日本videos18高清hd下 | 无毒黄网 | 君岛美绪一区二区三区在线视频 | jizz18毛片 | 久久亚洲精品裙底抄底 | 九九久久影视 | 久久久久一区 | 亚洲一区二区在线 | 一区二区三区国产好 | 亚洲高清网 | 欧美日韩成人在线 | 视频网站免费观看 | 九九热在线视频免费观看 | www.99日本精品片com | 狠狠艹 | 99r精品在线 | 国产一级在线观看 | 久久毛片| 在线看亚洲| 亚洲视频在线观看一区二区三区 | 激情五月婷婷综合 | 久久久91 | 久色 | 中文字幕一区二区在线观看 | 午夜精品久久久久久久星辰影院 | 久久99久久99精品免视看婷婷 | 日本不卡高字幕在线2019 | 国产精品久久久久久久久久妞妞 | 国产色播av在线 | 九九热这里只有精品6 | 欧美日韩三区 | 一区二区三区四区免费看 | 精品久久久久久久久久久久久久 | 亚洲成人精品影视 | 日韩电影专区 | 欧美国产一区二区 | 欧美成人三区 | 日韩精品久久 | www久久久 | 日韩精品一区二区三区在线播放 | 龙珠z在线观看 | 一区二区国产精品 | 美女福利视频网站 | 欧美日韩一区二区视频在线观看 | 91在线精品一区二区 | 久久久国产精品 | 羞羞视频网站在线看 | 国产欧美日韩综合精品一区二区 | 国产成人在线电影 | 91久久91久久精品免观看 | 国产一区二区高潮 | 这里有精品在线视频 | 亚洲永久免费 | 欧美性一区二区 | 亚洲色图偷拍视频 | 欧美狠狠操 | 亚洲第一成人在线视频 | 99久久电影 | 91福利视频导航 | 欧美日韩在线一区二区 | 亚洲不卡在线观看 | 中文字幕一区二区三区精彩视频 | av色资源| 日韩成人在线观看 | 免费国产一区二区 | 久久久精品久久久久 | 欧州一区二区 | 日本一区二区不卡视频 | 午夜私人影院 | 久久精精品 | 伊人电影综合 | 怡红院成人影院 | 精品一区二区三区中文字幕 | 亚洲一区在线日韩在线深爱 | 色黄视频在线 | 久久一区二区三区四区 | 玖玖精品 | 天天看天天干 | 亚洲综合网站 | 国产精品久久嫩一区二区 免费 | 免费观看国产精品 | 成人精品国产一区二区4080 | 国产亚洲一区二区三区在线 | 精品视频一区二区三区 | 成人精品久久久 | 国产精品一任线免费观看 | 国产一区二区视频免费看 | 天堂√在线观看一区二区 | 欧美视频在线播放 | 久久精品播放 | 污片在线免费看 | 欧美日韩精品在线一区 | 欧美精产国品一二三区 | 日韩在线成人 | aⅴ色国产 欧美 | 欧美精品综合在线 | 亚洲一区二区三区精品视频 | 探花在线观看 | 亚洲成人高清 | 亚洲aⅴ| 日韩欧美精品在线 | 国产精品极品美女在线观看免费 | 国产在线观看av | 日日摸夜夜添夜夜添高潮视频 | 日本福利在线观看 | 亚洲不卡视频 | 九九亚洲| 亚洲国产高清在线 | 亚洲国产精品久久久久久久 | 午夜视频在线观看免费视频 | 在线观看亚洲一区二区 | 国产一区二区高潮 | 综合色久| 久久三区| 中文字幕在线视频免费观看 | 成人在线免费视频 | 欧美在线网站 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 色约约精品免费看视频 | 91中文在线观看 | 国产在线一区二区 | 国产欧美综合一区二区三区 | 精品久久久久久国产 | 亚洲精品视频在线播放 | www久久久 | 一本大道综合伊人精品热热 | 国产精品一区二区三区免费视频 | 黄色毛片在线播放 | 成人夜晚看av | 亚洲高清电影 | 欧美日韩三区 | 精品国产鲁一鲁一区二区在线观看 | 天天久久 | 中文字幕一区二区三区乱码图片 | 亚洲成人av | 久久99一区二区 | 亚洲一区二区在线视频 | 欧美精品一区二区三区在线四季 | 国产一级片 | 欧美视频免费 | 欧美猛交ⅹxxx乱大交视频 | 中文字幕一区二区三区不卡 | 在线视频一区二区 | 欧美一区免费 | 91高清免费看 | 国产精国产精品 | 午夜日韩| 国产成人av网站 | 婷婷在线视频 | 欧美在线视频一区 | av在线一区二区 | 91成人精品 | 中文字幕a视频 | 中文字幕亚洲欧美日韩在线不卡 | 国产精品三级久久久久久电影 | 亚洲风情在线观看 | 国产激情精品一区二区三区 | 中文字幕亚洲字幕一区二区 | 亚洲精品一二三区 | av动漫一区二区 | 精品亚洲一区二区 | 国产成人在线免费观看视频 | 亚洲成人首页 | 国产精品人人做人人爽 | 91麻豆精品国产91久久久更新资源速度超快 | 色吟av| 久久伊人免费视频 | 精品在线播放 | 激情.com | 中文字幕一区二区三区在线视频 | 成人网18免费网站 | 婷婷精品 | 亚洲综合色网 | 中文字幕在线资源 | 精品成人久久 | 国产精品午夜电影 | 91精品国产91久久久久久黑人 | 欧美日韩在线观看一区二区 | 色无欲天天天影视综合网 | 动漫羞免费网站中文字幕 | 日本一本视频 | 欧美在线观看一区 | 天天干人人 | 在线中文字幕av | 玖玖免费| 91av官网 | 欧美freesex交免费视频 | 91在线精品视频 | 免费观看一级毛片 | 成人一区视频 | 国产日韩av在线 | 精品福利在线视频 | 亚洲精品中文字幕乱码无线 | 九九热视频在线 | 人人射人人舔 | 亚洲综合精品视频 | 狠狠色狠狠色综合网 | 亚洲高清av | 天天爽视频 | 久久国产精品一区二区 | 欧美一级在线观看 | 大乳videos巨大吃奶 | 天天操综合网 | 成人免费crm在线观看 | 中文字幕一区二区在线观看 | 亚洲国产精品福利 | 久久一区 | 不卡日韩在线 | 国产精品高清在线 | 亚洲激情在线 | 亚洲伊人成人 | 亚洲 欧美 在线 一区 | 午夜精品久久 | 国产欧美精品一区二区三区 | 中文字幕欧美在线观看 | 久久av资源网 | 91资源在线观看 | 久久成人在线 | 日韩欧美专区 | 精品国产一区二区国模嫣然 | 午夜精品久久久久久久99黑人 | 久久久久久综合 | 国产精品精品视频一区二区三区 | 成人在线播放 | 亚洲欧美日本在线 | 玖色视频| 91精品国产高清一区二区三区 | 国产精品久久久久影院色老大 | 国产精品视频 | 午夜精品久久久久久久久 | 九九久久精品 | 日日爱视频 | aaa大片免费观看 | 免费在线一区二区 | 中文字幕在线观看 | 999视频在线免费观看 | 成人福利网 | 九九国产精品视频 | 国产亚洲精品成人av久久影院 | 亚洲精品9999 | 风间由美一区二区三区在线观看 | 国产在线精品一区二区三区 | 国产免费看| 国产97色在线 | 亚洲 | 久久久99精品免费观看 | 国产精品久久久久久久久免费桃花 | 一本色道精品久久一区二区三区 | 国产一区二区视频在线观看 | 国产一区二区欧美 | 国产伦精品一区二区三区四区视频 | 国产精品原创av片国产免费 | 在线观看欧美日韩 | 成人精品高清 | 国产精品视频免费观看 | 久久99国产精品免费网站 | 日韩欧美中文字幕在线视频 | 国产精品高潮呻吟久久av野狼 | 欧美一级毛片久久99精品蜜桃 | 欧美a级在线观看 | 国产日韩欧美一区 | 久草天堂| 国产精品99久久久久久久vr | 日韩在线视频观看免费 | 国产成人精品av | 日操| 91欧美激情一区二区三区成人 | 久久国| 久久久精品久久久 | 欧美精品一区二区三区四区五区 | 91免费版在线看 | 日本久久久一区二区三区 | 久久精品99国产精品日本 | 国产一区二区视频在线 | 久久国产精品一区二区 | xvideos.蜜桃一区二区 | 久久综合狠狠综合久久 | www一起操 | 欧洲成人在线观看 | 一区二区三区四区在线 | 国产欧美日韩在线 | 日韩美香港a一级毛片免费 国产综合av | 成人av片在线观看 | 久久久久一区二区 | 麻豆亚洲| 久久青青 | 国内精品亚洲 | 欧美日韩成人免费 | 欧美国产在线视频 | 日韩福利| 久草观看 | 亚洲视频在线观看免费 | 夜夜视频 | 国产精品国产三级国产aⅴ中文 | 91久久精品一区二区二区 | 伊人免费在线观看高清版 | 日韩精品av一区二区三区 | 精品久久久久久久久福利 | 国产激情99| 欧美日韩国产精品一区二区 | 午夜资源 | 亚洲国产欧美日韩 | 成人免费淫片aa视频免费 | 亚洲女人天堂成人av在线 | 91av免费在线观看 | 狠狠久久伊人中文字幕 | 亚洲第一视频 | 国产精品久久国产精品 | 午夜寂寞福利视频 | 欧洲亚洲精品久久久久 | 黄色一级片免费播放 | 一区二区三区 在线 | 欧美日韩国产在线观看 | 亚洲欧美中文日韩在线v日本 | 中文字幕亚洲欧美日韩在线不卡 | 成人高清视频在线观看 | 午夜激情视频免费 | 色综合88| 97av视频| 午夜午夜精品一区二区三区文 | 国产成人av免费 | 久久99精品久久久久久园产越南 | 成人性大片免费观看网站 | 一区二区三区的视频 | www.亚洲区 | 国产欧美精品一区 | 日韩在线观看视频一区二区 | 国产在线视频在线 | 亚洲国产精品一区二区三区 | 中文字幕爱爱视频 | 国产高清久久久 | 亚洲1级片 | 欧美黄色a视频 | 天堂成人国产精品一区 | 久久久久综合狠狠综合日本高清 | 亚洲免费网站在线观看 | 欧美精品一区在线观看 | 黄色片免费在线观看 | 久久综合九色综合欧美狠狠 | 91久久精品国产91久久 | 自拍视频网 | 国产精品久久久久久 | 日韩欧美在线不卡 | 欧美一区二区三区久久精品 | 成人在线www | 成人免费视频视频在线观看 免费 | 亚洲精品系列 | 欧美日韩视频在线观看免费 | 日韩欧美精品在线 | 色婷婷亚洲一区二区三区 | 日本久草 | 久久久久久艹 | 国产日韩一区 | 97久久久 | 日韩欧美一区二区三区免费观看 | 9久久 | 老司机深夜福利在线观看 | 羞羞视频免费在线观看 | 日韩在线视频一区 | 在线免费观看黄色 | 成人av片在线观看 | 欧美精品在线一区 | 在线观看亚洲一区二区三区 | 日韩欧美国产网站 | 欧美视频区| 国产综合av | 91精品久久久久久久久久入口 | 黄一区| 国产成人精品久久二区二区91 | av在线天堂| 国产高潮好爽受不了了夜色 | 国产成人精品亚洲日本在线观看 | 免费在线国产 | 久久99精品久久久水蜜桃 | 看片一区| 日韩一区二区黄色片 |