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

相关文章

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

Python如何实现 HTTP echo 服务器

《Python如何实现HTTPecho服务器》本文介绍了如何使用Python实现一个简单的HTTPecho服务器,该服务器支持GET和POST请求,并返回JSON格式的响应,GET请求返回请求路... 一个用来做测试的简单的 HTTP echo 服务器。from http.server import HT

BUUCTF靶场[web][极客大挑战 2019]Http、[HCTF 2018]admin

目录   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 [web][HCTF 2018]admin 考点:弱密码字典爆破 四种方法:   [web][极客大挑战 2019]Http 考点:Referer协议、UA协议、X-Forwarded-For协议 访问环境 老规矩,我们先查看源代码

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

Anaconda 中遇到CondaHTTPError: HTTP 404 NOT FOUND for url的问题及解决办法

最近在跑一个开源项目遇到了以下问题,查了很多资料都大(抄)同(来)小(抄)异(去)的,解决不了根本问题,费了很大的劲终于得以解决,记录如下: 1、问题及过程: (myenv) D:\Workspace\python\XXXXX>conda install python=3.6.13 Solving environment: done.....Proceed ([y]/n)? yDownloa

构建高性能WEB之HTTP首部优化

0x00 前言 在讨论浏览器优化之前,首先我们先分析下从客户端发起一个HTTP请求到用户接收到响应之间,都发生了什么?知己知彼,才能百战不殆。这也是作为一个WEB开发者,为什么一定要深入学习TCP/IP等网络知识。 0x01 到底发生什么了? 当用户发起一个HTTP请求时,首先客户端将与服务端之间建立TCP连接,成功建立连接后,服务端将对请求进行处理,并对客户端做出响应,响应内容一般包括响应

Golang支持平滑升级的HTTP服务

前段时间用Golang在做一个HTTP的接口,因编译型语言的特性,修改了代码需要重新编译可执行文件,关闭正在运行的老程序,并启动新程序。对于访问量较大的面向用户的产品,关闭、重启的过程中势必会出现无法访问的情况,从而影响用户体验。 使用Golang的系统包开发HTTP服务,是无法支持平滑升级(优雅重启)的,本文将探讨如何解决该问题。 一、平滑升级(优雅重启)的一般思路 一般情况下,要实现平滑

Java http请求示例

使用HttpURLConnection public static String httpGet(String host) {HttpURLConnection connection = null;try {URL url = new URL(host);connection = (HttpURLConnection) url.openConnection();connection.setReq

3.比 HTTP 更安全的 HTTPS(工作原理理解、非对称加密理解、证书理解)

所谓的协议 协议只是一种规则,你不按规则来就无法和目标方进行你的工作 协议说白了只是人定的规则,任何人都可以定协议 我们不需要太了解细节,这些制定和完善协议的人去做的,我们只需要知道协议的一个大概 HTTPS 协议 1、概述 HTTPS(Hypertext Transfer Protocol Secure)是一种安全的超文本传输协议,主要用于在客户端和服务器之间安全地传输数据