青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

life02

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  197 隨筆 :: 3 文章 :: 37 評論 :: 0 Trackbacks
http://apps.hi.baidu.com/share/detail/43342917
 

看到同事都用來“自動重播”軟件來訂火車票了,我也下載一個來看看,下載回來反編譯一下看看,好像有廣告的啊,有一個好像是Google的還是那個廣告類在里面。索性自己弄一個好了,現在吸金軟件很多啊,自己編譯的才放心,呵呵!代碼不多,又有反編譯過來的代碼作為才看,雖然反編譯過來好像有的小地方不是很對,不過代碼邏輯還大概看得出來的,然后自己看了下Android SDK的文檔,Google了兩下,大概可以弄個出來。就是那個鬼模擬器和Eclipse太好資源了。在我的機器上幾乎跑不動了,浪費點時間。當然看Android SDK文檔理解一下基本概念也花了不少時間。

        不過很悲劇啊,早上起來快9點了,然后我用軟件一撥進去了,結果我搞錯時間了,以為還沒到我要買的日期就退了出來。等過一會再撥的時候票已經賣完了,有同事說是分時間段放票出來的,再試試看或者有
"軟a臥"也買了。

 

來看程序吧:

        整個程序的代碼邏輯很簡單,就是先啟動一個activity界面給用戶輸入,然后啟動一個后臺service不停的自動撥打相應的號碼,直到撥通為止。Android下面相應的關鍵功能實現代碼:

1. 撥打電話

通過Intent.ACTION_CALL 來請求系統的撥號Activity就可以了。在Android系統里面一個 Intent其實就相當于一條消息,然后系統就會自動根據的你的請求去找相應的功能模塊比如說package里面的那個類來加載了。應用都事先注冊了說我自己能夠接受那些Intent的。撥打電話也有他的一個Intent 就是 Intent.ACTION_CALL ,其他的發送短信啊那些也有其他的,自己看下文檔就知道了。

‍ 
private void PhoneCall()
 {
  
try {
   Thread.sleep(
2000);
  } 
catch (InterruptedException e) {
   
// TODO Auto-generated catch block
   e.printStackTrace();
  }
  mJustCall 
= false;
     Uri localUri 
= Uri.parse("tel:" + mPhoneNumber);
     Intent call 
= new Intent(Intent.ACTION_CALL, localUri);
     call.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);;
     startActivity(call);
     
//android.util.Log.v("TeleListener", "start to call"); 
     mDialedCount ++;
 }

注意這個功能要android.permission.CALL_PHONE的權限才能使用,所以要在AndroidManifest.xml 文件后面加上這句

<uses-permission android:name="android.permission.CALL_PHONE"></uses-permission>

安裝程序的時候,有什么“需要收費的服務什么的”提示就是這條了。

 

2. 手機通話狀態的查詢  

     這個程序還有一個功能就是能夠判斷手機是不是正在撥號啊通話啊,才好控制自動重播的。這個Android有通知事件過來的,就像以前的“位置感應
"事件一樣,只要你注冊了這個通知事件,手機狀態變化的時候就自動調用你Listener了。不過Android手機這個事件沒法區分“撥號”和“通話”這兩個狀態的,這兩者統一都是TelephonyManager.CALL_STATE_OFFHOOK狀態,TelephonyManager.CALL_STATE_RINGING指的是外面撥進來的響鈴吧。不過你看他系統里面其實是可以區分“撥號”和“通話”這兩個狀態的,打通了他就開始計時,界面也顯示“正在通話”,只是它沒有向外部應用開放這個接口而已。可以去看Android源碼的packages/apps/Phone/src/com/android/phone/ 下面的InCallScreen.java  CallCard.java 等文件。鑒于我們的“xxxxx”,可以到http://www.netmite.com/android/mydroid/packages/apps/Phone/src/com/android/phone/  這里去看吧,網上好像有很多提供在線源碼的

http:
//hi-android.info/src/com/android/phone/ 

 http:
