Http与后台任务(AsyncTask)

2024-04-28 11:08
文章标签 http asynctask 后台任务

本文主要是介绍Http与后台任务(AsyncTask),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

布局文件

<GridView xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:id="@+id/gridView"android:layout_width="match_parent"android:layout_height="match_parent"android:columnWidth="120dp"android:numColumns="3"android:stretchMode="columnWidth" />
<!--我们设置列的宽度为120dp,并使用numColumns属性指示GridView创建尽可能多的列,以铺满整个屏幕。如果在列的空间分配上出现少于120dp的剩余空间,则stretchMode属性会要求GridView在全部列间均分这部分剩余空间。
-->

网络连接类

package com.example.photogallery;import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.StringReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import org.xmlpull.v1.XmlPullParserFactory;import android.net.Uri;
import android.util.Log;public class FlickrFetchr {private static final String TAG = "FlickrFetchr";private static final String ENDPOINT = "http://api.flickr.com/services/rest";private static final String API_KEY = "yourApiKeyHere";private static final String METHOD_GET_RECENT = "flickr.photos.getRecent";private static final String PARAM_EXTRAS = "extras";private static final String EXTRA_SMALL_URL = "url_s";private static final String XML_PHOTO = "photo";/*** HttpURLConnection对象虽然提供了一个连接,但只有在调用getInputStream()方法时(如果是POST请求,* 则调用getOutputStream()方法), 它才会真正连接到指定URL地址。在此之前我们无法获得有效的返回代码。*/byte[] getUrlBytes(String urlSpec) throws IOException {URL url = new URL(urlSpec);HttpURLConnection connection = (HttpURLConnection) url.openConnection();try {ByteArrayOutputStream out = new ByteArrayOutputStream();InputStream in = connection.getInputStream();if (connection.getResponseCode() != HttpURLConnection.HTTP_OK) {return null;}int bytesRead = 0;byte[] buffer = new byte[1024];while ((bytesRead = in.read(buffer)) > 0) {out.write(buffer, 0, bytesRead);}out.close();return out.toByteArray();} finally {connection.disconnect();}}public String getUrl(String urlSpec) throws IOException {return new String(getUrlBytes(urlSpec));}/*** 这里我们使用Uri.Builder构建完整的Filckr API请求URL。便利类Uri.Builder可创建正确转义的参数化URL。* Uri.Builder.appendQueryParameter(String, String)可自动转义查询字符串。*/public ArrayList<GalleryItem> fetchItems() {ArrayList<GalleryItem> items = new ArrayList<GalleryItem>();try {String url = Uri.parse(ENDPOINT).buildUpon().appendQueryParameter("method", METHOD_GET_RECENT).appendQueryParameter("api_key", API_KEY).appendQueryParameter(PARAM_EXTRAS, EXTRA_SMALL_URL).build().toString();String xmlString = getUrl(url);Log.i(TAG, xmlString);XmlPullParserFactory factory = XmlPullParserFactory.newInstance();XmlPullParser parser = factory.newPullParser();parser.setInput(new StringReader(xmlString));parseItems(items, parser);} catch (Exception e) {e.printStackTrace();}return items;}void parseItems(ArrayList<GalleryItem> items, XmlPullParser parser)throws XmlPullParserException, IOException {int eventType = parser.next();while (eventType != XmlPullParser.END_DOCUMENT) {if (eventType == XmlPullParser.START_TAG&& XML_PHOTO.equals(parser.getName())) {String id = parser.getAttributeValue(null, "id");String caption = parser.getAttributeValue(null, "title");String smallUrl = parser.getAttributeValue(null, EXTRA_SMALL_URL);GalleryItem item = new GalleryItem();item.setId(id);item.setCaption(caption);item.setUrl(smallUrl);}eventType = parser.next();}}
}

在子线程中执行网络请求(调用AsyncTask)

package com.example.photogallery;import java.util.ArrayList;import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.GridView;public class PhotoGalleryFragment extends Fragment {private static final String TAG = "PhotoGalleryFragment";private GridView mGridView;private ArrayList<GalleryItem> mItems;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setRetainInstance(true);new FetchItemsTask().execute();}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {View view = inflater.inflate(R.layout.fragment_photo_gallery,container, false);mGridView = (GridView) view.findViewById(R.id.gridView);setupAdapter();return view;}/*** 设置adpter之前,应检查getActivity()的返回结果是否为空。这是因为fragment可脱离activity而存在。* 我们正在使用AsyncTask,我们必须自己负责触发相应的事件,而且也不能确定fragment是否与activity相关联。* 因此需检查确认fragment是否与activity相关联。如果fragment脱离了activity,则依赖于activity的操作* (如创建ArrayAdapter)就会失败。*/void setupAdapter() {if (getActivity() == null || mGridView == null)return;if (mItems != null) {mGridView.setAdapter(new ArrayAdapter<GalleryItem>(getActivity(),android.R.layout.simple_gallery_item, mItems));}else {mGridView.setAdapter(null);}}/*** AsyncTask<Params, Progress, Result>* Params可指定输入参数的类型。输入参数传入execute(...)方法(可接受一个或多个参数)。然后,这些变量参数传给doInBackground(...)方法* Progress指定发送进度更新需要的类型。在doInBackground(...)方法调用publishProgress(...)方法,系统会调用onProgressUpdate(...)方法,刷新进度* Result指定doInBackground(...)方法返回的类型以及onPostExecute(...)方法参数接受的类型。* * AsyncTask.cancel(boolean)方法撤销运行中的AsyncTask,分为两种工作模式:粗暴的和温和的。* 如调用温和的cancel(false)方法,该方法会设置isCancelled()状态为true。随后,AsyncTask会检查doInBackground(...)方法* 中的isCancelled()状态,然后选择提前结束运行。* 然而,如调用粗暴的cancel(true)方法,它会终止doInBackground(...)方法当前所在的线程。AsyncTask.cancel(true)方法停止AsyncTask* 的方式简单粗暴,如有可能,应尽量避免此种方式。*/private class FetchItemsTask extends AsyncTask<Void, Void, ArrayList<GalleryItem>> {@Overrideprotected void onPreExecute() {super.onPreExecute();}@Overrideprotected ArrayList<GalleryItem> doInBackground(Void... params) {return new FlickrFetchr().fetchItems();}@Overrideprotected void onProgressUpdate(Void... values) {super.onProgressUpdate(values);}@Overrideprotected void onPostExecute(ArrayList<GalleryItem> result) {mItems = result;setupAdapter();}}
}

代码地址

这篇关于Http与后台任务(AsyncTask)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/943096

相关文章

Maven 配置中的 <mirror>绕过 HTTP 阻断机制的方法

《Maven配置中的<mirror>绕过HTTP阻断机制的方法》:本文主要介绍Maven配置中的<mirror>绕过HTTP阻断机制的方法,本文给大家分享问题原因及解决方案,感兴趣的朋友一... 目录一、问题场景:升级 Maven 后构建失败二、解决方案:通过 <mirror> 配置覆盖默认行为1. 配置示

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (