日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android应用开发:网络编程-1

發(fā)布時間:2025/4/16 Android 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android应用开发:网络编程-1 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

網(wǎng)絡(luò)編程

  • Java基礎(chǔ):網(wǎng)絡(luò)編程
  • Uri、URL、UriMatcher、ContentUris詳解
  • Android應(yīng)用開發(fā):網(wǎng)絡(luò)編程1
  • Android應(yīng)用開發(fā):網(wǎng)絡(luò)編程2

1. 請求網(wǎng)絡(luò)圖片

網(wǎng)絡(luò)交互就是基于HTTP協(xié)議請求和響應(yīng)的過程。XMPP協(xié)議用于即時通訊。

示例:res\layout\activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity" ><Button android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="請求圖片" android:onClick="click"/><ImageView android:id="@+id/iv"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"/></RelativeLayout>

src/cn.itcast.imageviewer/MainActivity.java

package cn.itcast.imageviewer;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.view.View; import android.widget.ImageView; import android.widget.Toast;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){//向服務(wù)器發(fā)送Http請求去請求圖片String path = "http://192.168.1.100:8080/sh.jpg";try{//1. 把網(wǎng)址封裝成url對象URL url = new URL(path);//2. 打開一個連接對象HttpURLConnection conn = (HttpURLConnection) url.openConnection();//3. 給連接對象做設(shè)置conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);//4. 發(fā)送請求,建立連接conn.connect();//5. 獲取響應(yīng)碼,如果為200開頭,說明請求成功if(conn.getResponseCode() == 200){//獲取服務(wù)器的流,服務(wù)器返回的數(shù)據(jù)是通過流寫給客戶端的,也就是說,流里就是請求的圖片InputStream is = conn.getInputStream();//讀取流里的數(shù)據(jù),把數(shù)據(jù)構(gòu)造成一個圖片對象Bitmap bm = BitmapFactory.decodeStream(is);//把圖片顯示至屏幕ImageView iv = (ImageView) findViewById(R.id.iv);iv.setImageBitmap(bm);}else{Toast.makeText(this, "請求失敗啦啦啦", 0).show();}}catch(Exception e){e.printStackTrace();}} }

添加權(quán)限:

在Tomcat服務(wù)器webapps\ROOT存放圖片:

運行結(jié)果:雙擊start.bat,啟動tomcat。

啟動2.3.3版本模擬器,圖片顯示成功:

Handler機制讓子線程刷新UI,如果上面的示例運行在4.3版本的模擬器上,就會報警告:

在Android中,主線程是絕對不能阻塞的。因為,網(wǎng)絡(luò)請求是耗時操作,主線程處于阻塞狀態(tài),用戶任何操作都無效,處于類似于死機的狀態(tài)。此時,點擊HOME鍵有效,點擊返回鍵、菜單鍵都沒有反應(yīng)。因為,返回鍵和菜單鍵是由當(dāng)前應(yīng)用程序自行處理,HOME鍵是由系統(tǒng)處理。應(yīng)用程序可以阻塞自己的主線程,不可能阻塞Android系統(tǒng)。
為了保證用戶體驗良好,所有的耗時操作都不要寫在主線程里,包括:請求網(wǎng)絡(luò)、加載數(shù)據(jù)(數(shù)據(jù)庫)和資源。
ANR:Application Not Responding,應(yīng)用長時間不能響應(yīng)用戶操作。

查看出現(xiàn)ANR的原因,導(dǎo)出data/anr/traces.txt文件,打開。

ANR無法調(diào)試,解決方法就是在主線程中不要做耗時操作。
只有主線程可以刷新UI,主線程又稱UI線程。這樣做,是為了線程安全,只有一個線程可以刷新UI,如果有多個線程同時刷新UI,就可能出現(xiàn)線程安全導(dǎo)致UI刷新混亂的問題。

如果我們在MainActivity.java中啟動一個線程進行網(wǎng)絡(luò)請求,再次執(zhí)行該應(yīng)用程序就會報警告,如下:

通過異常可以看出來,刷新UI的代碼必須在主線程中執(zhí)行,但是請求圖片的代碼又由于不能引起阻塞,只能在子線程中執(zhí)行,而且只有請求完圖片之后才能刷新UI,這時候就形成了矛盾。Android里面提供了一種機制能夠解決這個問題,也就是Handler機制。

2. Handler機制

主線程創(chuàng)建的時候,主線程中有一個消息隊列MessageQueue,用來存放消息。還有一個Looper用來不斷檢測MessageQueue是否有消息。如果有消息就交給消息處理器Handler,Handler中有一個方法handleMessage,用來處理消息,這個方法是在主線程調(diào)用。那么,這個方法就可以刷新UI。如此,子線程想要刷新UI,只需調(diào)用Handler的sendMessag方法,將消息發(fā)送到MessageQueue即可。

示例:src/cn.itcast.imageviewer2/MainActivity.java

package cn.itcast.imageviewer2;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL;import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.ImageView; import android.widget.Toast;public class MainActivity extends Activity {Handler handler = new Handler(){//程序員需要重寫handlerMessage方法,刷新UI@Overridepublic void handleMessage(Message msg) {switch(msg.what){case 1://判斷消息是成功消息還是失敗消息ImageView iv = (ImageView) findViewById(R.id.iv);iv.setImageBitmap((Bitmap)msg.obj);break;case 2:Toast.makeText(MainActivity.this, "請求失敗啦啦啦", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){Thread t = new Thread(){public void run(){String path = "http://192.168.1.100:8080/sh.jpg";try{URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);conn.connect();if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();Bitmap bm = BitmapFactory.decodeStream(is);//創(chuàng)建消息對象Message msg = new Message();//消息對象可以攜帶數(shù)據(jù)msg.obj = bm;msg.what = 1;//發(fā)送消息至主線程的消息隊列handler.sendMessage(msg);}else{Message msg = new Message();msg.what = 2;handler.sendMessage(msg);//由于Message沒有攜帶任何數(shù)據(jù),所以上面3句可以用下面1句替換。//handler.sendEmptyMessage(2);}}catch(Exception e){e.printStackTrace();}}};t.start();} }

運行結(jié)果:

添加緩存功能的圖片查看器,為了提升效率,查看圖片后,緩存起來,便于下次查看圖片不必在通過網(wǎng)絡(luò)請求。

代碼:src/cn.itcast.imageviewer3/MainActivity.java

package cn.itcast.imageviewer3;import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.ImageView; import android.widget.Toast;public class MainActivity extends Activity {Handler handler = new Handler(){@Overridepublic void handleMessage(Message msg) {switch(msg.what){case 1:ImageView iv = (ImageView) findViewById(R.id.iv);iv.setImageBitmap((Bitmap)msg.obj);break;case 2:Toast.makeText(MainActivity.this, "請求失敗啦啦啦", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){final String path = "http://192.168.1.100:8080/sh.jpg";final File file = new File(getCacheDir(),getFileName(path));if(file.exists()){System.out.println("從緩存獲取");Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());ImageView iv = (ImageView) findViewById(R.id.iv);iv.setImageBitmap(bm);}else{Thread t = new Thread(){public void run(){try{System.out.println("從網(wǎng)絡(luò)獲取");URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);conn.connect();if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();//需要自己開啟文件輸出流,讀取流里數(shù)據(jù)的同時,把數(shù)據(jù)寫到本地byte[] b = new byte[1024];int len;FileOutputStream fos = new FileOutputStream(file);while((len = is.read(b)) != -1){fos.write(b, 0, len);}fos.close();//流里數(shù)據(jù)已經(jīng)讀取完畢,這行代碼無法再構(gòu)造圖片了//Bitmap bm = BitmapFactory.decodeStream(is);Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());Message msg = new Message();msg.obj = bm;msg.what = 1;handler.sendMessage(msg);}else{Message msg = new Message();msg.what = 2;handler.sendMessage(msg);}}catch(Exception e){e.printStackTrace();}}};t.start();}}public String getFileName(String path){int index = path.lastIndexOf("/");return path.substring(index+1);} }

運行結(jié)果:

第一次,從網(wǎng)絡(luò)獲取。第二次再次點擊按鈕,從緩存獲取。

3. 獲取開源代碼

在程序開發(fā)中,會遇到很多問題。例如,請求圖片過程中遇到斷網(wǎng),網(wǎng)速慢,圖片過大內(nèi)存不夠等等情況。由于這些情況大部分項目都會遇到,所以網(wǎng)上有很多寫好的現(xiàn)成的模塊。不要重新發(fā)明輪子,可以直接拿來用。
好的開源網(wǎng)站: http://code.google.com http://github.com
搜索,下載源碼,解壓,復(fù)制到我們自己的應(yīng)用程序項目中。

res\layout\activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity" ><Button android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="請求網(wǎng)絡(luò)圖片" android:onClick="click"/><com.loopj.android.image.SmartImageView android:id="@+id/iv"android:layout_width="wrap_content"android:layout_height="wrap_content"android:src="@drawable/ic_launcher"android:layout_centerInParent="true"/> </RelativeLayout>

SmartImageView是自定義控件,以后會有專門的課程講解。

src/cn.itcast.smartimageview/MainActivity.java

package cn.itcast.smartimageview;import android.app.Activity; import android.os.Bundle; import android.view.View;import com.loopj.android.image.SmartImageView;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){String path = "http://192.168.1.100:8080/sh.jpg";SmartImageView iv = (SmartImageView) findViewById(R.id.iv);iv.setImageUrl(path);} }

添加權(quán)限:

運行結(jié)果:

4. Html源文件查看器

代碼:res\layout\activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity" ><Button android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="請求網(wǎng)絡(luò)" android:onClick="click"/><ScrollView android:layout_width="match_parent"android:layout_height="match_parent"><TextView android:id="@+id/tv"android:layout_width="match_parent"android:layout_height="match_parent"/></ScrollView> </RelativeLayout>

src/cn.itcast.htmlviewer.tool/Tools.java

package cn.itcast.htmlviewer.tool;import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream;public class Tools {public static String getTextFromStream(InputStream is){try{byte[] b = new byte[1024];int len;ByteArrayOutputStream bos = new ByteArrayOutputStream();while((len = is.read(b)) != -1){bos.write(b,0,len);}//把輸出流里的內(nèi)容轉(zhuǎn)換成字節(jié)數(shù)組String text = new String(bos.toByteArray());return text;}catch(IOException e){e.printStackTrace();}return null;} }

src/cn.itcast.htmlviewer/MainActivity.java

package cn.itcast.htmlviewer;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL;import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.TextView; import cn.itcast.htmlviewer.tool.Tools;public class MainActivity extends Activity {Handler handler = new Handler(){@Overridepublic void handleMessage(Message msg) {TextView tv = (TextView) findViewById(R.id.tv);tv.setText((String)msg.obj);}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){Thread t = new Thread(){public void run(){String path = "http://192.168.1.100:8080/baidu.html";try{URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);//先發(fā)送請求,再獲取響應(yīng)碼,getResponseCode方法自身會發(fā)送請求消息if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();String text = Tools.getTextFromStream(is);//如果消息池中沒有消息,new一個,如果有,復(fù)用這條空閑消息Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}}catch(Exception e){e.printStackTrace();}}};t.start();} }

添加權(quán)限:

運行結(jié)果:

如果html文件為gbk編碼:

那么Tools.java中代碼只要進行如下修改即可:

新聞客戶端布局

res\layout\item_listview.xml

<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content" ><ImageView android:id="@+id/iv"android:layout_width="90dp"android:layout_height="70dp"android:src="@drawable/ic_launcher"android:layout_centerVertical="true"/><!-- android:singleLine是為了讓過長的標題不會導(dǎo)致?lián)Q行,影響美觀 --><TextView android:id="@+id/tv_title"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textSize="22sp"android:text="這是標題"android:singleLine="true"android:layout_toRightOf="@+id/iv"/><!-- android:lines表示如果文本過長,最多顯示幾行 --><TextView android:id="@+id/tv_detail"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textSize="15sp"android:text="這是詳細"android:lines="2"android:textColor="@android:color/darker_gray"android:layout_toRightOf="@+id/iv"android:layout_below="@id/tv_title"/><TextView android:id="@+id/tv_comment"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="12345條評論"android:textColor="#ff0000"android:layout_alignParentRight="true"android:layout_below="@id/tv_detail"/></RelativeLayout>

效果:

獲取新聞信息,將news.xml和images文件夾存放在Tomcat服務(wù)器中。

News.xml

<?xml version="1.0" encoding="UTF-8" ?> <newslist><news><title>西安一期就業(yè)快報</title><detail>熱烈祝賀西安一期平均薪水突破13k</detail><comment>15687</comment><image>http://192.168.1.100:8080/images/6.jpg</image></news><news><title>程序員因?qū)懘a太亂被殺害</title><detail>兇手是死者同事,維護死者代碼時完全看不懂而痛下殺手</detail><comment>16359</comment><image>http://192.168.1.100:8080/images/7.jpg</image></news><news><title>產(chǎn)品經(jīng)理因頻繁改需求被殺害</title><detail>兇手是一名程序員,因死者對項目需求頻繁改動而痛下殺手</detail><comment>14112</comment><image>http://192.168.1.100:8080/images/7.jpg</image></news><news><title>3Q大戰(zhàn)宣判: 騰訊獲賠500萬</title><detail>最高法駁回360上訴, 維持一審宣判.</detail><comment>6427</comment><image>http://192.168.1.100:8080/images/1.jpg</image></news><news><title>今日之聲:北大雕塑被戴口罩</title><detail>市民: 因霧霾起訴環(huán)保局; 公務(wù)員談"緊日子": 堅決不出去.</detail><comment>681</comment><image>http://192.168.1.100:8080/images/2.jpg</image></news><news><title>奧巴馬見達賴是裝蒜</title><detail>外文局: 國際民眾認可中國大國地位;法院: "流量清零"未侵權(quán).</detail><comment>1359</comment><image>http://192.168.1.100:8080/images/3.jpg</image></news><news><title>輕松一刻: 我要沉迷學(xué)習(xí)不自拔</title><detail>放假時我醒了不代表我起床了, 如今我起床了不代表我醒了!</detail><comment>11616</comment><image>http://192.168.1.100:8080/images/4.jpg</image></news><news><title>男女那些事兒</title><detail>"媽, 我在東莞被抓, 要2萬保釋金, 快匯錢到xxx!"</detail><comment>10339</comment><image>http://192.168.1.100:8080/images/5.jpg</image></news><news><title>趙帥哥語錄一</title><detail>少壯不努力,老大做IT</detail><comment>14612</comment><image>http://192.168.1.100:8080/images/8.jpg</image></news><news><title>趙帥哥語錄二</title><detail>問君能有幾多愁,恰似調(diào)完代碼改需求</detail><comment>13230</comment><image>http://192.168.1.100:8080/images/8.jpg</image></news><news><title>趙帥哥語錄三</title><detail>覺得我?guī)浀娜斯べY一般都比較高</detail><comment>9928</comment><image>http://192.168.1.100:8080/images/8.jpg</image></news><news><title>今日之聲:北大雕塑被戴口罩</title><detail>市民: 因霧霾起訴環(huán)保局; 公務(wù)員談"緊日子": 堅決不出去.</detail><comment>681</comment><image>http://192.168.1.100:8080/images/2.jpg</image></news><news><title>奧巴馬見達賴是裝蒜</title><detail>外文局: 國際民眾認可中國大國地位;法院: "流量清零"未侵權(quán).</detail><comment>1359</comment><image>http://192.168.1.100:8080/images/3.jpg</image></news> </newslist> src/cn.itcast.news.domain/News.java package cn.itcast.news.domain;public class News {private String title; private String detail;private String comment;private String imageUrl;public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}public String getDetail() {return detail;}public void setDetail(String detail) {this.detail = detail;}public String getComment() {return comment;}public void setComment(String comment) {this.comment = comment;}public String getImageUrl() {return imageUrl;}public void setImageUrl(String imageUrl) {this.imageUrl = imageUrl;} } src/cn.itcast.news/MainActivity.java package cn.itcast.news;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.ArrayList; import java.util.List;import org.xmlpull.v1.XmlPullParser;import android.app.Activity; import android.os.Bundle; import android.util.Xml; import cn.itcast.news.domain.News;public class MainActivity extends Activity {List<News> newsList;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);getNewsInfo();}private void getNewsInfo(){Thread t = new Thread(){public void run(){String path = "http://192.168.1.100:8080/news.xml";try{URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection)url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);if(conn.getResponseCode() == 200){//獲取服務(wù)器返回的流,流里就是xml文件InputStream is = conn.getInputStream();parserNewsInfo(is);}}catch(Exception e){e.printStackTrace();}}};t.start();}private void parserNewsInfo(InputStream is){XmlPullParser xp = Xml.newPullParser();try{xp.setInput(is,"utf-8"); int type = xp.getEventType(); News news = null; while(type != XmlPullParser.END_DOCUMENT){switch(type){case XmlPullParser.START_TAG:if("newslist".equals(xp.getName())){newsList = new ArrayList<News>();}else if("news".equals(xp.getName())){news = new News();}else if("title".equals(xp.getName())){String title = xp.nextText();news.setTitle(title);}else if("detail".equals(xp.getName())){String detail = xp.nextText();news.setDetail(detail);}else if("comment".equals(xp.getName())){String comment = xp.nextText();news.setComment(comment);}else if("image".equals(xp.getName())){String image = xp.nextText();news.setImageUrl(image);}break;case XmlPullParser.END_TAG:if("news".equals(xp.getName())){newsList.add(news);}break;}type = xp.next();}}catch(Exception e){e.printStackTrace();}} }

把新聞信息顯示至界面
修改res\layout\item_listview.xml中的ImageView標簽為SmartImageView標簽,便于顯示圖片。

src/cn.itcast.news/MainActivity.java package cn.itcast.news;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.ArrayList; import java.util.List; import org.xmlpull.v1.XmlPullParser; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.util.Xml; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ListView; import android.widget.TextView; import cn.itcast.news.domain.News;import com.loopj.android.image.SmartImageView;public class MainActivity extends Activity {List<News> newsList;Handler handler = new Handler(){@Overridepublic void handleMessage(Message msg) {ListView lv = (ListView)findViewById(R.id.lv);lv.setAdapter(new MyAdapter());}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);getNewsInfo();//由于getNewsInfo方法中是開啟了一個子線程,與主線程并行。所以當(dāng)listview顯示內(nèi)容時,newsList還沒來得及創(chuàng)建,所以lv設(shè)置顯示內(nèi)容的代碼不能運行在這里。要保證運行在xml解析完畢之后。//ListView lv = (ListView)findViewById(R.id.lv);//lv.setAdapter(new MyAdapter());}class MyAdapter extends BaseAdapter{@Overridepublic int getCount() {//之所以系統(tǒng)需要知道條目數(shù)量,是因為屏幕右側(cè)的控制條顯示基于此數(shù)據(jù)而定return newsList.size();}@Overridepublic Object getItem(int position) {return null;}@Overridepublic long getItemId(int position) {return 0;}//視圖保存器class ViewHolder{TextView tv_title;TextView tv_detail;TextView tv_comment;SmartImageView siv;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {View v = null;ViewHolder vh = null;News news = newsList.get(position);if(convertView == null){v = View.inflate(MainActivity.this, R.layout.item_listview, null);vh = new ViewHolder();//如果緩存為空,那么需要填充新的View對象,同時找到布局文件中的所有組件,并封裝至ViewHolder對象中vh.tv_title = (TextView)v.findViewById(R.id.tv_title);vh.tv_detail = (TextView)v.findViewById(R.id.tv_detail);vh.tv_comment = (TextView)v.findViewById(R.id.tv_comment);vh.siv = (SmartImageView) v.findViewById(R.id.iv);//把ViewHolder對象存入View對象中,緩存View對象,同時緩存了ViewHolder對象v.setTag(vh);}else{v = convertView;//從緩存中取出ViewHolder對象,這個對象中就封裝了布局文件中所有的組件對象,那么就不需要再次findViewById了vh = (ViewHolder)v.getTag();}vh.tv_title.setText(news.getTitle());vh.tv_detail.setText(news.getDetail());vh.tv_comment.setText(news.getComment() + "條評論");vh.siv.setImageUrl(news.getImageUrl());return v;}}private void getNewsInfo(){Thread t = new Thread(){public void run(){String path = "http://192.168.1.100:8080/news.xml";try{URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection)url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();parserNewsInfo(is);}}catch(Exception e){e.printStackTrace();}}};t.start();}private void parserNewsInfo(InputStream is){XmlPullParser xp = Xml.newPullParser();try{xp.setInput(is,"utf-8");int type = xp.getEventType();News news = null;while(type != XmlPullParser.END_DOCUMENT){switch(type){case XmlPullParser.START_TAG:if("newslist".equals(xp.getName())){newsList = new ArrayList<News>();}else if("news".equals(xp.getName())){news = new News();}else if("title".equals(xp.getName())){String title = xp.nextText();news.setTitle(title);}else if("detail".equals(xp.getName())){String detail = xp.nextText();news.setDetail(detail);}else if("comment".equals(xp.getName())){String comment = xp.nextText();news.setComment(comment);}else if("image".equals(xp.getName())){String image = xp.nextText();news.setImageUrl(image);}break;case XmlPullParser.END_TAG:if("news".equals(xp.getName())){newsList.add(news);}break;}type = xp.next();}}catch(Exception e){e.printStackTrace();}//xml解析完畢,發(fā)送消息,通知主線程,設(shè)置lv的顯示內(nèi)容handler.sendEmptyMessage(1);} }

添加權(quán)限:

運行結(jié)果:

使用get方式提交表單

使用MyEclipse,新建一個Servlet:Login.java,把該Web項目部署到Tomcat服務(wù)器上。

src/cn.itcast.login/Login.java

package cn.itcast.login;import java.io.IOException;import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;public class Login extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {String name = request.getParameter("name");String pass = request.getParameter("pass");ServletOutputStream os = response.getOutputStream();if("asd".equals(name)&&"123".equals(pass)){os.write("登陸成功".getBytes("utf-8"));}else{os.write("登陸失敗".getBytes("utf-8"));}}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);} }

WebRoot/index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html><head></head><body><form action="/Web/servlet/Login" method=get>賬號:<input type="text" name="name"><br/>密碼:<input type="text" name="pass"><br/><input type="submit" value="登陸"/></form></body> </html>

打開瀏覽器,輸入地址,然后輸入用戶名和密碼,提交。

將瀏覽器編碼改為UTF-8。

結(jié)果如下:

Android之Get方式提交數(shù)據(jù): res\layout\activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity" android:orientation="vertical"><EditText android:id="@+id/et_name"android:layout_width="match_parent"android:layout_height="wrap_content"/><EditText android:id="@+id/et_pass"android:layout_width="match_parent"android:layout_height="wrap_content"/><Button android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="登陸"android:onClick="click"/> </LinearLayout> src/cn.itcast.getmethod.tool/Tools.java package cn.itcast.getmethod.tool;import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream;public class Tools {public static String getTextFromStream(InputStream is){try{byte[] b = new byte[1024];int len;ByteArrayOutputStream bos = new ByteArrayOutputStream();while((len = is.read(b)) != -1){bos.write(b,0,len);}//把輸出流里的內(nèi)容轉(zhuǎn)換成字節(jié)數(shù)組String text = new String(bos.toByteArray());return text;}catch(IOException e){e.printStackTrace();}return null;} } src/cn.itcast.getmethod/MainActivity.java package cn.itcast.getmethod;import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL;import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.EditText; import android.widget.Toast; import cn.itcast.getmethod.tool.Tools;public class MainActivity extends Activity {Handler handler = new Handler(){@Overridepublic void handleMessage(Message msg) {Toast.makeText(MainActivity.this, (String)msg.obj, 0).show();}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){EditText et_name = (EditText)findViewById(R.id.et_name);EditText et_pass = (EditText)findViewById(R.id.et_pass);String name = et_name.getText().toString();String pass = et_pass.getText().toString();//在url后面拼接要提交的數(shù)據(jù)final String path = "http://localhost:8080/Web/servlet/Login?name=" + name + "&pass=" + pass;Thread t = new Thread(){public void run(){URL url;try {url = new URL(path);HttpURLConnection conn = (HttpURLConnection)url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();String text = Tools.getTextFromStream(is);Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}} catch (Exception e) {e.printStackTrace();}}};t.start();} }

添加權(quán)限:

運行結(jié)果:

提交表單的亂碼問題

將Login.java中“zhangsan”修改為“張三”,并且打印出接收到的用戶名及密碼。

src/cn.itcast.login/Login.java

package cn.itcast.login;import java.io.IOException;import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;public class Login extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {String name = request.getParameter("name");String pass = request.getParameter("pass");System.out.println(name);System.out.println(pass);ServletOutputStream os = response.getOutputStream();if("張三".equals(name)&&"123".equals(pass)){os.write("登陸成功".getBytes("utf-8"));}else{os.write("登陸失敗".getBytes("utf-8"));}}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);} }

重新部署,運行。結(jié)果如下:

將瀏覽器編碼調(diào)整為UTF-8。

可以看到,打印出來的為亂碼。原因在于瀏覽器提交表單的時候,會把“張三”用UTF-8編碼變成字節(jié)數(shù)組,然后傳給服務(wù)器。服務(wù)器拿到這些字節(jié)以后,因為getParameter默認使用iso8859-1編碼把讀取到的字節(jié)數(shù)組構(gòu)造成字符串,導(dǎo)致亂碼。因此,解決方案為,首先使用iso8859-1把字符串重新轉(zhuǎn)換成字節(jié)數(shù)組,然后再用utf-8構(gòu)造成字符串即可。

重新部署,運行,結(jié)果如下:

嘗試通過手機端發(fā)送中文的情況,如下:輸入中文,首先選擇谷歌拼音輸入法。

由上面的圖片可以看到,依然存在亂碼問題。原因在于瀏覽器提交的數(shù)據(jù)都是經(jīng)過URL編碼的,所以,通過代碼提交的數(shù)據(jù)就需要手動編碼。

修改后,運行結(jié)果:

使用post方式提交表單,修改表單為post提交方式:

通過代碼實現(xiàn)post提交請求,一方面通過流的方式將數(shù)據(jù)傳輸給服務(wù)器,一方面是給post請求頭添加額外屬性。

src/cn.itcast.postmethod/MainActivity.java

package cn.itcast.postmethod;import java.io.InputStream; import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.URL; import java.net.URLEncoder;import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.EditText; import android.widget.Toast; import cn.itcast.getmethod.tool.Tools;public class MainActivity extends Activity {Handler handler = new Handler(){@Overridepublic void handleMessage(Message msg) {Toast.makeText(MainActivity.this, (String)msg.obj, 0).show();}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){EditText et_name = (EditText)findViewById(R.id.et_name);EditText et_pass = (EditText)findViewById(R.id.et_pass);final String name = et_name.getText().toString();final String pass = et_pass.getText().toString();final String path = "http://192.168.1.100:8080/Web/servlet/Login";Thread t = new Thread(){public void run(){URL url;try {url = new URL(path);HttpURLConnection conn = (HttpURLConnection)url.openConnection();conn.setRequestMethod("POST");conn.setConnectTimeout(8000);conn.setReadTimeout(8000);//post請求頭需要添加額外屬性conn.setRequestProperty("Content-type", "application/x-www-form-urlencoded");String content = "name=" + URLEncoder.encode(name) + "&pass=" + pass;conn.setRequestProperty("Content-Length", content.length() + "");//開啟請求頭的流,把要提交的數(shù)據(jù)寫入流中//設(shè)置打開連接對象輸出流conn.setDoOutput(true);OutputStream os = conn.getOutputStream();os.write(content.getBytes());if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();String text = Tools.getTextFromStream(is);Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}} catch (Exception e) {e.printStackTrace();}}};t.start();} }

運行結(jié)果:


1. 網(wǎng)絡(luò)圖片查看器

  • 確定圖片的網(wǎng)址
  • 發(fā)送http請求
URL url = new URL(address); //獲取連接對象,并沒有建立連接 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); //設(shè)置連接和讀取超時 conn.setConnectTimeout(5000); conn.setReadTimeout(5000); //設(shè)置請求方法,注意必須大寫 conn.setRequestMethod("GET"); //建立連接,發(fā)送get請求 //conn.connect(); //建立連接,然后獲取響應(yīng)嗎,200說明請求成功 conn.getResponseCode();
  • 服務(wù)器的圖片是以流的形式返回給瀏覽器的
//拿到服務(wù)器返回的輸入流 InputStream is = conn.getInputStream(); //把流里的數(shù)據(jù)讀取出來,并構(gòu)造成圖片 Bitmap bm = BitmapFactory.decodeStream(is);
  • 把圖片設(shè)置為ImageView的顯示內(nèi)容
ImageView iv = (ImageView) findViewById(R.id.iv); iv.setImageBitmap(bm);
  • 添加網(wǎng)絡(luò)權(quán)限

1.1 主線程不能被阻塞

  • 在Android中,主線程被阻塞會導(dǎo)致應(yīng)用不能刷新ui界面,不能響應(yīng)用戶操作,用戶體驗將非常差
  • 主線程阻塞時間過長,系統(tǒng)會拋出ANR異常
  • ANR:Application Not Response;應(yīng)用無響應(yīng)
  • 任何耗時操作都不可以寫在主線程
  • 因為網(wǎng)絡(luò)交互屬于耗時操作,如果網(wǎng)速很慢,代碼會阻塞,所以網(wǎng)絡(luò)交互的代碼不能運行在主線程

1.2 只有主線程能刷新ui

  • 刷新ui的代碼只能運行在主線程,運行在子線程是沒有任何效果的
  • 如果需要在子線程中刷新ui,使用消息隊列機制

1.3 消息隊列

  • Looper一旦發(fā)現(xiàn)Message Queue中有消息,就會把消息取出,然后把消息扔給Handler對象,Handler會調(diào)用自己的handleMessage方法來處理這條消息
  • handleMessage方法運行在主線程
  • 主線程創(chuàng)建時,消息隊列和輪詢器對象就會被創(chuàng)建,但是消息處理器對象,需要使用時,自行創(chuàng)建
//消息隊列 Handler handler = new Handler(){//主線程中有一個消息輪詢器looper,不斷檢測消息隊列中是否有新消息,//如果發(fā)現(xiàn)有新消息,自動調(diào)用此方法,注意此方法是在主線程中運行的public void handleMessage(android.os.Message msg) {} };
  • 在子線程中往消息隊列里發(fā)消息
//創(chuàng)建消息對象 Message msg = new Message(); //消息的obj屬性可以賦值任何對象,通過這個屬性可以攜帶數(shù)據(jù) msg.obj = bm; //what屬性相當(dāng)于一個標簽,用于區(qū)分出不同的消息,從而運行不能的代碼 msg.what = 1; //發(fā)送消息 handler.sendMessage(msg);
  • 通過switch語句區(qū)分不同的消息
public void handleMessage(android.os.Message msg) {switch (msg.what) {//如果是1,說明屬于請求成功的消息case 1:ImageView iv = (ImageView) findViewById(R.id.iv);Bitmap bm = (Bitmap) msg.obj;iv.setImageBitmap(bm);break;case 2:Toast.makeText(MainActivity.this, "請求失敗", 0).show();break;} } public class MainActivity extends Activity {static ImageView iv;static MainActivity ma;static Handler handler = new Handler(){//此方法在主線程中調(diào)用,可以用來刷新uipublic void handleMessage(android.os.Message msg) {//處理消息時,需要知道到底是成功的消息,還是失敗的消息switch (msg.what) {case 1://把位圖對象顯示至imageviewiv.setImageBitmap((Bitmap)msg.obj);break;case 0:Toast.makeText(ma, "請求失敗", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);iv = (ImageView) findViewById(R.id.iv);ma = this;}public void click(View v){Thread t = new Thread(){@Overridepublic void run() {//下載圖片//1.確定網(wǎng)址String path = "http://192.168.13.13:8080/dd.jpg";try {//2.把網(wǎng)址封裝成一個url對象URL url = new URL(path);//3.獲取客戶端和服務(wù)器的連接對象,此時還沒有建立連接HttpURLConnection conn = (HttpURLConnection) url.openConnection();//4.對連接對象進行初始化//設(shè)置請求方法,注意大寫conn.setRequestMethod("GET");//設(shè)置連接超時conn.setConnectTimeout(5000);//設(shè)置讀取超時conn.setReadTimeout(5000);//5.發(fā)送請求,與服務(wù)器建立連接conn.connect();//如果響應(yīng)碼為200,說明請求成功if(conn.getResponseCode() == 200){//獲取服務(wù)器響應(yīng)頭中的流,流里的數(shù)據(jù)就是客戶端請求的數(shù)據(jù)InputStream is = conn.getInputStream();//讀取出流里的數(shù)據(jù),并構(gòu)造成位圖對象Bitmap bm = BitmapFactory.decodeStream(is);// ImageView iv = (ImageView) findViewById(R.id.iv); // //把位圖對象顯示至imageview // iv.setImageBitmap(bm);Message msg = new Message();//消息對象可以攜帶數(shù)據(jù)msg.obj = bm;msg.what = 1;//把消息發(fā)送至主線程的消息隊列handler.sendMessage(msg);}else{ // Toast.makeText(MainActivity.this, "請求失敗", 0).show();Message msg = handler.obtainMessage();msg.what = 0;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();} }

1.4 案例1:網(wǎng)絡(luò)圖片查看器

public class MainActivity extends Activity {static ImageView iv;static MainActivity ma;static Handler handler = new Handler(){//此方法在主線程中調(diào)用,可以用來刷新uipublic void handleMessage(android.os.Message msg) {//處理消息時,需要知道到底是成功的消息,還是失敗的消息switch (msg.what) {case 1://把位圖對象顯示至imageviewiv.setImageBitmap((Bitmap)msg.obj);break;case 0:Toast.makeText(ma, "請求失敗", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);iv = (ImageView) findViewById(R.id.iv);ma = this;}public void click(View v){Thread t = new Thread(){@Overridepublic void run() {//下載圖片//1.確定網(wǎng)址String path = "http://192.168.13.13:8080/dd.jpg";try {//2.把網(wǎng)址封裝成一個url對象URL url = new URL(path);//3.獲取客戶端和服務(wù)器的連接對象,此時還沒有建立連接HttpURLConnection conn = (HttpURLConnection) url.openConnection();//4.對連接對象進行初始化//設(shè)置請求方法,注意大寫conn.setRequestMethod("GET");//設(shè)置連接超時conn.setConnectTimeout(5000);//設(shè)置讀取超時conn.setReadTimeout(5000);//5.發(fā)送請求,與服務(wù)器建立連接conn.connect();//如果響應(yīng)碼為200,說明請求成功if(conn.getResponseCode() == 200){//獲取服務(wù)器響應(yīng)頭中的流,流里的數(shù)據(jù)就是客戶端請求的數(shù)據(jù)InputStream is = conn.getInputStream();//讀取出流里的數(shù)據(jù),并構(gòu)造成位圖對象Bitmap bm = BitmapFactory.decodeStream(is);// ImageView iv = (ImageView) findViewById(R.id.iv); // //把位圖對象顯示至imageview // iv.setImageBitmap(bm);Message msg = new Message();//消息對象可以攜帶數(shù)據(jù)msg.obj = bm;msg.what = 1;//把消息發(fā)送至主線程的消息隊列handler.sendMessage(msg);}else{ // Toast.makeText(MainActivity.this, "請求失敗", 0).show();Message msg = handler.obtainMessage();msg.what = 0;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();} }

1.5 加入緩存圖片的功能

  • 把服務(wù)器返回的流里的數(shù)據(jù)讀取出來,然后通過文件輸入流寫至本地文件
//1.拿到服務(wù)器返回的輸入流 InputStream is = conn.getInputStream(); //2.把流里的數(shù)據(jù)讀取出來,并構(gòu)造成圖片FileOutputStream fos = new FileOutputStream(file); byte[] b = new byte[1024]; int len = 0; while((len = is.read(b)) != -1){fos.write(b, 0, len); }
  • 創(chuàng)建bitmap對象的代碼改成
Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());
  • 每次發(fā)送請求前檢測一下在緩存中是否存在同名圖片,如果存在,則讀取緩存
public class MainActivity extends Activity {static ImageView iv;static MainActivity ma;static Handler handler = new Handler(){//此方法在主線程中調(diào)用,可以用來刷新uipublic void handleMessage(android.os.Message msg) {//處理消息時,需要知道到底是成功的消息,還是失敗的消息switch (msg.what) {case 1://把位圖對象顯示至imageviewiv.setImageBitmap((Bitmap)msg.obj);break;case 0:Toast.makeText(ma, "請求失敗", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);iv = (ImageView) findViewById(R.id.iv);ma = this;}public void click(View v){//下載圖片//1.確定網(wǎng)址final String path = "http://192.168.13.13:8080/dd.jpg";final File file = new File(getCacheDir(), getFileName(path));//判斷,緩存中是否存在該文件if(file.exists()){//如果緩存存在,從緩存讀取圖片System.out.println("從緩存讀取的");Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());iv.setImageBitmap(bm);}else{//如果緩存不存在,從網(wǎng)絡(luò)下載System.out.println("從網(wǎng)上下載的");Thread t = new Thread(){@Overridepublic void run() {try {//2.把網(wǎng)址封裝成一個url對象URL url = new URL(path);//3.獲取客戶端和服務(wù)器的連接對象,此時還沒有建立連接HttpURLConnection conn = (HttpURLConnection) url.openConnection();//4.對連接對象進行初始化//設(shè)置請求方法,注意大寫conn.setRequestMethod("GET");//設(shè)置連接超時conn.setConnectTimeout(5000);//設(shè)置讀取超時conn.setReadTimeout(5000);//5.發(fā)送請求,與服務(wù)器建立連接conn.connect();//如果響應(yīng)碼為200,說明請求成功if(conn.getResponseCode() == 200){//獲取服務(wù)器響應(yīng)頭中的流,流里的數(shù)據(jù)就是客戶端請求的數(shù)據(jù)InputStream is = conn.getInputStream();//讀取服務(wù)器返回的流里的數(shù)據(jù),把數(shù)據(jù)寫到本地文件,緩存起來FileOutputStream fos = new FileOutputStream(file);byte[] b = new byte[1024];int len = 0;while((len = is.read(b)) != -1){fos.write(b, 0, len);}fos.close();//讀取出流里的數(shù)據(jù),并構(gòu)造成位圖對象//流里已經(jīng)沒有數(shù)據(jù)了 // Bitmap bm = BitmapFactory.decodeStream(is);Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());Message msg = new Message();//消息對象可以攜帶數(shù)據(jù)msg.obj = bm;msg.what = 1;//把消息發(fā)送至主線程的消息隊列handler.sendMessage(msg);}else{ // Toast.makeText(MainActivity.this, "請求失敗", 0).show();Message msg = handler.obtainMessage();msg.what = 0;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}}public String getFileName(String path){int index = path.lastIndexOf("/");return path.substring(index + 1);}}

1.6 案例2:帶緩存的網(wǎng)絡(luò)圖片查看器

public class MainActivity extends Activity {static ImageView iv;static MainActivity ma;static Handler handler = new Handler(){//此方法在主線程中調(diào)用,可以用來刷新uipublic void handleMessage(android.os.Message msg) {//處理消息時,需要知道到底是成功的消息,還是失敗的消息switch (msg.what) {case 1://把位圖對象顯示至imageviewiv.setImageBitmap((Bitmap)msg.obj);break;case 0:Toast.makeText(ma, "請求失敗", 0).show();break;}}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);iv = (ImageView) findViewById(R.id.iv);ma = this;}public void click(View v){//下載圖片//1.確定網(wǎng)址final String path = "http://192.168.13.13:8080/dd.jpg";final File file = new File(getCacheDir(), getFileName(path));//判斷,緩存中是否存在該文件if(file.exists()){//如果緩存存在,從緩存讀取圖片System.out.println("從緩存讀取的");Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());iv.setImageBitmap(bm);}else{//如果緩存不存在,從網(wǎng)絡(luò)下載System.out.println("從網(wǎng)上下載的");Thread t = new Thread(){@Overridepublic void run() {try {//2.把網(wǎng)址封裝成一個url對象URL url = new URL(path);//3.獲取客戶端和服務(wù)器的連接對象,此時還沒有建立連接HttpURLConnection conn = (HttpURLConnection) url.openConnection();//4.對連接對象進行初始化//設(shè)置請求方法,注意大寫conn.setRequestMethod("GET");//設(shè)置連接超時conn.setConnectTimeout(5000);//設(shè)置讀取超時conn.setReadTimeout(5000);//5.發(fā)送請求,與服務(wù)器建立連接conn.connect();//如果響應(yīng)碼為200,說明請求成功if(conn.getResponseCode() == 200){//獲取服務(wù)器響應(yīng)頭中的流,流里的數(shù)據(jù)就是客戶端請求的數(shù)據(jù)InputStream is = conn.getInputStream();//讀取服務(wù)器返回的流里的數(shù)據(jù),把數(shù)據(jù)寫到本地文件,緩存起來FileOutputStream fos = new FileOutputStream(file);byte[] b = new byte[1024];int len = 0;while((len = is.read(b)) != -1){fos.write(b, 0, len);}fos.close();//讀取出流里的數(shù)據(jù),并構(gòu)造成位圖對象//流里已經(jīng)沒有數(shù)據(jù)了 // Bitmap bm = BitmapFactory.decodeStream(is);Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());Message msg = new Message();//消息對象可以攜帶數(shù)據(jù)msg.obj = bm;msg.what = 1;//把消息發(fā)送至主線程的消息隊列handler.sendMessage(msg);}else{ // Toast.makeText(MainActivity.this, "請求失敗", 0).show();Message msg = handler.obtainMessage();msg.what = 0;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}}public String getFileName(String path){int index = path.lastIndexOf("/");return path.substring(index + 1);}}

1.7 案例3:開源圖片查看器

public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){//下載圖片//1.確定網(wǎng)址String path = "http://192.168.13.13:8080/dd.jpg";//2.找到智能圖片查看器對象SmartImageView siv = (SmartImageView) findViewById(R.id.iv);//3.下載并顯示圖片siv.setImageUrl(path);}}

2. 獲取開源代碼的網(wǎng)站

  • code.google.com
  • github.com
  • 在github搜索smart-image-view
  • 下載開源項目smart-image-view
  • 使用自定義組件時,標簽名字要寫包名
<com.loopj.android.image.SmartImageView/>
  • SmartImageView的使用
SmartImageView siv = (SmartImageView) findViewById(R.id.siv); siv.setImageUrl("http://192.168.1.102:8080/dd.jpg");

3. 新聞客戶端

public class MainActivity extends Activity {List<News> newsList;Handler handler = new Handler(){public void handleMessage(android.os.Message msg) {ListView lv = (ListView) findViewById(R.id.lv);lv.setAdapter(new MyAdapter());}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);getNewsInfo(); // ListView lv = (ListView) findViewById(R.id.lv); // //要保證在設(shè)置適配器時,新聞xml文件已經(jīng)解析完畢了 // lv.setAdapter(new MyAdapter());}class MyAdapter extends BaseAdapter{//得到模型層中元素的數(shù)量,用來確定listview需要有多少個條目@Overridepublic int getCount() {// TODO Auto-generated method stubreturn newsList.size();}@Override//返回一個View對象,作為listview的條目顯示至界面public View getView(int position, View convertView, ViewGroup parent) {News news = newsList.get(position);View v = null;ViewHolder mHolder;if(convertView == null){v = View.inflate(MainActivity.this, R.layout.item_listview, null);mHolder = new ViewHolder();//把布局文件中所有組件的對象封裝至ViewHolder對象中mHolder.tv_title = (TextView) v.findViewById(R.id.tv_title);mHolder.tv_detail = (TextView) v.findViewById(R.id.tv_detail);mHolder.tv_comment = (TextView) v.findViewById(R.id.tv_comment);mHolder.siv = (SmartImageView) v.findViewById(R.id.iv);//把ViewHolder對象封裝至View對象中v.setTag(mHolder);}else{v = convertView;mHolder = (ViewHolder) v.getTag();}//給三個文本框設(shè)置內(nèi)容mHolder.tv_title.setText(news.getTitle());mHolder.tv_detail.setText(news.getDetail());mHolder.tv_comment.setText(news.getComment() + "條評論");//給新聞圖片imageview設(shè)置內(nèi)容mHolder.siv.setImageUrl(news.getImageUrl());return v;}class ViewHolder{//條目的布局文件中有什么組件,這里就定義什么屬性TextView tv_title;TextView tv_detail;TextView tv_comment;SmartImageView siv;}@Overridepublic Object getItem(int position) {return null;}@Overridepublic long getItemId(int position) {return 0;}}private void getNewsInfo() {Thread t = new Thread(){@Overridepublic void run() {String path = "http://192.168.13.13:8080/news.xml";try {URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(5000);conn.setReadTimeout(5000);//發(fā)送http GET請求,獲取相應(yīng)碼if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();//使用pull解析器,解析這個流parseNewsXml(is);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}private void parseNewsXml(InputStream is) {XmlPullParser xp = Xml.newPullParser();try {xp.setInput(is, "utf-8");//對節(jié)點的事件類型進行判斷,就可以知道當(dāng)前節(jié)點是什么節(jié)點int type = xp.getEventType();News news = null;while(type != XmlPullParser.END_DOCUMENT){switch (type) {case XmlPullParser.START_TAG:if("newslist".equals(xp.getName())){newsList = new ArrayList<News>();}else if("news".equals(xp.getName())){news = new News();}else if("title".equals(xp.getName())){String title = xp.nextText();news.setTitle(title);}else if("detail".equals(xp.getName())){String detail = xp.nextText();news.setDetail(detail);}else if("comment".equals(xp.getName())){String comment = xp.nextText();news.setComment(comment);}else if("image".equals(xp.getName())){String image = xp.nextText();news.setImageUrl(image);}break;case XmlPullParser.END_TAG:if("news".equals(xp.getName())){newsList.add(news);}break;}//解析完當(dāng)前節(jié)點后,把指針移動至下一個節(jié)點,并返回它的事件類型type = xp.next();}//發(fā)消息,讓主線程設(shè)置listview的適配器,如果消息不需要攜帶數(shù)據(jù),可以發(fā)送空消息handler.sendEmptyMessage(1);// for (News n : newsList) { // System.out.println(n.toString()); // }} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}

3.1 案例5:新聞客戶端

public class MainActivity extends Activity {List<News> newsList;Handler handler = new Handler(){public void handleMessage(android.os.Message msg) {ListView lv = (ListView) findViewById(R.id.lv);lv.setAdapter(new MyAdapter());}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);getNewsInfo(); // ListView lv = (ListView) findViewById(R.id.lv); // //要保證在設(shè)置適配器時,新聞xml文件已經(jīng)解析完畢了 // lv.setAdapter(new MyAdapter());}class MyAdapter extends BaseAdapter{//得到模型層中元素的數(shù)量,用來確定listview需要有多少個條目@Overridepublic int getCount() {// TODO Auto-generated method stubreturn newsList.size();}@Override//返回一個View對象,作為listview的條目顯示至界面public View getView(int position, View convertView, ViewGroup parent) {News news = newsList.get(position);View v = null;ViewHolder mHolder;if(convertView == null){v = View.inflate(MainActivity.this, R.layout.item_listview, null);mHolder = new ViewHolder();//把布局文件中所有組件的對象封裝至ViewHolder對象中mHolder.tv_title = (TextView) v.findViewById(R.id.tv_title);mHolder.tv_detail = (TextView) v.findViewById(R.id.tv_detail);mHolder.tv_comment = (TextView) v.findViewById(R.id.tv_comment);mHolder.siv = (SmartImageView) v.findViewById(R.id.iv);//把ViewHolder對象封裝至View對象中v.setTag(mHolder);}else{v = convertView;mHolder = (ViewHolder) v.getTag();}//給三個文本框設(shè)置內(nèi)容mHolder.tv_title.setText(news.getTitle());mHolder.tv_detail.setText(news.getDetail());mHolder.tv_comment.setText(news.getComment() + "條評論");//給新聞圖片imageview設(shè)置內(nèi)容mHolder.siv.setImageUrl(news.getImageUrl());return v;}class ViewHolder{//條目的布局文件中有什么組件,這里就定義什么屬性TextView tv_title;TextView tv_detail;TextView tv_comment;SmartImageView siv;}@Overridepublic Object getItem(int position) {return null;}@Overridepublic long getItemId(int position) {return 0;}}private void getNewsInfo() {Thread t = new Thread(){@Overridepublic void run() {String path = "http://192.168.13.13:8080/news.xml";try {URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(5000);conn.setReadTimeout(5000);//發(fā)送http GET請求,獲取相應(yīng)碼if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();//使用pull解析器,解析這個流parseNewsXml(is);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}private void parseNewsXml(InputStream is) {XmlPullParser xp = Xml.newPullParser();try {xp.setInput(is, "utf-8");//對節(jié)點的事件類型進行判斷,就可以知道當(dāng)前節(jié)點是什么節(jié)點int type = xp.getEventType();News news = null;while(type != XmlPullParser.END_DOCUMENT){switch (type) {case XmlPullParser.START_TAG:if("newslist".equals(xp.getName())){newsList = new ArrayList<News>();}else if("news".equals(xp.getName())){news = new News();}else if("title".equals(xp.getName())){String title = xp.nextText();news.setTitle(title);}else if("detail".equals(xp.getName())){String detail = xp.nextText();news.setDetail(detail);}else if("comment".equals(xp.getName())){String comment = xp.nextText();news.setComment(comment);}else if("image".equals(xp.getName())){String image = xp.nextText();news.setImageUrl(image);}break;case XmlPullParser.END_TAG:if("news".equals(xp.getName())){newsList.add(news);}break;}//解析完當(dāng)前節(jié)點后,把指針移動至下一個節(jié)點,并返回它的事件類型type = xp.next();}//發(fā)消息,讓主線程設(shè)置listview的適配器,如果消息不需要攜帶數(shù)據(jù),可以發(fā)送空消息handler.sendEmptyMessage(1);// for (News n : newsList) { // System.out.println(n.toString()); // }} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}

4. Html源文件查看器

  • 發(fā)送GET請求
URL url = new URL(path); //獲取連接對象 HttpURLConnection conn = (HttpURLConnection) url.openConnection(); //設(shè)置連接屬性 conn.setRequestMethod("GET"); conn.setConnectTimeout(5000); conn.setReadTimeout(5000); //建立連接,獲取響應(yīng)嗎 if(conn.getResponseCode() == 200){}
  • 獲取服務(wù)器返回的流,從流中把html源碼讀取出來
byte[] b = new byte[1024]; int len = 0; ByteArrayOutputStream bos = new ByteArrayOutputStream(); while((len = is.read(b)) != -1){//把讀到的字節(jié)先寫入字節(jié)數(shù)組輸出流中存起來bos.write(b, 0, len); } //把字節(jié)數(shù)組輸出流中的內(nèi)容轉(zhuǎn)換成字符串 //默認使用utf-8 text = new String(bos.toByteArray());

4.1 亂碼的處理

  • 亂碼的出現(xiàn)是因為服務(wù)器和客戶端碼表不一致導(dǎo)致
//手動指定碼表 text = new String(bos.toByteArray(), "gb2312");

4.2 案例4:HTML源文件查看器

public class MainActivity extends Activity {Handler handler = new Handler(){public void handleMessage(android.os.Message msg) {TextView tv = (TextView) findViewById(R.id.tv);tv.setText((String)msg.obj);}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void click(View v){Thread t = new Thread(){@Overridepublic void run() {String path = "http://192.168.13.13:8080/baidu.html";try {URL url = new URL(path);//獲取連接對象,此時還未建立連接HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(5000);conn.setReadTimeout(5000);//先建立連接,然后獲取響應(yīng)碼if(conn.getResponseCode() == 200){//拿到服務(wù)器返回的輸入流,流里的數(shù)據(jù)就是html的源文件InputStream is = conn.getInputStream();//從流里把文本數(shù)據(jù)取出來String text = Utils.getTextFromStream(is);//發(fā)送消息,讓主線程刷新ui,顯示源文件Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}}

5. 提交數(shù)據(jù)

5.1 GET方式提交數(shù)據(jù)

  • get方式提交的數(shù)據(jù)是直接拼接在url的末尾
final String path = "http://192.168.1.104/Web/servlet/CheckLogin?name=" + name + "&pass=" + pass;
  • 發(fā)送get請求,代碼和之前一樣
URL url = new URL(path); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("GET"); conn.setReadTimeout(5000); conn.setConnectTimeout(5000); if(conn.getResponseCode() == 200){}
  • 瀏覽器在發(fā)送請求攜帶數(shù)據(jù)時會對數(shù)據(jù)進行URL編碼,我們寫代碼時也需要為中文進行URL編碼
String path = "http://192.168.1.104/Web/servlet/CheckLogin?name=" + URLEncoder.encode(name) + "&pass=" + pass;

5.2 案例6:使用get方式提交數(shù)據(jù)

public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}Handler handler = new Handler(){public void handleMessage(android.os.Message msg) {Toast.makeText(MainActivity.this, (String)msg.obj, 0).show();}};public void click(View v){EditText et_name = (EditText) findViewById(R.id.et_name);EditText et_pass = (EditText) findViewById(R.id.et_pass);final String name = et_name.getText().toString();final String pass = et_pass.getText().toString();Thread t = new Thread(){@Overridepublic void run() {//提交的數(shù)據(jù)需要經(jīng)過url編碼,英文和數(shù)字編碼后不變@SuppressWarnings("deprecation")String path = "http://192.168.13.13/Web2/servlet/LoginServlet?name=" + URLEncoder.encode(name) + "&pass=" + pass;try {URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("GET");conn.setConnectTimeout(5000);conn.setReadTimeout(5000);if(conn.getResponseCode() == 200){InputStream is =conn.getInputStream();String text = Utils.getTextFromStream(is);Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();}} public class Utils {public static String getTextFromStream(InputStream is){byte[] b = new byte[1024];int len = 0;//創(chuàng)建字節(jié)數(shù)組輸出流,讀取輸入流的文本數(shù)據(jù)時,同步把數(shù)據(jù)寫入數(shù)組輸出流ByteArrayOutputStream bos = new ByteArrayOutputStream();try {while((len = is.read(b)) != -1){bos.write(b, 0, len);}//把字節(jié)數(shù)組輸出流里的數(shù)據(jù)轉(zhuǎn)換成字節(jié)數(shù)組String text = new String(bos.toByteArray());return text;} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}return null;} }

5.3 POST方式提交數(shù)據(jù)

  • post提交數(shù)據(jù)是用流寫給服務(wù)器的
  • 協(xié)議頭中多了兩個屬性
    • Content-Type: application/x-www-form-urlencoded,描述提交的數(shù)據(jù)的mimetype
    • Content-Length: 32,描述提交的數(shù)據(jù)的長度
//給請求頭添加post多出來的兩個屬性 String data = "name=" + URLEncoder.encode(name) + "&pass=" + pass; conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); conn.setRequestProperty("Content-Length", data.length() + "");
  • 設(shè)置允許打開post請求的流
conn.setDoOutput(true);
  • 獲取連接對象的輸出流,往流里寫要提交給服務(wù)器的數(shù)據(jù)
OutputStream os = conn.getOutputStream(); os.write(data.getBytes());

5.4 案例7:使用post方式提交數(shù)據(jù)

public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}Handler handler = new Handler(){public void handleMessage(android.os.Message msg) {Toast.makeText(MainActivity.this, (String)msg.obj, 0).show();}};public void click(View v){EditText et_name = (EditText) findViewById(R.id.et_name);EditText et_pass = (EditText) findViewById(R.id.et_pass);final String name = et_name.getText().toString();final String pass = et_pass.getText().toString();Thread t = new Thread(){@Overridepublic void run() {//提交的數(shù)據(jù)需要經(jīng)過url編碼,英文和數(shù)字編碼后不變@SuppressWarnings("deprecation")String path = "http://192.168.13.13/Web2/servlet/LoginServlet";try {URL url = new URL(path);HttpURLConnection conn = (HttpURLConnection) url.openConnection();conn.setRequestMethod("POST");conn.setConnectTimeout(5000);conn.setReadTimeout(5000);//拼接出要提交的數(shù)據(jù)的字符串String data = "name=" + URLEncoder.encode(name) + "&pass=" + pass;//添加post請求的兩行屬性conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");conn.setRequestProperty("Content-Length", data.length() + "");//設(shè)置打開輸出流conn.setDoOutput(true);//拿到輸出流OutputStream os = conn.getOutputStream();//使用輸出流往服務(wù)器提交數(shù)據(jù)os.write(data.getBytes());if(conn.getResponseCode() == 200){InputStream is = conn.getInputStream();String text = Utils.getTextFromStream(is);Message msg = handler.obtainMessage();msg.obj = text;handler.sendMessage(msg);}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}};t.start();} }

6. 網(wǎng)絡(luò)請求

6.1 主線程阻塞

  • UI停止刷新,應(yīng)用無法響應(yīng)用戶操作
  • 耗時操作不應(yīng)該在主線程進行
  • ANR

    • application not responding
    • 應(yīng)用無響應(yīng)異常
    • 主線程阻塞時間過長,就會拋出ANR
  • 主線程又稱UI線程,因為只有在主線程中,才能刷新UI

6.2 消息隊列機制

  • 主線程創(chuàng)建時,系統(tǒng)會同時創(chuàng)建消息隊列對象(MessageQueue)和消息輪詢器對象(Looper)
  • 輪詢器的作用,就是不停的檢測消息隊列中是否有消息(Message)
  • 消息隊列一旦有消息,輪詢器會把消息對象傳給消息處理器(Handler),處理器會調(diào)用handleMessage方法來處理這條消息,handleMessage方法運行在主線程中,所以可以刷新ui
  • 總結(jié):只要消息隊列有消息,handleMessage方法就會調(diào)用
  • 子線程如果需要刷新ui,只需要往消息隊列中發(fā)一條消息,觸發(fā)handleMessage方法即可
  • 子線程使用處理器對象的sendMessage方法發(fā)送消息

總結(jié)

以上是生活随笔為你收集整理的Android应用开发:网络编程-1的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

国产一级高清 | 日日操天天操夜夜操 | 国产91小视频| 国产护士hd高朝护士1 | 91av原创| 日本免费久久高清视频 | 精品一区二区免费视频 | 91久久久久久国产精品 | 欧美日韩二区三区 | 97在线看片 | 在线观看日韩视频 | 久草在线观看视频免费 | 国产色网站 | 国产日产在线观看 | 999国内精品永久免费视频 | 国产精品九九九九九九 | 亚洲精品国产麻豆 | 久久久久电影 | 在线观看小视频 | av色一区| 91精品一区二区三区蜜桃 | 中文字幕乱视频 | 国产精品麻豆99久久久久久 | 色爱区综合激月婷婷 | 丁香av | 日日夜夜噜 | 久久99在线观看 | 久久99久久99精品免观看软件 | 久久久久久黄色 | 国产精品久久久久久久久久久久午夜片 | 国产一区二区视频在线 | 国产美女精品视频免费观看 | 91久久国产综合精品女同国语 | 亚洲精品动漫久久久久 | 成年人app网址 | 欧美人牲 | 国产视频99| 欧美大片在线观看一区 | 欧美精品在线观看一区 | 国产成人精品一区二区三区福利 | 少妇bbbb搡bbbb搡bbbb | 午夜精品一二三区 | 免费a级大片 | 精品国产aⅴ麻豆 | av网址最新 | 人人干人人做 | 欧美激情视频一区二区三区免费 | 久久图| 亚洲精品在线观看不卡 | 又黄又爽又湿又无遮挡的在线视频 | 久久草网| 国产黄色片免费在线观看 | 国产精品久久人 | 国产又粗又硬又爽的视频 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 波多野结衣视频网址 | 黄色成人在线观看 | 在线观看日韩免费视频 | 天天射天天干天天 | 奇米网网址 | 国产欧美精品xxxx另类 | 最新中文字幕视频 | 深爱激情av | 91精品一| 久久综合狠狠狠色97 | 亚洲女在线| 超碰人人91| 亚洲成人软件 | 国产日韩精品久久 | 在线观看日韩中文字幕 | 99国产在线视频 | 天天操天天曰 | 91成品人影院 | free. 性欧美.com| 久久五月天色综合 | 中文字幕免费一区 | 免费在线国产 | 国产精品免费在线视频 | 久草视频在线免费看 | 亚洲成人午夜av | 日韩中文字幕在线看 | 中文在线8资源库 | 欧美午夜寂寞影院 | 国产 一区二区三区 在线 | 久久激情网站 | 国产馆在线播放 | 超碰久热 | 天天色综合三 | av在线小说 | 超碰成人av| 亚洲国产日韩欧美在线 | 久久综合精品一区 | 美女国产在线 | 久久一精品 | 精品久久网 | 九九免费精品视频 | 国产麻豆视频免费观看 | 国产一级视屏 | 91精品国产欧美一区二区成人 | av在线播放观看 | 色婷婷在线观看视频 | 久久精品在线免费观看 | 成人18视频| 91看毛片 | 日本精品视频在线播放 | 亚洲精品456在线播放 | 国产女v资源在线观看 | 亚洲精品视频网站在线观看 | av免费看在线 | 日韩深夜在线观看 | 国产在线观看一区 | 日本超碰在线 | 色婷婷久久一区二区 | 亚洲精品男人的天堂 | 右手影院亚洲欧美 | 欧美在线视频a | 丁香婷婷色月天 | 手机av在线网站 | 在线导航av| 国产 一区二区三区 在线 | 国产黑丝袜在线 | 国产精品videoxxxx | 在线 欧美 日韩 | 日韩激情视频 | 久久久久亚洲国产精品 | 日韩精品视频在线观看网址 | 久久午夜精品 | 丁香伊人网 | 日韩视频一区二区三区在线播放免费观看 | 久久黄色片子 | 97碰碰精品嫩模在线播放 | 国产一区在线观看免费 | 国产精品久久久久久久久久免费 | 婷婷免费在线视频 | 91自拍视频在线观看 | 日韩视频一区二区在线 | 国产精品专区一 | 午夜视频免费播放 | 黄色的视频网站 | 免费亚洲婷婷 | 久久a v电影 | 天天想夜夜操 | 精品久久久久久久久久久久久 | 在线免费色视频 | 天堂久色| 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 在线国产欧美 | 天堂av观看 | 日韩欧美在线国产 | 日韩在线视频一区二区三区 | 欧美极品在线播放 | 黄色软件大全网站 | 天天操天天干天天摸 | 日本中文字幕在线 | 免费看一级特黄a大片 | 色多多视频在线观看 | 一 级 黄 色 片免费看的 | av电影免费在线 | 国内久久视频 | 夜夜爱av | 97超碰在线免费 | 久久视频在线观看 | 香蕉久草 | 日日干日日色 | 九色91在线| 日本中文字幕在线免费观看 | 亚洲精品网页 | 国产日产高清dvd碟片 | 91精品国自产拍天天拍 | 在线日韩| 国产精品一区二区久久久 | 欧美午夜理伦三级在线观看 | 欧美日韩一区二区免费在线观看 | 国产 在线观看 | 国产v视频 | 久久久久久久久久久综合 | 在线观看免费色 | 99久久99精品| 成年人在线免费看视频 | 中文久草 | 在线免费观看视频一区二区三区 | 天天摸日日操 | 日韩在线观看你懂的 | 在线观看av的网站 | 中文日韩在线 | 国产精品久久久久9999吃药 | 五月天狠狠操 | 在线播放精品一区二区三区 | 日韩在线欧美在线 | 成人精品影视 | 最新日本中文字幕 | 日韩黄色一级电影 | 欧美高清视频不卡网 | 在线观看亚洲视频 | 精品999国产 | 免费在线观看污网站 | 欧美成人xxxxx | 日韩电影在线观看中文字幕 | 在线免费黄 | 97视频免费在线看 | 91精品久久久久 | 亚洲精品午夜久久久久久久 | 在线播放精品一区二区三区 | 亚洲尺码电影av久久 | avhd高清在线谜片 | 色偷偷97 | 66av99精品福利视频在线 | 日本少妇久久久 | 午夜视频亚洲 | 免费国产亚洲视频 | 日韩av成人免费看 | 1024在线看片 | 天天摸日日摸人人看 | 国产精品久久久久久久久久新婚 | 久久精品99视频 | 日韩在线视频不卡 | 久久久久久久久久久免费av | 久久伦理电影网 | 热久久国产精品 | 成人av久久 | 久草久热 | 91精品国产高清自在线观看 | 超碰人人99 | av 在线观看 | 精品免费在线视频 | 婷婷激情网站 | 狠狠伊人 | 又爽又黄在线观看 | 久久精品日产第一区二区三区乱码 | 日日干夜夜干 | 91最新网址在线观看 | 日韩黄色免费看 | 在线精品在线 | 毛片永久免费 | 亚洲天天在线日亚洲洲精 | 久久精品中文字幕少妇 | 毛片在线网 | 国产成人av综合色 | 少妇av片| 国产精品免费小视频 | 中文字幕美女免费在线 | 手机av永久免费 | 激情久久久久久久久久久久久久久久 | 日韩二区在线观看 | 字幕网av | 免费在线视频一区二区 | 国产精品美女久久久久久 | 在线免费高清一区二区三区 | 99亚洲视频 | 国产黄色片一级三级 | 日本在线观看一区二区 | 国产精品久久久视频 | 亚洲成av | 欧美无极色 | 国内综合精品午夜久久资源 | 国产婷婷色 | 国产精品麻豆果冻传媒在线播放 | 免费视频xnxx com| 在线中文字幕播放 | 成人免费在线观看av | 国产精品久久久免费 | 美女视频黄免费的久久 | 欧美动漫一区二区三区 | 欧美成人理伦片 | 丝袜美腿亚洲 | 日韩精品免费 | 国产精品999久久久 久产久精国产品 | 亚洲精品综合一二三区在线观看 | 国产69精品久久app免费版 | 91久久精品一区 | 91成人免费观看视频 | 婷婷网站天天婷婷网站 | 国产在线观看中文字幕 | 日韩av二区 | av网站在线免费观看 | 亚洲精品免费观看视频 | 免费欧美 | av在线网站免费观看 | 成人av在线看 | 日韩免费视频在线观看 | 麻豆国产精品va在线观看不卡 | 亚洲一区动漫 | 中文在线免费一区三区 | 91精品国产乱码久久 | 在线99| 在线观看日韩国产 | 亚洲一二三在线 | 欧美亚洲另类在线视频 | 91综合色| 激情中文字幕 | av黄色影院 | 美女福利视频一区二区 | 亚洲视频分类 | 国产精品久久久一区二区三区网站 | av在线免费播放网站 | 操操操干干干 | 日韩精品视频在线观看网址 | 色欲综合视频天天天 | 狠狠婷婷 | 五月婷婷久 | 欧美性粗大hdvideo | 国产日韩欧美在线观看 | 91在线网址| 日本黄色免费大片 | 欧美最猛性xxxx | 黄色毛片在线看 | 色综合色综合色综合 | 一区二区三区在线免费 | 亚洲国内精品在线 | 91精品在线免费视频 | 1区2区3区在线观看 三级动图 | 粉嫩一区二区三区粉嫩91 | 亚洲一级在线观看 | av经典在线 | 人人舔人人舔 | av电影中文字幕在线观看 | 韩国精品福利一区二区三区 | 日韩av二区 | 国产精品自在欧美一区 | 91最新国产 | 亚洲毛片视频 | 成人在线观看av | 欧美日韩国产精品久久 | 偷拍视频一区 | 99高清视频有精品视频 | 婷婷成人综合 | 午夜av在线电影 | 亚洲综合网站在线观看 | 蜜桃麻豆www久久囤产精品 | 亚一亚二国产专区 | 日韩欧美网址 | 久黄色 | 精品人妖videos欧美人妖 | 国产又粗又硬又长又爽的视频 | 伊人黄色网 | 一区二区三区四区五区六区 | 日韩精品在线看 | 亚州av成人 | 日韩在线视频看看 | 久艹在线播放 | 国内精品久久久久影院优 | 亚a在线 | 免费看三级黄色片 | 国产视频精选 | 免费观看性生活大片3 | 亚洲精品视频中文字幕 | 超碰97人人干 | 91丨九色丨高潮 | 不卡国产视频 | 欧美成人黄| 精品国产电影一区二区 | 午夜精选视频 | 99视频免费 | 在线视频婷婷 | 三级av中文字幕 | 人人干人人搞 | 日韩美女高潮 | 99久久婷婷国产一区二区三区 | 久久中文字幕导航 | 亚洲精品国产综合久久 | 免费看十八岁美女 | 国产精品美女久久久久aⅴ 干干夜夜 | 五月婷香| 五月天婷亚洲天综合网鲁鲁鲁 | 国产亚洲精品福利 | 成人免费视频视频在线观看 免费 | 中文字幕资源网 国产 | 久久精品波多野结衣 | 中文字幕 国产视频 | 国产亚洲成人精品 | 色婷婷婷 | 国产久草在线观看 | 午夜久久久久久久久久久 | 色a在线观看 | 干干操操| 色a网| 欧美精品久久久久久久久久丰满 | 久草国产精品 | 色婷婷丁香 | 99精品在线视频播放 | 亚洲成人二区 | 91cn国产在线 | 午夜影院一级 | a黄色片在线观看 | 九九免费在线观看 | 精品伊人久久久 | 天天操月月操 | 中文字幕av最新 | 国产精品麻豆99久久久久久 | 操操操日日日干干干 | 亚洲六月丁香色婷婷综合久久 | 色综合久久网 | 黄色最新网址 | 9热精品 | 又黄又爽又色无遮挡免费 | 69xxxx欧美 | 亚洲综合在线视频 | 亚洲免费激情 | 国产韩国日本高清视频 | 99精品国产福利在线观看免费 | 欧美久久久久 | 日韩艹| 国产精品久久久久久久av电影 | 狠狠干夜夜爱 | 91在线免费播放视频 | 米奇四色影视 | 三级av在线免费观看 | 天天干天天搞天天射 | 欧美性极品xxxx娇小 | 日本在线观看黄色 | 国产在线一区观看 | 91成版人在线观看入口 | 日韩精品中文字幕在线观看 | 天堂av一区二区 | 欧美资源在线观看 | 久久久精品国产免费观看一区二区 | 天天摸日日摸人人看 | 97免费| 久久成电影 | 日韩av黄 | 一区二区男女 | 精品国产资源 | 最近最新中文字幕视频 | 狠狠色丁香婷婷综合最新地址 | 成人观看 | 中文字幕在线观看网 | 国内久久久久 | 色婷婷综合成人av | 国产一区二区在线播放视频 | 久草在线视频免费资源观看 | 91av蜜桃| 亚洲欧美精品在线 | 亚洲精品婷婷 | av爱干| 国产一级片免费视频 | 狠狠操欧美 | 午夜精品久久久久久久爽 | av电影在线播放 | 日本在线视频网址 | 久久久久久久18 | av黄色在线 | 亚洲精品一区二区久 | 欧美伦理电影一区二区 | 亚洲成人免费在线 | 久久在现 | 日韩av不卡在线观看 | aⅴ视频在线| 免费在线观看黄 | 免费久久99精品国产 | 天天色天天操天天爽 | 999日韩 | 很黄很黄的网站免费的 | 91精品免费视频 | 久久综合福利 | 狠狠干 狠狠操 | av中文在线观看 | 欧美日韩高清一区二区三区 | 日日夜夜91 | 狠狠色丁香婷婷 | 色视频成人在线观看免 | 国产99色 | 超碰在线98| 在线看成人 | 精品国产自在精品国产精野外直播 | 伊人国产女 | 91免费在线 | 中文伊人| 一区二区不卡视频在线观看 | 免费亚洲成人 | 久久久久亚洲天堂 | 欧美日韩国产一区二区三区 | 久射网| 亚洲精品日韩一区二区电影 | www.狠狠色| 日韩免费av网址 | 国产不卡毛片 | 特级西西人体444是什么意思 | 97人人澡人人添人人爽超碰 | 在线国产福利 | 国产欧美精品一区二区三区四区 | 丁香午夜 | 国产精品久久久久婷婷 | 免费在线观看成人 | 亚洲一区二区视频在线 | 国产99久久精品一区二区300 | 一区二区国产精品 | 99色| 麻豆成人精品 | 午夜精品一区二区三区在线视频 | 成年人电影免费看 | 中文字幕在线观看不卡 | 亚洲精品2区 | 午夜12点 | 国产一区二区三区在线免费观看 | 91在线精品一区二区 | 午夜精品电影 | 热99久久精品 | 日韩在线观看一区二区 | 欧美日韩视频一区二区三区 | 日韩欧美一区视频 | 免费看十八岁美女 | 国产亚洲亚洲 | 国产91av视频在线观看 | 国产视频一区二区在线 | 日日爱网站 | 久久综合九色综合久久久精品综合 | 国产精品美女久久久久久网站 | 一区二区视频在线观看免费 | 最近中文字幕高清字幕免费mv | 日本电影黄色 | 成人在线免费视频观看 | 亚洲一区欧美激情 | www.超碰97.com| 狠狠久久综合 | 久久亚洲综合国产精品99麻豆的功能介绍 | 免费大片黄在线 | av中文字幕免费在线观看 | 成人免费在线播放 | 在线观看免费版高清版 | 麻豆传媒视频观看 | 国产免费亚洲 | 久久精品视频中文字幕 | av资源免费看 | 国产成人综合在线观看 | 国产精品美女999 | 婷香五月 | 在线有码中文字幕 | 日本中文一级片 | 欧美成人精品xxx | 一区二区三区免费在线观看视频 | 五月天视频网站 | 久久精品国产精品亚洲精品 | 精品久久久久久久久久久久 | 2019免费中文字幕 | 97超碰总站 | 91亚洲精品久久久蜜桃网站 | 欧美九九九 | 成人黄色小说网 | 精品国产一区二区三区四区在线观看 | 国产福利91精品一区二区三区 | 亚洲欧美精品一区二区 | 91豆花在线 | 国产原创在线 | 一区二区电影在线观看 | 国产探花| www黄色com | 国产精品一区二区三区视频免费 | 亚洲va欧美va| 超碰在线网 | 在线观看不卡视频 | 欧美在线观看小视频 | av电影中文字幕 | 日本三级大片 | 免费无遮挡动漫网站 | 国产精品国内免费一区二区三区 | 人人澡超碰碰 | 中文字幕在线视频一区二区 | 日韩激情精品 | 精品国产乱码久久久久久三级人 | 国产精品美女视频网站 | 亚洲精品在线观看av | 亚洲综合色网站 | 久久精品国产免费看久久精品 | 99精品国产99久久久久久97 | 中文字幕精品在线 | 亚洲欧美视频在线观看 | 天天干天天干天天 | 日日婷婷夜日日天干 | 久草在线视频资源 | 日韩久久精品一区二区三区下载 | 免费久久99精品国产婷婷六月 | 天天操天天拍 | 一级一片免费视频 | 精品国产乱子伦一区二区 | 国产在线观看av | av九九九| 久久久精品免费观看 | a级国产片 | 青青射 | 日韩久久视频 | 久久免费片| 亚洲精品中文字幕在线 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 在线网址你懂得 | jizz18欧美18| 97人人超碰在线 | 六月久久婷婷 | 99久久国产免费看 | 日韩在线在线 | 黄网站免费大全入口 | 久久99精品久久只有精品 | 99精品欧美一区二区 | 日韩免费观看高清 | 国产精品h在线观看 | 亚洲亚洲精品在线观看 | 国产小视频国产精品 | 欧美黄色成人 | 久久久久久免费毛片精品 | 九九久久成人 | 波多野结衣在线观看一区二区三区 | 少妇bbbb搡bbbb桶 | 亚洲在线视频观看 | 波多野结衣在线观看一区二区三区 | 激情av网址 | 热久久视久久精品18亚洲精品 | 超碰在线人 | 国产精品6999成人免费视频 | 免费看一级一片 | 天天操天天操 | 在线精品视频免费播放 | 免费av片在线 | 国产在线黄色 | 亚洲三级在线免费观看 | 国产亚洲在线 | 成人啪啪18免费游戏链接 | 久久免费激情视频 | 国产精品不卡在线 | 区一区二区三在线观看 | 99精品乱码国产在线观看 | 日韩三级视频在线看 | 国产在线999 | 黄色免费电影网站 | 欧美日韩一区二区三区免费视频 | 不卡av在线免费观看 | 国际精品久久 | 在线观看国产麻豆 | 草久久久久久 | 色婷婷久久 | 激情狠狠干 | 国产精品久久久久久久久久免费 | 五月天色综合 | 97超碰在| 亚洲一区二区视频在线 | 国产在线观看a | 毛片网站在线观看 | 成人精品一区二区三区电影免费 | 伊人精品影院 | 亚洲欧美日本国产 | 精品国内自产拍在线观看视频 | 五月婷综合| 四虎成人网 | 91成人精品一区在线播放 | 精品999 | 亚洲精品999| 欧美有色| 欧美射射射 | 91精品一区二区三区久久久久久 | 黄色a大片| 久久久人人爽 | 日韩免费电影在线观看 | 日韩欧美在线观看 | 91免费版成人 | 国产黄色一级大片 | 天干啦夜天干天干在线线 | 欧美三级高清 | a天堂一码二码专区 | 天天躁日日躁狠狠躁 | 亚洲一区二区精品视频 | 国产91大片 | 国产一级黄色免费看 | 亚洲va在线va天堂va偷拍 | 久久蜜臀一区二区三区av | 99热精品在线观看 | 日韩高清一区二区 | 日韩精品亚洲专区在线观看 | 玖玖精品视频 | av网站在线观看播放 | 人人射人人插 | 国产精品女人久久久 | 日韩欧美视频在线免费观看 | 久久免费观看少妇a级毛片 久久久久成人免费 | 久久一区国产 | 天天操天天操天天操天天操 | 奇米影视四色8888 | 99精品在线免费观看 | www.色五月| 亚洲小视频在线观看 | 亚洲精品在线国产 | 日韩在线观看网址 | www激情网| 日韩a级黄色片 | 久久久久久久久久久久电影 | 日本午夜在线亚洲.国产 | 91免费高清视频 | 五月天高清欧美mv | 国产高清中文字幕 | 国产精品大片在线观看 | 色噜噜日韩精品欧美一区二区 | 欧美成a人片在线观看久 | 色香蕉网| 亚洲视频在线播放 | 久久久久久久久久久免费视频 | 色老板在线 | 亚洲午夜精品在线观看 | 久久视频一区二区 | 欧美日韩精品国产 | 美女久久久久 | 久久精品亚洲一区二区三区观看模式 | 91手机电视 | 在线观看小视频 | 亚洲欧美日韩精品一区二区 | 色综合天天狠天天透天天伊人 | 五月婷婷影院 | 最近中文字幕视频网 | 人人涩 | 国产专区在线播放 | 国产中文视 | 二区三区精品 | 亚洲一区二区黄色 | 91理论电影 | 亚洲色影爱久久精品 | 国产精品一区二区在线免费观看 | 久久99影院 | 婷婷射五月 | 天天透天天插 | 中文字幕文字幕一区二区 | 五月天婷婷免费视频 | 国产福利免费在线观看 | 超碰在线免费福利 | 黄色的网站免费看 | 国产区av在线 | 成人毛片一区二区三区 | 白丝av免费观看 | 91麻豆精品 | 国产免费三级在线观看 | 蜜桃av综合网 | 麻豆视频在线观看 | 超碰97人人射妻 | 狠狠操狠狠干2017 | 91免费高清 | 99精品视频免费观看视频 | 高潮久久久久久久久 | 色狠狠干 | 天天操天天操天天操天天操天天操 | 中文字幕成人网 | 91精品夜夜 | 国产高清视频在线观看 | 国产精品久久久久久久久久免费看 | 久久久久 | 久久久www| 涩涩色亚洲一区 | 97电影院网 | 少妇性色午夜淫片aaaze | 97中文字幕 | 手机成人av在线 | 91污视频在线观看 | 91看片黄色 | 久久精品欧美一 | 成人小视频免费在线观看 | 毛片一级免费一级 | 中文字幕在线免费看线人 | 亚洲精品乱码久久久久久高潮 | 日韩三级.com | 五月天婷亚洲天综合网精品偷 | 丰满少妇对白在线偷拍 | 美女视频黄,久久 | 欧美a级片网站 | 玖玖玖在线观看 | 亚洲精品天天 | 欧美精品第一 | 久草在线资源视频 | 婷婷av电影 | 亚洲伦理中文字幕 | 蜜臀久久99精品久久久久久网站 | 91在线资源 | 亚洲国产免费看 | 日韩电影一区二区三区 | 国产成人av电影 | 美女网站视频色 | 亚洲精品高清视频 | 欧美大码xxxx | 在线精品一区二区 | 久久久高清 | 日韩电影精品 | 国产 日韩 中文字幕 | 免费看的黄色网 | 久久少妇 | 欧美激情精品久久 | 中文字幕在线视频第一页 | 国产精品午夜8888 | 91麻豆精品国产91久久久无限制版 | 99视频久| 国产不卡视频在线播放 | 国产成人一区二区三区久久精品 | 日日夜夜中文字幕 | 久久大视频 | 日韩av免费一区二区 | 视频精品一区二区三区 | 久久五月婷婷丁香 | japanesexxxhd奶水 国产一区二区在线免费观看 | 中文字幕在线观看免费 | 日日操日日 | 爱爱一区 | 奇米网网址 | 日韩成人邪恶影片 | 永久免费看av | 五月婷婷影院 | 久久人视频 | 欧美亚洲一区二区在线 | 国产一区二区视频在线 | 久久伊人精品一区二区三区 | 中文字幕精品视频 | 亚洲精品午夜久久久久久久久久久 | 免费黄色网址大全 | 韩日电影在线免费看 | 极品美女被弄高潮视频网站 | 日韩高清在线一区二区三区 | 91成人区 | 免费a v观看 | 99精品在线免费视频 | 99视频偷窥在线精品国自产拍 | 亚洲aⅴ免费在线观看 | 五月婷婷天堂 | 天天天天干 | 久久热亚洲| 国产精品国内免费一区二区三区 | 五月天中文在线 | 久久午夜视频 | 国产一区二区在线免费播放 | av天天草| 精品一区二区在线观看 | 日韩电影在线观看一区二区 | 久久久久久久久久久网 | 国产一区二区在线观看免费 | 久久综合99 | 色视频网站在线 | av成人免费在线看 | av不卡免费在线观看 | 中文字幕av播放 | 在线免费观看av网站 | 久久精品这里热有精品 | 国产探花视频在线播放 | 国产久草在线观看 | 国产精品一区免费观看 | 日韩精品久久一区二区三区 | 成人黄色大片在线免费观看 | 麻豆91在线观看 | av黄色在线观看 | 久草免费手机视频 | 国产精品一区二区三区99 | 日韩精品一区电影 | 二区三区中文字幕 | 久久精品系列 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 国产一级片一区二区三区 | 91视频在线网址 | 二区三区毛片 | 福利电影一区二区 | 免费在线观看黄网站 | 在线亚洲日本 | 日韩av高清 | www.eeuss影院av撸 | 91大神一区二区三区 | 国产精品黑丝在线观看 | 欧美一级片在线免费观看 | 91成人精品一区在线播放 | 成人动漫一区二区 | 精品久久一区二区三区 | 激情综合网色播五月 | 三级a毛片 | 91免费在线视频 | 日韩中文在线视频 | 久久不射电影院 | 911久久香蕉国产线看观看 | 人人cao| 久久精品亚洲 | 国产亚洲午夜高清国产拍精品 | 韩日在线一区 | 在线观看色网 | 香蕉国产91 | 成人黄在线 | 天天射天天干天天 | 久久午夜网 | x99av成人免费| 亚洲成人av片 | 亚洲高清在线视频 | www久久99 | 三上悠亚一区二区在线观看 | 中文字幕一区在线 | 免费观看成人 | 免费看成人a | 免费热情视频 | 免费视频 你懂的 | 美女久久久久久久 | 又爽又黄在线观看 | 免费三级黄色 | 日韩欧美在线免费观看 | 人人草网站 | 高清在线一区二区 | 永久免费毛片 | 2019av在线视频 | 国产高清在线看 | 欧美黄色软件 | 丁香六月天婷婷 | 欧美日韩亚洲国产一区 | 久草免费资源 | 人人干人人干人人干 | 国产成人精品一区二三区 | 国产精品福利视频 | 五月婷在线 | 久久久久久久久久国产精品 | 久久黄色精品视频 | 日韩在线观看精品 | 最新中文字幕在线播放 | 久久免费精品 | 日本中文字幕影院 | 天天干.com| 免费在线观看视频一区 | 久久人人爽爽 | 片网站| 91在线小视频 | 超碰在线中文字幕 | 成人日批视频 | 久久综合天天 | 亚洲经典视频 | 久热av| 99久久精品免费看国产四区 | 久久91久久久久麻豆精品 | 公与妇乱理三级xxx 在线观看视频在线观看 | 久久伊人精品天天 | 美女福利视频一区二区 | 午夜色大片在线观看 | 瑞典xxxx性hd极品| 四虎国产精品成人免费4hu | 久久久福利视频 | 日韩在线一区二区免费 | 国产视频一区二区三区在线 | 婷婷久久亚洲 | 久久伊人精品一区二区三区 | 久色 网| 中文字幕国产一区 | 中文字幕在线字幕中文 | 国产精品18久久久久久久网站 | 午夜久久久影院 | 精品不卡av | 一区二区三区视频网站 | 奇米网在线观看 | 亚洲国产天堂av | 在线免费国产视频 | 九九免费在线看完整版 | 香蕉97视频观看在线观看 | www黄色软件 | 亚洲撸撸 | 久久亚洲精品电影 | 精品黄色片 | 成年人网站免费在线观看 | 欧美视屏一区二区 | 四虎永久精品在线 | 91九色成人蝌蚪首页 | 国产精品国产亚洲精品看不卡 | 国产精品久久久久国产精品日日 | 69国产在线观看 | 日韩网 | 岛国av在线 | www国产亚洲精品久久麻豆 | 欧美一区二区三区不卡 | 日本中文字幕一二区观 | 亚洲精品在线观看中文字幕 | 国产色在线观看 | 日日夜夜国产 | 国产亚洲视频中文字幕视频 | 国产精品欧美久久久久无广告 | 欧美一区二区三区四区夜夜大片 | 国产无套精品久久久久久 | 国产精品欧美久久久久三级 | 免费网站观看www在线观看 | 999国内精品永久免费视频 | 97超碰人人爱 | 99热这里有 | 男女拍拍免费视频 | 在线观看网站av | 久久久久国产精品视频 | 国产日产精品一区二区三区四区的观看方式 | 五月婷婷爱 | 午夜av电影院 | 天天干天天色2020 | 欧美精品天堂 | 国产亚洲精品久久久久久久久久久久 | 久草在线免费色站 | 国产美女免费看 | 久久视频二区 | 亚洲精品乱码久久久久久按摩 | 国产精品亚洲片夜色在线 | 黄色特级片 | 免费视频二区 | 91精品国产三级a在线观看 | 美女视频网站久久 | 久久国产精品色av免费看 | 日韩理论片 | 国产精品ⅴa有声小说 | 久草观看 | 久久成人高清视频 | 国产在线国偷精品产拍免费yy | 久久久久国产精品免费免费搜索 | 亚洲一区二区三区毛片 | 国产日韩欧美在线观看视频 | 亚洲永久av| 3d黄动漫免费看 |