//gitorious.org/0xdroid/packages_apps_phone/trees/5f6f01ecda4336dfb47108e67ff909a65f14b820/src/com/android/phone

另外監a聽這個事件需要權限
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>

其實網上那些軟件比如說“別人大個電話過來播放隨機鈴聲”應該也是通過這個來做到的吧。

     TelephonyManager telephonyMgr 
= (TelephonyManager)getSystemService("phone");
     TeleListener teleListener 
= new TeleListener(this);
     telephonyMgr.listen(teleListener, 
0);

 

 
class TeleListener extends PhoneStateListener {
  
private AutoRedialService manager;
     
public TeleListener(AutoRedialService a)
     {
       
this.manager = a;
     }
  @Override
  
public void onCallStateChanged(int state, String incomingNumber) {
   
super.onCallStateChanged(state, incomingNumber);
   
switch (state) {
   
// 當處于待機狀態中
   case TelephonyManager.CALL_STATE_IDLE: {
    manager.Log(
"IDLE");
    
//android.util.Log.v("TeleListener", "IDLE"); 
    if (manager.ShouldStop() || manager.LastCallSucceed()) {         
     manager.stopSelf();  
     
break;
    }            
    PhoneCall();    
    
break;
   }
    
// 當處于正在撥號出去,或者正在通話中
   case TelephonyManager.CALL_STATE_OFFHOOK: {
    manager.Log(
"OFFHOOK");
    
//android.util.Log.v("TeleListener", "OFFHOOK"); 
    mJustCall = true;
    
//Timer t = new Timer(); 
    break;
   }
    
// 外面撥進來,好沒有接撥號狀態中..
   case TelephonyManager.CALL_STATE_RINGING: {
    manager.Log(
"RINGING");
    
//android.util.Log.v("TeleListener", "RINGING"); 
    break;
   }
   
default:
    
break;
   }
  }

 

 

 
3"通一話一記一錄"查詢   (媽的這都是關鍵詞啊,搞我半天發不上了)

上面說了不能區分
"接通"與“撥號”狀態,所以我想到的辦法只有撥完之后再去查看最近的通話記錄了,如果最后一條記錄的通話時間是大于0的,說明就撥通了,就不需要再重播了。這個用起來還可以,程序撥通就給我退出了。在Android里面這個信息需要向“content provider內a容提供者”去要,其實就是類似查詢數據庫,可以查、增、減之類的,自己的程序也可以提供這種接口供別人查詢。注意這個也需要權a限

<uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>
 我一開始不知道,結果用那個蝸牛一樣模擬器調試了半天才調試出來。

 
private boolean LastCallSucceed ()
 {
 
  
if ( mJustCall == false) {
        
return false;
  } 
 
  String[] projection 
= new String[] {
        Calls.NUMBER,
        Calls.DURATION
    };
 
  ContentResolver cr 
= getContentResolver();
  
final Cursor cur = cr.query(android.provider.CallLog.Calls.CONTENT_URI,
    projection,
    
null,
    
null,
    Calls.DEFAULT_SORT_ORDER);
   
if (cur.moveToFirst()) {
   
int duration = cur.getInt(1);
   
//上次通話時間
   if (duration > 0 )
   {  
    
//android.util.Log.v("TeleListener", "|"+ String.valueOf(duration) + "|");
    
//Log( "|"+ String.valueOf(duration) + "|");
    return true;
   }
      }
 
  
return false;
 }

 

4. Activity 和Service直接的通訊

在Android里面activity和service是分別屬于兩個不同的進程的,要兩者交互還挺麻煩的,按照文檔說法,要實現bindservice等大堆接口,弄起來挺麻煩的,我這一個這么小玩意就算了吧。偷看了一下反編譯的出來的代碼,里面啟動service的時候,activity發送出去Intent消息攜帶多一點信息過去,然后在service里面可以讀出來,但是service想傳點數據回activity就不行了。這種簡單的辦法也夠用了,還有朋友發現什么簡單辦法可以告訴我一下。

在 activity中

 
public void onClick(View v) {

     
switch (v.getId()) {

     
case R.id.Button_Start:
      Intent msg 
= new Intent(this, AutoRedialService.class);
         EditText pnumEdit 
= (EditText) findViewById(R.id.EditText_phoneNumber);
         EditText retryEdit 
= (EditText)findViewById(R.id.EditText_RetryCount);
         String phoneNumber 
=  pnumEdit.getText().toString();
         Integer i 
= Integer.decode(retryEdit.getText().toString());
      
int retryCount = i.intValue();
         msg.putExtra(
"RetryCount", retryCount);
      msg.putExtra(
"PhoneNumber",phoneNumber);
      
//retryEdit.setText(String.valueOf(retryCount-1));
      startService(msg);

 

然后在service啟動的時候可以讀出來

 
public void onStart(Intent intent, int startID) {
  
super.onStart(intent, startID);
  mRetryCount 
= intent.getIntExtra("RetryCount"0);
  String tmp  
= intent.getStringExtra("PhoneNumber");
  
if (tmp != null)
  {
   mPhoneNumber 
= tmp; 
  }

 

寫完之后,我發程序發到我的手機上去試了一下,好像還行啊,有時需要撥幾十次才能打通電話,呵呵,真是省去不少功夫了。有點小問題,有時想停止的時候,不那么好控制,我把重撥間隔定為2秒了,要操作的很快才行啊。還有就是那個“撥號”“通話”兩種狀態的變化,感覺可以去讀取撥號程序的界面來判斷,如果能夠找到那個activity的實例,然后就好辦了再findViewById就可以讀出上面控件的狀態了。不過android好像很難獲取別的activity的實例,即使這個應用是自己的同一個application啟動起來的。看文檔好像通過android 測試接口Instrumentation  下面的的activitymonitor什么也許可以獲取的 到其他activity的實例,不過我沒有去試,這個需要建一個“android測試”項目然后從那開始吧。

 

完整的代碼

================AutoRedialService。java================================

package widebright.AutoRedial;

import java.util.Timer;

import android.app.Service;
import android.content.ContentResolver;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.IBinder;
import android.provider.CallLog.Calls;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;

public class AutoRedialService extends Service {
    
private int mRetryCount = 0;
    
private int mDialedCount = 0;
 
private String mPhoneNumber= "10086";
 
private String mDebugLog = "";
 
private boolean mJustCall = false;
 
    
public void Log (String text){
     
//mDebugLog += text;
    }       
   
 @Override
 
public IBinder onBind(Intent msg) {
  
// 使用 bind的辦法,可以方便的在service和
  
//activity兩個不同的進程直接交互,不過看代碼很多啊
 
  
return null;
 
 }
 
 
private void PhoneCall()
 {
  
try {
   Thread.sleep(
2000);
  } 
catch (InterruptedException e) {
   
// TODO Auto-generated catch block
   e.printStackTrace();
  }
  mJustCall 
= false;
     Uri localUri 
= Uri.parse("tel:" + mPhoneNumber);
     Intent call 
= new Intent(Intent.ACTION_CALL, localUri);
     call.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);;
     startActivity(call);
     
//android.util.Log.v("TeleListener", "start to call");
     mDialedCount ++;
 }
 
 
private  boolean ShouldStop()
 {
  
return  mDialedCount > mRetryCount;
 }
 
 
private boolean LastCallSucceed ()
 {
 
  
if ( mJustCall == false) {
        
return false;
  } 
 
  String[] projection 
= new String[] {
        Calls.NUMBER,
        Calls.DURATION
    };
 
  ContentResolver cr 
= getContentResolver();
  
final Cursor cur = cr.query(android.provider.CallLog.Calls.CONTENT_URI,
    projection,
    
null,
    
null,
    Calls.DEFAULT_SORT_ORDER);
   
if (cur.moveToFirst()) {
   
int duration = cur.getInt(1);
   
//上次通話時間
   if (duration > 0 )
   {  
    
//android.util.Log.v("TeleListener", "|"+ String.valueOf(duration) + "|");
    
//Log( "|"+ String.valueOf(duration) + "|");
    return true;
   }
      }
 
  
return false;
 }
   
public void onCreate()
   {
     
super.onCreate();
   }

 
public void onStart(Intent intent, int startID) {
  
super.onStart(intent, startID);
  
//android.util.Log.v("TeleListener", "starting haha");
  
// 獲取電話管理的一個類實例
  mRetryCount = intent.getIntExtra("RetryCount"0);
  String tmp  
= intent.getStringExtra("PhoneNumber");
  
if (tmp != null)
  {
   mPhoneNumber 
= tmp; 
  }
 
  TelephonyManager telephonyMgr 
= (TelephonyManager) this
    .getSystemService(Context.TELEPHONY_SERVICE);

  
// 建立一個監聽器來實時監聽電話的通話狀態
  telephonyMgr.listen(new TeleListener(this),
    PhoneStateListener.LISTEN_CALL_STATE);

 
  mDialedCount 
= 0;
  
//PhoneCall();

 }

 
public void onDestroy()
 {
     TelephonyManager telephonyMgr 
= (TelephonyManager)getSystemService("phone");
     TeleListener teleListener 
= new TeleListener(this);
     telephonyMgr.listen(teleListener, 
0);
     mDialedCount 
= 0;
     mRetryCount 
= 0;
     mPhoneNumber
= "10086";
     
super.onDestroy();
 }
  
 
class TeleListener extends PhoneStateListener {
  
private AutoRedialService manager;
     
public TeleListener(AutoRedialService a)
     {
       
this.manager = a;
     }
  @Override
  
public void onCallStateChanged(int state, String incomingNumber) {
   
super.onCallStateChanged(state, incomingNumber);
   
switch (state) {
   
// 當處于待機狀態中
   case TelephonyManager.CALL_STATE_IDLE: {
    manager.Log(
"IDLE");
    
//android.util.Log.v("TeleListener", "IDLE");
    if (manager.ShouldStop() || manager.LastCallSucceed()) {        
     manager.stopSelf(); 
     
break;
    }           
    PhoneCall();   
    
break;
   }
    
// 當處于正在撥號出去,或者正在通話中
   case TelephonyManager.CALL_STATE_OFFHOOK: {
    manager.Log(
"OFFHOOK");
    
//android.util.Log.v("TeleListener", "OFFHOOK");
    mJustCall = true;
    
//Timer t = new Timer(); 
    break;
   }
    
// 外面撥進來,好沒有接撥號狀態中..
   case TelephonyManager.CALL_STATE_RINGING: {
    manager.Log(
"RINGING");
    
//android.util.Log.v("TeleListener", "RINGING");
    break;
   }
   
default:
    
break;
   }
  }

 }
 
 
}


===============================main.java================================

package widebright.AutoRedial;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class main extends Activity implements OnClickListener {
 Button buttonStart, buttonStop;
    
/** Called when the activity is first created. */
    @Override
    
public void onCreate(Bundle savedInstanceState) {
        
super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
//EditText pnumEdit = (EditText) findViewById(R.id.EditText_phoneNumber);
        
//EditText retryEdit = (EditText)findViewById(R.id.EditText_RetryCount);
     
//retryEdit.setText("10");
      
       buttonStart 
= (Button) findViewById(R.id.Button_Start);
       buttonStop 
= (Button) findViewById(R.id.Button_Stop);
       buttonStart.setOnClickListener(
this);
       buttonStop.setOnClickListener(
this);
    }
    @Override
 
public void onClick(View v) {

     
switch (v.getId()) {

     
case R.id.Button_Start:
      Intent msg 
= new Intent(this, AutoRedialService.class);
         EditText pnumEdit 
= (EditText) findViewById(R.id.EditText_phoneNumber);
         EditText retryEdit 
= (EditText)findViewById(R.id.EditText_RetryCount);
         String phoneNumber 
=  pnumEdit.getText().toString();
         Integer i 
= Integer.decode(retryEdit.getText().toString());
      
int retryCount = i.intValue();
         msg.putExtra(
"RetryCount", retryCount);
      msg.putExtra(
"PhoneNumber",phoneNumber);
      
//retryEdit.setText(String.valueOf(retryCount-1));
      startService(msg);        
      
       
break;
     
case R.id.Button_Stop:
          stopService(
new Intent(this, AutoRedialService.class));
             
break;
         
default:
          
break;
     }
 }
   
   
   
}


=====================AutoRedialManifest.xm===========================================

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      
package="widebright.AutoRedial"
      android:versionCode
="1"
      android:versionName
="1.0">
    
<application android:icon="@drawable/icon" android:label="@string/app_name">
  
<activity android:name=".main" android:icon="@drawable/icon"
   android:label
="@string/app_name">
   
<intent-filter>
    
<action android:name="android.intent.action.MAIN" />
    
<category android:name="android.intent.category.LAUNCHER" />
   
</intent-filter>
  
</activity>

  
<service android:icon="@drawable/icon" android:label="@string/app_name"
   android:name
=".AutoRedialService">
  
</service>

    
</application>
    
<uses-sdk android:minSdkVersion="7" />
 
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
 
<uses-permission android:name="android.permission.CALL_PHONE"></uses-permission>
 
<uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>
 

</manifest>

 

 

============================layout/main.xml=============================

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation
="vertical" android:layout_width="fill_parent"
 android:layout_height
="fill_parent" android:layout_gravity="right">
 
<TextView android:layout_width="fill_parent"
  android:layout_height
="wrap_content"
  android:text
="@string/hello" />

 
<TextView android:text="@string/number"
           android:id
="@+id/TextView01"
        android:layout_width
="fill_parent"
        android:layout_height
="wrap_content">
 
</TextView>
 
<EditText android:layout_width="fill_parent"
        android:singleLine
="true"
        android:layout_height
="wrap_content"
        android:text
="10086"
           android:phoneNumber
="true"
           android:id
="@+id/EditText_phoneNumber">
           
</EditText>
 
<TextView android:text="@string/times"
           android:id
="@+id/TextView02"
        android:layout_width
="wrap_content"
        android:layout_height
="wrap_content">
        
</TextView>
 
<EditText android:layout_width="fill_parent"
        android:layout_height
="wrap_content"
        android:text
="100"
        android:id
="@+id/EditText_RetryCount"
        android:numeric
="integer"
        android:singleLine
="true"
        android:inputType
="number">
        
</EditText>


<LinearLayout android:id="@+id/LinearLayout01" android:layout_width="fill_parent" android:layout_height="wrap_content">
<Button android:text="@string/start"
        android:id
="@+id/Button_Start"
        android:layout_height
="wrap_content" android:layout_width="wrap_content" android:layout_gravity="left">
        
</Button>
<Button android:text="@string/stop"
        android:id
="@+id/Button_Stop"
        android:layout_height
="wrap_content" android:layout_gravity="right" android:layout_width="wrap_content">
        
</Button>
</LinearLayout>

</LinearLayout>


==========================================

 

 

 

再發兩個網上找到的小實例,沒有測試過

1. 模擬鍵盤按鍵

  
final IWindowManager windowManager = IWindowManager.Stub
               .asInterface(ServiceManager.getService(
"window"));

windowManager.injectchangerchangerKeyEvent(kEvent,
true);

2. 攔截撥打電話號碼操作

1.第一步,寫一個Receiver繼承自BroadcastReceiver
public class PhoneStatReceiver extends BroadcastReceiver{
       
        
private static final String TAG = "PhoneStatReceiver";
       
//        private static MyPhoneStateListener phoneListener = new MyPhoneStateListener();
       
        
private static boolean incomingFlag = false;
       
        
private static String incoming_number = null;

        @Override
        
public void onReceive(Context context, Intent intent) {
                
//如果是撥打電話
                if(intent.getAction().equals(Intent.ACTION_NEW_OUTGOING_CALL)){                       
                        incomingFlag 
= false;
                        String phoneNumber 
= intent.getStringExtra(Intent.EXTRA_PHONE_NUMBER);       
                        Log.i(TAG, 
"call OUT:"+phoneNumber);                       
                }
else{                       
                        
//如果是來電
                        TelephonyManager tm =
                            (TelephonyManager)context.getSystemService(Service.TELEPHONY_SERVICE);                       
                       
                        
switch (tm.getCallState()) {
                        
case TelephonyManager.CALL_STATE_RINGING:
                                incomingFlag 
= true;//標識當前是來電
                                incoming_number = intent.getStringExtra("incoming_number");
                                Log.i(TAG, 
"RINGING :"+ incoming_number);
                                
break;
                        
case TelephonyManager.CALL_STATE_OFFHOOK:                               
                                
if(incomingFlag){
                                        Log.i(TAG, 
"incoming ACCEPT :"+ incoming_number);
                                }
                                
break;
                       
                        
case TelephonyManager.CALL_STATE_IDLE:                               
                                
if(incomingFlag){
                                        Log.i(TAG, 
"incoming IDLE");                              
                                }
                                
break;
                        }
                }
        }
}

第二步:在AndroidManifest.xml,配置寫好的Receiver,并攔截相應的BroadCastAction,
另外注意加上相應的權限。
<receiver android:name=".filter.PhoneStatReceiver"> 
            
<intent-filter>
                 
<action android:name="android.intent.action.PHONE_STATE"/>          
                 
<action android:name="android.intent.action.NEW_OUTGOING_CALL" />
            
</intent-filter>
</receiver>

另外有撥打緊急號碼權限

   
<uses-permission android:name="android.permission.CALL_PRIVILEGED" />
posted on 2011-12-15 22:40 life02 閱讀(1547) 評論(0)  編輯 收藏 引用 所屬分類: Android開發
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一级特黄| 麻豆精品精华液| 在线免费一区三区| 极品尤物av久久免费看| 国内精品久久久久影院薰衣草 | 暖暖成人免费视频| 欧美国产精品人人做人人爱| 最新成人在线| 一区二区三区黄色| 欧美一区二区性| 久久综合伊人77777| 欧美久久电影| 国产日韩三区| 亚洲黄色av| 亚洲制服丝袜在线| 久久女同精品一区二区| 欧美成人69av| 中文日韩电影网站| 欧美一区精品| 欧美日本在线看| 国内成+人亚洲| 99国产精品| 亚洲激情av| 亚洲视频碰碰| 麻豆精品视频在线观看视频| 久久久久青草大香线综合精品| 国外成人在线视频| 麻豆成人在线播放| 你懂的视频欧美| 日韩亚洲欧美综合| 一本色道久久88综合亚洲精品ⅰ| 欧美日韩中文字幕在线| 午夜亚洲性色福利视频| 欧美一区二区三区视频免费播放| 黑人巨大精品欧美一区二区| 欧美激情一区在线观看| 欧美日韩一区成人| 久久久久久久精| 欧美国产日韩精品免费观看| 亚洲欧美国内爽妇网| 久久精品国产久精国产爱| 亚洲人人精品| 亚洲在线视频网站| 亚洲高清一区二| 一区二区三区回区在观看免费视频| 国产精品呻吟| 亚洲第一视频| 国产精品羞羞答答xxdd| 欧美jjzz| 欧美午夜精彩| 欧美69视频| 国产酒店精品激情| 91久久久久久国产精品| 国产欧美日韩高清| 亚洲精品国产精品国自产在线| 国产欧美日韩一区二区三区| 欧美激情久久久久久| 国产亚洲激情在线| 亚洲毛片在线| 亚洲高清免费视频| 午夜欧美理论片| 一区二区久久久久久| 久久久久综合网| 欧美呦呦网站| 欧美伦理视频网站| 免费成人黄色片| 国产日韩在线不卡| 一个色综合av| 亚洲免费观看视频| 久久亚洲影音av资源网| 久久av红桃一区二区小说| 欧美日韩国产精品专区| 亚洲福利视频专区| 伊人久久av导航| 午夜精品一区二区三区电影天堂| 一区二区三区**美女毛片| 麻豆国产精品777777在线| 久久久.com| 国产日本欧美一区二区三区在线 | 国产自产高清不卡| 亚洲午夜精品17c| 欧美激情视频一区二区三区不卡| 欧美中文字幕| 国产精品视频导航| 亚洲精品一区二区三区不| 91久久精品国产| 免费在线视频一区| 欧美成人日本| 影音先锋久久精品| 久久精品九九| 老牛影视一区二区三区| 在线日韩欧美| 久久尤物视频| 欧美激情a∨在线视频播放| 亚洲高清久久| 欧美激情综合在线| 亚洲精选成人| 亚洲欧美国产精品va在线观看 | 欧美视频一区在线观看| 99在线精品观看| 亚洲一区二区三区777| 欧美色一级片| 亚洲一区二区三区成人在线视频精品| 一区二区黄色| 国产精品每日更新| 香蕉久久精品日日躁夜夜躁| 久久亚洲精品伦理| 精品福利免费观看| 牛牛影视久久网| 亚洲伦理久久| 欧美一区免费| 狠久久av成人天堂| 欧美精品123区| 一本色道88久久加勒比精品 | 欧美 日韩 国产一区二区在线视频| 在线观看一区欧美| 欧美激情久久久| 亚洲视频第一页| 久久av一区二区三区漫画| 亚洲成人在线网| 欧美色大人视频| 欧美中文字幕在线视频| 亚洲福利视频免费观看| 午夜国产精品影院在线观看| 韩国精品久久久999| 欧美激情中文不卡| 欧美一区二视频| 亚洲区国产区| 欧美淫片网站| 日韩午夜免费| 国产一区二区无遮挡| 欧美激情aaaa| 欧美一级片久久久久久久| 亚洲国内自拍| 久久精品夜色噜噜亚洲a∨| 亚洲精品在线观看免费| 国产女人18毛片水18精品| 欧美顶级少妇做爰| 欧美在线视频一区二区| 夜夜嗨av一区二区三区网页| 免费不卡亚洲欧美| 午夜精品久久久久久久白皮肤| 亚洲国产va精品久久久不卡综合| 国产精品日本| 欧美三区免费完整视频在线观看| 一区二区三区精品在线| 亚洲国产精品电影在线观看| 国产精品美女久久久浪潮软件| 免费成人黄色av| 欧美在线视频免费| aa国产精品| 欧美成人精品激情在线观看| 欧美尤物一区| 亚洲欧美精品在线| 亚洲精品视频在线观看免费| 国产一区日韩二区欧美三区| 国产精品日韩一区| 欧美日韩国产在线| 美玉足脚交一区二区三区图片| 性欧美videos另类喷潮| 亚洲午夜激情免费视频| 亚洲欧洲综合另类| 久久综合精品一区| 欧美在线网站| 欧美亚洲午夜视频在线观看| 亚洲小说春色综合另类电影| 一本色道久久综合亚洲91| 亚洲精品欧美在线| 亚洲动漫精品| 亚洲成人在线网| 91久久精品国产91久久| 亚洲人体偷拍| 亚洲久久视频| 日韩性生活视频| 日韩视频在线观看国产| 亚洲毛片在线观看.| 最近中文字幕mv在线一区二区三区四区| 国产亚洲制服色| 激情另类综合| 亚洲国产精品一区二区www在线| 亚洲福利视频一区二区| 亚洲国产精品一区二区第四页av | 免费日本视频一区| 久久久久国产精品麻豆ai换脸| 欧美伊人久久| 久久久久国产一区二区三区四区| 久久精品理论片| 久久久久亚洲综合| 蜜桃av一区二区| 亚洲高清自拍| 亚洲精品九九| 一区二区三区视频在线| 亚洲欧美日韩精品久久亚洲区| 亚洲欧美日韩一区在线观看| 久久gogo国模裸体人体| 欧美成人首页| 欧美午夜视频网站| 国精品一区二区| 亚洲精品午夜精品| 亚洲欧美精品在线观看|