亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統(tǒng) > Android > 正文

Java操作Ant壓縮和解壓文件及批量打包Anroid應(yīng)用

2020-01-02 07:03:43
字體:
供稿:網(wǎng)友

實(shí)現(xiàn)zip/tar的壓縮與解壓

java中實(shí)際是提供了對  zip等壓縮格式的支持,但是為什么這里會(huì)用到ant呢?

原因主要有兩個(gè):
1. java提供的類對于包括有中文字符的路徑,文件名支持不夠好,你用其它第三方軟件解壓的時(shí)候就會(huì)存在亂碼。而ant.jar就支持文件名或者路徑包括中文字符。
2. ant.jar提供了強(qiáng)大的工具類,更加方便于我們對壓縮與解壓的操作。
注意事項(xiàng):
1. 首先說明一下,關(guān)于皮膚或者類似于皮膚的Zip包,實(shí)際上公司可能會(huì)根據(jù)自己的規(guī)定或需求,自定義壓縮包文件的結(jié)尾,實(shí)際上大多還是Zip包的格式. 具體部分的處理大致上是一樣的,因此不再復(fù)述, 本文給出的例子已經(jīng)有Zip包和Tar包的解壓縮.
2. 還有要注意的是,此處為提升理解,因此加入zip/tar壓縮,解壓的界面,實(shí)際應(yīng)用中此部分無需單獨(dú)的界面展示(解壓縮需要一定時(shí)間的話,則為加強(qiáng)用戶體驗(yàn),加入提示框與進(jìn)度條),請自行編寫解壓縮管理類進(jìn)行邏輯判斷分別處理.
3. 測試時(shí)需要講要解壓縮的包導(dǎo)入sdcard目錄下(若為其他目錄,請修改代碼中路徑)

2016226144353610.jpg (563×582)

程序主界面及解壓縮的界面:

2016226144429500.jpg (369×473)2016226144445346.jpg (332×440)

接下來是解壓縮核心的代碼:
布局文件: antzip.xml:

<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"   android:layout_width="fill_parent"   android:layout_height="fill_parent">         <LinearLayout     android:orientation="vertical" android:layout_width="fill_parent"     android:layout_height="wrap_content"     android:gravity="center"     android:padding="20dip"     android:layout_centerInParent="true">          <RadioGroup       android:layout_width="wrap_content"       android:layout_height="wrap_content"       android:orientation="horizontal">       <RadioButton android:layout_width="wrap_content"         android:layout_height="wrap_content"         android:id="@+id/radioZip"         android:checked="true"         android:text="ZIP"/>              <RadioButton android:layout_width="wrap_content"         android:layout_height="wrap_content"         android:id="@+id/radioTar"         android:text="TAR"         android:layout_marginLeft="10dip"/>     </RadioGroup>          <Button android:text="壓縮" android:id="@+id/button1"       android:layout_width="fill_parent" android:layout_height="wrap_content"       android:paddingLeft="30dip" android:paddingRight="30dip"></Button>     <Button android:text="解壓" android:id="@+id/button2"       android:layout_width="fill_parent" android:layout_height="wrap_content"       android:paddingLeft="30dip" android:paddingRight="30dip"       android:layout_marginTop="20dip"></Button>   </LinearLayout>       </RelativeLayout> 

AntZipActivity:

public class AntZipActivity extends Activity {   public static final String TYPE = "type";   public static final int   TYPE_ZIP = -1;   public static final int   TYPE_TAR = 1;      public static final String SUFFIX_ZIP = ".zip";   public static final String SUFFIX_TAR = ".tar";   /** Called when the activity is first created. */   private Button   btnDoCompress;   private Button   btnDecompress;      private RadioButton radioZip;   private RadioButton radioTar;      private boolean isZip = true;   @Override   public void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);     setContentView(R.layout.antzip);     radioZip = (RadioButton)findViewById(R.id.radioZip);     isZip = true;     radioZip.setChecked(true);     radioZip.setOnCheckedChangeListener(new OnCheckedChangeListener() {              @Override       public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {         System.out.println("radioZip:"+isChecked);         if(isChecked)         {           isZip = true;         }       }     });     radioTar = (RadioButton)findViewById(R.id.radioTar);     radioTar.setOnCheckedChangeListener(new OnCheckedChangeListener() {              @Override       public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {         System.out.println("radioTar:"+isChecked);         if(isChecked)         {           isZip = false;         }       }     });     btnDoCompress = (Button)findViewById(R.id.button1);     btnDoCompress.setOnClickListener(new OnClickListener() {              @Override       public void onClick(View v) {         //進(jìn)入壓縮界面          Intent i = new Intent(AntZipActivity.this,DozipActivity.class);         i.putExtra(TYPE, isZip?TYPE_ZIP:TYPE_TAR);         AntZipActivity.this.startActivity(i);       }     });     btnDecompress = (Button)findViewById(R.id.button2);     btnDecompress.setOnClickListener(new OnClickListener() {              @Override       public void onClick(View v) {         //進(jìn)入解壓界面          Intent i = new Intent(AntZipActivity.this,UnzipActivity.class);         i.putExtra(TYPE, isZip?TYPE_ZIP:TYPE_TAR);         AntZipActivity.this.startActivity(i);       }     });   } } 

DozipActivity:

public class DozipActivity extends Activity implements OnClickListener{   private EditText etPath;   private EditText etDest;   private Button btnDozip;   private TextView  tvTip;      private String srcPath;   private String zipDest;      private int   type;   private String suffix;   @Override   public void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);     setTitle("Ant-壓縮");     type = getIntent().getIntExtra(AntZipActivity.TYPE, AntZipActivity.TYPE_ZIP);     suffix = type==AntZipActivity.TYPE_ZIP ? AntZipActivity.SUFFIX_ZIP:AntZipActivity.SUFFIX_TAR;     setContentView(R.layout.dozip);     //     etPath = (EditText)findViewById(R.id.editText1);     etDest = (EditText)findViewById(R.id.editText2);     //設(shè)置一些默認(rèn)的函數(shù)     etPath.setText("/sdcard/antzip");     etDest.setText("/sdcard/antzip"+suffix);     btnDozip = (Button)findViewById(R.id.button);     tvTip  = (TextView)findViewById(R.id.tv_tip);     btnDozip.setOnClickListener(this);   }   @Override   public void onClick(View v) {     srcPath = etPath.getEditableText().toString();     if(TextUtils.isEmpty(srcPath))     {       Toast.makeText(this, "請指定一個(gè)路徑", Toast.LENGTH_SHORT).show();       return;     }     File srcFile = new File(srcPath);     if(!srcFile.exists())     {       Toast.makeText(this, "指定的壓縮包不存在", Toast.LENGTH_SHORT).show();       return;     }     zipDest = etDest.getEditableText().toString();     if(TextUtils.isEmpty(zipDest))     {       //如果用戶沒有輸入目標(biāo)文件,則生成一個(gè)默認(rèn)的       zipDest = srcFile.getParent();     }     System.out.println("zip name:"+zipDest);     //如果是以/結(jié)尾的,則證明用戶輸入的是一個(gè)目錄 ,需要在后面加上文件名     if(zipDest.endsWith(File.separator))     {       zipDest+=srcFile.getName()+suffix;     }     else     {       //如果壓縮文件名不是以zip/tar結(jié)尾,則加上后綴后       if(!zipDest.endsWith(suffix))       {         zipDest +=suffix;       }     }     //如果用戶選擇的是zip,則用 zipUtil進(jìn)行壓縮     if(type == AntZipActivity.TYPE_ZIP)     {        ZipUtil zipp = new ZipUtil();       zipp.doZip(srcPath, zipDest);     }     //如果用戶選擇的是tar,則用 tarUtil進(jìn)行壓縮     else     {       TarUtil tarr = new TarUtil();       tarr.doTar(srcPath, zipDest);     }     //壓縮完成后還是提示用戶     tvTip.setText("壓縮文件路徑:"+zipDest);     Toast.makeText(this, "壓縮完成", Toast.LENGTH_SHORT).show();   } } 

解壓縮工具類ZipUtil:

public class ZipUtil {   private ZipFile     zipFile;    private ZipOutputStream zipOut;   //壓縮Zip    private int      bufSize;  //size of bytes    private byte[]     buf;     public ZipUtil(){     //要構(gòu)造函數(shù)中去初始化我們的緩沖區(qū)     this.bufSize = 1024*4;      this.buf = new byte[this.bufSize];    }        /**    * 對傳入的目錄或者是文件進(jìn)行壓縮    * @param srcFile 需要 壓縮的目錄或者文件    * @param destFile 壓縮文件的路徑    */   public void doZip(String srcFile, String destFile) {// zipDirectoryPath:需要壓縮的文件夾名     File zipFile = new File(srcFile);     try {       //生成ZipOutputStream,會(huì)把壓縮的內(nèi)容全都通過這個(gè)輸出流輸出,最后寫到壓縮文件中去       this.zipOut = new ZipOutputStream(new BufferedOutputStream(           new FileOutputStream(destFile)));       //設(shè)置壓縮的注釋       zipOut.setComment("comment");       //設(shè)置壓縮的編碼,如果要壓縮的路徑中有中文,就用下面的編碼       zipOut.setEncoding("GBK");       //啟用壓縮        zipOut.setMethod(ZipOutputStream.DEFLATED);         //壓縮級(jí)別為最強(qiáng)壓縮,但時(shí)間要花得多一點(diǎn)        zipOut.setLevel(Deflater.BEST_COMPRESSION);               handleFile(zipFile, this.zipOut,"");       //處理完成后關(guān)閉我們的輸出流       this.zipOut.close();     } catch (IOException ioe) {       ioe.printStackTrace();     }   }    /**    * 由doZip調(diào)用,遞歸完成目錄文件讀取    * @param zipFile    * @param zipOut    * @param dirName 這個(gè)主要是用來記錄壓縮文件的一個(gè)目錄層次結(jié)構(gòu)的    * @throws IOException    */   private void handleFile(File zipFile, ZipOutputStream zipOut,String dirName) throws IOException {     System.out.println("遍歷文件:"+zipFile.getName());     //如果是一個(gè)目錄,則遍歷     if(zipFile.isDirectory())     {       File[] files = zipFile.listFiles();        if (files.length == 0) {// 如果目錄為空,則單獨(dú)創(chuàng)建之.         //只是放入了空目錄的名字         this.zipOut.putNextEntry(new ZipEntry(dirName+zipFile.getName()+File.separator));         this.zipOut.closeEntry();       } else {// 如果目錄不為空,則進(jìn)入遞歸,處理下一級(jí)文件         for (File file : files) {           // 進(jìn)入遞歸,處理下一級(jí)的文件           handleFile(file, zipOut, dirName+zipFile.getName()+File.separator);         }       }     }     //如果是文件,則直接壓縮     else     {       FileInputStream fileIn = new FileInputStream(zipFile);       //放入一個(gè)ZipEntry       this.zipOut.putNextEntry(new ZipEntry(dirName+zipFile.getName()));       int length = 0;       //放入壓縮文件的流       while ((length = fileIn.read(this.buf)) > 0) {         this.zipOut.write(this.buf, 0, length);       }       //關(guān)閉ZipEntry,完成一個(gè)文件的壓縮       this.zipOut.closeEntry();     }        }    /**    * 解壓指定zip文件    * @param unZipfile 壓縮文件的路徑    * @param destFile   解壓到的目錄     */   public void unZip(String unZipfile, String destFile) {// unZipfileName需要解壓的zip文件名     FileOutputStream fileOut;     File file;     InputStream inputStream;      try {       //生成一個(gè)zip的文件       this.zipFile = new ZipFile(unZipfile);       //遍歷zipFile中所有的實(shí)體,并把他們解壓出來       for (@SuppressWarnings("unchecked")       Enumeration<ZipEntry> entries = this.zipFile.getEntries(); entries           .hasMoreElements();) {         ZipEntry entry = entries.nextElement();         //生成他們解壓后的一個(gè)文件         file = new File(destFile+File.separator+entry.getName());          if (entry.isDirectory()) {           file.mkdirs();         } else {           // 如果指定文件的目錄不存在,則創(chuàng)建之.           File parent = file.getParentFile();           if (!parent.exists()) {             parent.mkdirs();           }           //獲取出該壓縮實(shí)體的輸入流           inputStream = zipFile.getInputStream(entry);            fileOut = new FileOutputStream(file);           int length = 0;           //將實(shí)體寫到本地文件中去           while ((length = inputStream.read(this.buf)) > 0) {             fileOut.write(this.buf, 0, length);           }           fileOut.close();           inputStream.close();         }       }       this.zipFile.close();     } catch (IOException ioe) {       ioe.printStackTrace();     }   } } 

Ant 實(shí)現(xiàn)批量打包Android應(yīng)用
由于公司運(yùn)維需要以及應(yīng)用中需要加上應(yīng)用推廣的統(tǒng)計(jì),往往要對應(yīng)二三十個(gè)渠道,按照正常方法一個(gè)一個(gè)的去生成不同渠道包的應(yīng)用,不僅浪費(fèi)了時(shí)間,而且大大降低了效率.
上一篇講到使用Ant進(jìn)行Zip/Tar包的解壓縮,實(shí)際上Ant工具不僅僅具有此類功能,它更強(qiáng)大的地方在于自動(dòng)化調(diào)用程序完成項(xiàng)目的編譯,打包,測試等. 類似于C語言中的make腳本完成這些工作的批處理任務(wù). 不同于MakeFile的是,Ant是純Java編寫的,因此具有很好的跨平臺(tái)性.

在此我主要講下如何自動(dòng)構(gòu)建工具Ant, 對應(yīng)用進(jìn)行批量打包, 生成對應(yīng)不同市場的應(yīng)用:

首先分別看一下用于打包的Java工程AntTest和需要被打包進(jìn)行發(fā)布的Android工程結(jié)構(gòu):

2016226144512430.jpg (519×200)

2016226144528909.jpg (537×356)

market.txt里保存需要打包的市場標(biāo)識(shí),如:

youmenggfan.......

此文件里自行根據(jù)需求添加渠道名稱.

然后看一下實(shí)現(xiàn)批量打包AntTest類中的內(nèi)容:
注意:紅色標(biāo)注部分需要進(jìn)行修改:

package com.cn.ant;  import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Calendar;  import org.apache.tools.ant.DefaultLogger; import org.apache.tools.ant.Project; import org.apache.tools.ant.ProjectHelper;  public class AntTest {   private Project project;    public void init(String _buildFile, String _baseDir) throws Exception {     project = new Project();      project.init();      DefaultLogger consoleLogger = new DefaultLogger();     consoleLogger.setErrorPrintStream(System.err);     consoleLogger.setOutputPrintStream(System.out);     consoleLogger.setMessageOutputLevel(Project.MSG_INFO);     project.addBuildListener(consoleLogger);      // Set the base directory. If none is given, "." is used.     if (_baseDir == null)       _baseDir = new String(".");      project.setBasedir(_baseDir);      if (_buildFile == null)       _buildFile = new String(projectBasePath + File.separator           + "build.xml");      // ProjectHelper.getProjectHelper().parse(project, new     // File(_buildFile));     <span style="color:#FF0000;">// 關(guān)鍵代碼</span>     ProjectHelper.configureProject(project, new File(_buildFile));   }    public void runTarget(String _target) throws Exception {     // Test if the project exists     if (project == null)       throw new Exception(           "No target can be launched because the project has not been initialized. Please call the 'init' method first !");     // If no target is specified, run the default one.     if (_target == null)       _target = project.getDefaultTarget();      // Run the target     project.executeTarget(_target);    }    <span style="color:#FF0000;">private final static String projectBasePath = "D://android//workspace3//XXX";//要打包的項(xiàng)目根目錄   private final static String copyApkPath = "D://android//apktest";//保存打包apk的根目錄   private final static String signApk = "XXX-release.apk";//這里的文件名必須是準(zhǔn)確的項(xiàng)目名!   private final static String reNameApk = "XXX_";//重命名的項(xiàng)目名稱前綴(地圖項(xiàng)目不用改)   private final static String placeHolder = "@market@";//需要修改manifest文件的地方(占位符) </span>   public static void main(String args[]) {     long startTime = 0L;     long endTime = 0L;     long totalTime = 0L;     Calendar date = Calendar.getInstance();     SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd:HH:mm:ss");     try {       System.out.println("---------ant批量自動(dòng)化打包開始----------");       startTime = System.currentTimeMillis();       date.setTimeInMillis(startTime);       System.out.println("開始時(shí)間為:" + sdf.format(date.getTime()));        BufferedReader br = new BufferedReader(new FileReader("market.txt"));       String flag = null;       while ((flag = br.readLine()) != null) {          // 先修改manifest文件:讀取臨時(shí)文件中的@market@修改為市場標(biāo)識(shí),然后寫入manifest.xml中         String tempFilePath = projectBasePath + File.separator             + "AndroidManifest.xml.temp";         String filePath = projectBasePath + File.separator             + "AndroidManifest.xml";         write(filePath, read(tempFilePath, flag.trim()));         // 執(zhí)行打包命令         AntTest mytest = new AntTest();         mytest.init(projectBasePath + File.separator + "build.xml",             projectBasePath);         mytest.runTarget("clean");         mytest.runTarget("release");         // 打完包后執(zhí)行重命名加拷貝操作         File file = new File(projectBasePath + File.separator + "bin"             + File.separator + signApk);// bin目錄下簽名的apk文件                  File renameFile = new File(copyApkPath + File.separator + reNameApk             + flag + ".apk");         boolean renametag = file.renameTo(renameFile);         System.out.println("rename------>"+renametag);         System.out.println("file ------>"+file.getAbsolutePath());         System.out.println("rename------>"+renameFile.getAbsolutePath());       }       System.out.println("---------ant批量自動(dòng)化打包結(jié)束----------");       endTime = System.currentTimeMillis();       date.setTimeInMillis(endTime);       System.out.println("結(jié)束時(shí)間為:" + sdf.format(date.getTime()));       totalTime = endTime - startTime;       System.out.println("耗費(fèi)時(shí)間為:" + getBeapartDate(totalTime));      } catch (Exception e) {       e.printStackTrace();       System.out.println("---------ant批量自動(dòng)化打包中發(fā)生異常----------");       endTime = System.currentTimeMillis();       date.setTimeInMillis(endTime);       System.out.println("發(fā)生異常時(shí)間為:" + sdf.format(date.getTime()));       totalTime = endTime - startTime;       System.out.println("耗費(fèi)時(shí)間為:" + getBeapartDate(totalTime));     }   }    /**    * 根據(jù)所秒數(shù),計(jì)算相差的時(shí)間并以**時(shí)**分**秒返回    *    * @param d1    * @param d2    * @return    */   public static String getBeapartDate(long m) {     m = m / 1000;     String beapartdate = "";     int nDay = (int) m / (24 * 60 * 60);     int nHour = (int) (m - nDay * 24 * 60 * 60) / (60 * 60);     int nMinute = (int) (m - nDay * 24 * 60 * 60 - nHour * 60 * 60) / 60;     int nSecond = (int) m - nDay * 24 * 60 * 60 - nHour * 60 * 60 - nMinute         * 60;     beapartdate = nDay + "天" + nHour + "小時(shí)" + nMinute + "分" + nSecond + "秒";      return beapartdate;   }    public static String read(String filePath, String replaceStr) {     BufferedReader br = null;     String line = null;     StringBuffer buf = new StringBuffer();      try {       // 根據(jù)文件路徑創(chuàng)建緩沖輸入流       br = new BufferedReader(new FileReader(filePath));        // 循環(huán)讀取文件的每一行, 對需要修改的行進(jìn)行修改, 放入緩沖對象中       while ((line = br.readLine()) != null) {         // 此處根據(jù)實(shí)際需要修改某些行的內(nèi)容         if (line.contains(placeHolder)) {           line = line.replace(placeHolder, replaceStr);           buf.append(line);         } else {           buf.append(line);         }         buf.append(System.getProperty("line.separator"));       }     } catch (Exception e) {       e.printStackTrace();     } finally {       // 關(guān)閉流       if (br != null) {         try {           br.close();         } catch (IOException e) {           br = null;         }       }     }      return buf.toString();   }    /**    * 將內(nèi)容回寫到文件中    *    * @param filePath    * @param content    */   public static void write(String filePath, String content) {     BufferedWriter bw = null;      try {       // 根據(jù)文件路徑創(chuàng)建緩沖輸出流       bw = new BufferedWriter(new FileWriter(filePath));       // 將內(nèi)容寫入文件中       bw.write(content);     } catch (Exception e) {       e.printStackTrace();     } finally {       // 關(guān)閉流       if (bw != null) {         try {           bw.close();         } catch (IOException e) {           bw = null;         }       }     }   } } 


然后是Android工程中需要進(jìn)行修改的部分:

1. 修改local.properties中的sdk根目錄:

  sdk.dir=D://android//android-sdk-windows-r17//android-sdk-windows-r17

2. 修改ant.properties中簽名文件的路徑和密碼(如果需要)

  key.store=D://android//mykeystore  key.store.password=123456  key.alias=mykey  key.alias.password=123456

3. 修改AndroidManifest.xml.temp
    拷貝AndroidManifest.xml一份,命名為AndroidManifest.xml.temp
    將需要替換的地方改為占位符,需與打包工程AntTest中的placeHolder常量一致
  如: <meta-data android:value="@market@" android:name="UMENG_CHANNEL"/>
4. Build.xml中:
    <project name="XXX" default="help">,XXX必須為Android工程名稱.

如果機(jī)器沒有配置過Ant環(huán)境變量,可根據(jù)如下步驟進(jìn)行配置:

ANT環(huán)境變量設(shè)置:

Windows下ANT用到的環(huán)境變量主要有2個(gè),ANT_HOME 、PATH。

設(shè)置ANT_HOME指向ant的安裝目錄。

設(shè)置方法:

ANT_HOME = D:/apache_ant_1.7.0

將%ANT_HOME%/bin; %ANT_HOME%/lib添加到環(huán)境變量的path中。

設(shè)置方法:

PATH = %ANT_HOME%/bin; %ANT_HOME%/lib 

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
18岁成年人网站| 国产精品theporn88| 婷婷六月综合亚洲| 国产精品∨欧美精品v日韩精品| 黄色网免费观看| 欧美老女人性开放| 欧美日韩xxx| 天堂在线观看一卡二卡三卡四卡| 播九公社成人综合网站| 领导边摸边吃奶边做爽在线观看| 欧美唯美清纯偷拍| 成人免费福利片| 久久免费一区| 久久精品在这里| 国产人成在线观看| 国产精品久久久久久av公交车| 全部免费的黄色毛片| 精品国产一区二区三区噜噜噜| 日韩不卡视频在线观看| 久久久男人天堂| 91综合久久爱com| 国产成人97精品免费看片| 中文字幕乱码人妻二区三区| 日韩精品中文字幕第1页| 波多野结衣中文字幕在线| 欧美日韩精品欧美日韩精品一综合| 国精产品一区一区三区有限在线| 色综合久久九月婷婷色综合| 国产高清欧美| 亚洲麻豆av| 国产在视频一区二区三区吞精| 日韩av在线直播| 国产真实夫妇交换视频| 日本不卡不卡| 一区二区三区播放| 成人av电影在线播放| 国产精品久久久久久久久久久久久| 欧美日韩国产探花| 国产剧情在线观看一区| 一级片免费视频| 奇米精品一区二区三区四区| 欧美日韩aaa| 欧美剧情电影在线观看完整版免费励志电影| 国产欧美日韩不卡| 久久婷婷国产综合精品青草| 日本美女久久久| 久久精品日产第一区二区三区乱码| 欧美一站二站| jjzzjjzz欧美69巨大| 亚洲va韩国va欧美va精品| 亚洲欧美中文日韩在线| 四虎884aa成人精品最新| 超碰免费公开在线| 欧美日韩亚洲激情| 美女网站视频一区| 国产精品第二页| 九色在线网站| 四虎永久免费在线观看| 久久这里有精品| 亚洲成人资源网| 亚洲国产高清在线观看| 国产精品爽爽ⅴa在线观看| 天堂在线观看视频观看www| 尤物视频在线观看视频| 992tv在线观看在线播放| 女女调教被c哭捆绑喷水百合| 亚洲综合视频在线播放| 97精品人妻一区二区三区蜜桃| 进去里视频在线观看| 国产精品jizz视频| 在线观看免费国产成人软件| 91片在线免费观看| 国产精品二三区| 日本乱码一区二区三区不卡| av有声小说一区二区三区| www.99.热| 一二三四日本中文字幕| 黄色片免费在线观看视频| 国产精品国产三级国产普通话99| 青草青青在线视频| 美国三级日本三级久久99| 国产亚洲激情在线| 欧美高清电影在线看| 日韩欧美一级二级三级| 婷婷夜色潮精品综合在线| 欧美色图在线视频| 亚洲视频在线网| 日本理论片2828理论片| 日韩在线视频免费观看高清中文| 久久精品高清| 中文字幕在线资源| 丝袜脚交免费网站xx| 国产在线一区二区三区播放| 夜夜春很很躁夜夜躁| 综合激情在线| 欧美在线导航| 亚洲高清在线视频| 国产麻豆精品久久一二三| 中文字幕日韩精品有码视频| 国产美女娇喘av呻吟久久| 免费无码毛片一区二三区| 久久久久久网址| 国产一区二区在线|播放| 这里只有精品视频在线观看| 51精品在线观看| 国产精品国产三级国产在线观看| 先锋欧美三级| 99热久久这里只有精品| 国产免费无遮挡吸奶头视频| 欧美日韩精品一区二区在线播放| 中文字幕一区在线| 亚洲理论中文字幕| 成人福利片在线| 国产精品久久一卡二卡| 精品国产欧美日韩一区二区三区| 亚洲精品aⅴ中文字幕乱码| 神马久久久久久久久久久| 色网在线播放| 中文在线播放一区二区| 久久天堂国产精品| 亚洲国产精品久久久久婷婷软件| 欧美禁忌电影| 午夜激情福利在线| 欧美精品卡一卡二| 日本一区二区三区免费视频| 国产一区二区三区免费观看在线| 狠狠色噜噜狠狠狠8888米奇| 欧美亚洲另类色图| 成人做爰视频www| 无码无遮挡又大又爽又黄的视频| 国产福利精品视频| 亚洲欧美中文在线视频| 天天干天天曰天天操| 午夜诱惑痒痒网| 老司机精品福利在线观看| 91观看网站| 在线观看国产精品淫| 男人天堂av网站| 一本一道久久综合狠狠老精东影业| 色一情一乱一区二区| 欧美丰满高潮xxxx喷水动漫| 一区二区三视频| 国产xxxxxx| 一级肉体全黄裸片| 又粗又大的机巴好爽欧美| 久操视频在线免费观看| 秋霞成人午夜鲁丝一区二区三区| zjzjzjzjzj亚洲女人| 日本精品免费在线观看| 婷婷社区五月天| 日韩城人网站| 91高清视频免费| 99久久久久国产精品| 免费一级淫片aaa片毛片a级| 无码一区二区三区在线观看| 中文字幕久久久久久久| 国产私拍一区| 日韩中文字幕国产精品| 另类一区二区| 国产丝袜一区二区三区免费视频| 免费黄色av网址| 在线观看一级片| 97超级碰在线看视频免费在线看| 蜜桃传媒一区二区亚洲av| x99av成人免费| 成人福利片网站| 国产尤物在线播放| 国产成人午夜片在线观看高清观看| 99视频高清| 国产老肥熟xxxx在线观看| 超碰在线人人干| 99re视频在线播放| 99久久综合| 成人软件在线观看| 久久久爽爽爽美女图片| 国产又大又黄的视频| 3d成人动漫在线| 欧美日韩中文字幕日韩欧美| 岛国精品一区| 免费一级片91| 日本久久国产| 成人羞羞视频免费看看| 欧美区视频在线观看| 亚洲一区二区三区综合| 欧美黑人性受xxxx精品| 亚洲一线在线观看| 97精品久久| 五月天网站亚洲| 精品无码黑人又粗又大又长| 免费在线毛片网站| 久久99精品久久久久子伦| 亚洲一区视频在线观看视频| 日韩在线你懂得| 亚洲色图校园春色| 亚洲天堂2020| 这里只有视频精品| 一个人看的视频www在线观看免费| 老鸭窝亚洲一区二区三区| 国产精品久久久久久久妇| 熟妇无码乱子成人精品| 国产风韵犹存在线视精品| 国产日韩欧美在线播放不卡| av色综合网| 精品国产乱码久久久久久鸭王1| 欧洲精品在线视频| 色在线免费观看| www.成人黄色| 久久99蜜桃综合影院免费观看| 91免费视频黄| 久久久综合色| av播放官网| 亚洲综合丁香| 亚洲欧美激情诱惑| 中文字幕亚洲一区二区va在线| 欧美亚洲国产成人| 亚洲色图视频免费播放| 99视频免费播放| 国产精品免费网站在线观看| 国产午夜精品美女视频明星a级| 亚洲另类第一页| 欧美第十八页| 久久精品男人的天堂| 亚洲国产无线乱码在线观看| 老司机2019福利精品视频导航| 欧美专区一区二区三区| 妞干网这里只有精品| 欧美专区日韩视频| 国产精品丝袜一区| 国产女人18水真多18精品一级做| 日韩精品在线私人| 中文字幕欧美日韩一区| 男人的天堂久久久| 国产不卡一区视频| 黄色一级视频在线播放| 欧美午夜性色大片在线观看| 亚洲精品国精品久久99热| 5g影院5g天天爽永久免费影院| 国产欧美久久久| 青青草视频在线视频| 在线电影欧美日韩一区二区私密| 精品久久久久久久久久久下田| 日日噜噜噜噜人人爽亚洲精品| 国产欧美一区二区三区另类精品| 经典三级在线视频| 国产欧美在线观看视频| av免费观看不卡| 91在线短视频| 97在线视频免费观看完整版| 国产伦精品一区二区三区88av| 日本爱爱小视频| 欧美精品乱人伦久久久久久| 欧美激情福利视频在线观看免费| 国产亚洲欧美一区二区三区| 精品国产一区二区三区久久久樱花| 97超碰免费在线观看| 老头老太做爰xxx视频| 九九久久九九| 亚洲婷婷综合色高清在线| 日韩欧美中文免费| 国产一区一区| 九九九九九国产| 久久精品国产亚洲av麻豆蜜芽| 亚洲精品www| 老师我好爽再深一点的视频| 成人婷婷网色偷偷亚洲男人的天堂| 欧美a极品极品欧美| 88av在线播放| 国产三级精品三级在线观看国产| 天堂视频福利| 日本中文字幕一区二区视频| 亚洲国产aⅴ精品一区二区三区| 成年男人的天堂| 免费看黄色的视频| 国产精品99久久久久久久vr| 成人综合视频在线| 亚洲精品国产精品国自产网站按摩| 久久这里只有精品99| 日韩国产91| 国产一区二区按摩在线观看| 亚洲欧洲国产日本综合| 91精品综合久久| 国产精品麻豆入口| 久久精品国产精品亚洲精品| 欧美日韩一区二区欧美激情| 一区二区三区亚洲变态调教大结局| 国产欧美一区二区三区在线看蜜臀| www免费在线观看| 成人小视频在线| 亚洲va天堂va欧美ⅴa在线| 91麻豆福利精品推荐| 国产麻豆永久视频| 日韩av电影中文字幕| 欧美a视频在线| 国产精品久久久久久久久久99| 妞干网在线观看| 男人添女人下面免费视频| 91在线观看免费视频| 国产成人一区二区三区小说| 97色在线视频| 91成人在线网站| 精品av综合导航| av中文字幕在线不卡| 精品国产一区二区三区久久久狼| 最近中文字幕无免费| 成人毛片视频网站| 四虎亚洲成人| 久久不见久久见国语| 婷婷五月综合缴情在线视频| 亚洲欧美福利一区二区| 99综合在线| 日韩有码第一页| 日韩av网站在线免费观看| 综合久久给合久久狠狠狠97色| 很黄的网站在线观看| 久久精品电影一区二区| 一区三区视频| 久久精品欧美日韩精品| 久久久久久一区二区三区四区别墅| 日韩美女av在线| 男人的天堂视频网站| 黄页视频在线观看| 亚洲精品色婷婷福利天堂| 91精品免费观看| 亚洲精品一区中文字幕电影| 97人妻精品一区二区三区免费| 久久国产色av| 自拍视频网站| 欧美日韩的一区二区|