android 网络请求库volley方法详解

使用volley进行网络请求:需先将volley包导入androidstudio中

File下的Project Structrue,点加号导包

volley网络请求步骤:

1. 创建请求队列       RequestQueue queue = Volley.newRequestQueue(this);

2.创建请求对象(3种)

StringRequest request = new StringRequest(“请求方法”,“请求的网络地址”,“成功的网络回调”,“失败的网络回调”);

ImageRequest request = new ImageRequest(“图片路径”,“成功的回调函数”,“图片宽度”,“图片高度”,“图片的颜色属性”,“失败的网络回调”);

Jsonrequest request = new Jsonrequest();

3.把请求对象放入请求队列     queue.add(request);

 // 注销请求:重写onstop方法

 @Override
  protected void onStop() {
   super.onStop();
   /*取消当前请求队列的所有请求*/
   queue.cancelAll(this);
   /*取消当前请求队列tag为get的请求*/
   queue.cancelAll("get");
   /*取消当前请求队列tag为post的请求*/
   queue.cancelAll("post");
  }
//设置当前请求的优先级:重写getPriority方法
@Override
public Priority getPriority() {
 return Priority.LOW;
}
//设置请求头:重写GetHeader方法
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
 Map<String,String> map = new HashMap<String, String>();
 map.put("apikey","fc642e216cd19906f642ee930ce28174");
 return map;
}

//传递参数:重写GetParams方法
@Override
protected Map<String, String> getParams() throws AuthFailureError {
 Map<String,String> map = new HashMap<String, String>();
 map.put("num","10");
 map.put("page","1");
 map.put("word","%E6%9E%97%E4%B8%B9");
 return map;
}

代码部分:

xml文件:

<?xml version="1.0" encoding="utf-8"?>
<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"
 android:paddingBottom="@dimen/activity_vertical_margin"
 android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 android:orientation="vertical"
 tools:context="com.jredu.helloworld.activity.VolleyActivity">
 <WebView
  android:id="@+id/volleyWebView"
  android:layout_width="match_parent"
  android:layout_height="300dp">
 </WebView>
 <ImageView
  android:id="@+id/img"
  android:layout_width="match_parent"
  android:layout_height="wrap_content" />
 <Button
  android:id="@+id/volleyButton"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_marginTop="5dp"
  android:textAllCaps="false"
  android:text="Volley"/>
 <Button
  android:id="@+id/imgButton"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_marginTop="5dp"
  android:textAllCaps="false"
  android:text="Volley获取图片"/>
</LinearLayout>

  activity文件:

package com.jredu.helloworld.activity;

import android.graphics.Bitmap;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.ImageView;

import com.android.volley.AuthFailureError;
import com.android.volley.NetworkResponse;
import com.android.volley.ParseError;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.HttpHeaderParser;
import com.android.volley.toolbox.ImageRequest;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;
import com.jredu.helloworld.R;

import java.io.UnsupportedEncodingException;
import java.util.HashMap;
import java.util.Map;

public class VolleyActivity extends AppCompatActivity {
 WebView webView;
 Button button;
 Button imgButton;
 ImageView img;
 RequestQueue queue = null;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_volley);
  queue = Volley.newRequestQueue(this);
  webView = (WebView) findViewById(R.id.volleyWebView);
  img = (ImageView) findViewById(R.id.img);
  button = (Button) findViewById(R.id.volleyButton);
  button.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    doStringVolley2();
    doStringVolley();
   }
  });
  imgButton = (Button) findViewById(R.id.imgButton);
  imgButton.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    GetImg();
   }
  });
 }
 /*get方法*/
 public void doStringVolley(){
  /*创建请求队列*/
  //RequestQueue queue = Volley.newRequestQueue(this);
  /*创建请求对象*/
  StringRequest request = new StringRequest(
    Request.Method.GET,
    "http://apis.baidu.com/txapi/tiyu/tiyu?num=10&page=1&word=%E6%9E%97%E4%B8%B9",
    /*"http://www.baidu.com",*/
    new Response.Listener<String>() {
     @Override
     public void onResponse(String response) {
      String s = response;
      webView.getSettings().setDefaultTextEncodingName("utf-8");
      webView.getSettings().setJavaScriptEnabled(true);
      webView.loadDataWithBaseURL(null,s,"text/html","utf-8",null);
     }
    },
    new Response.ErrorListener() {
     @Override
     public void onErrorResponse(VolleyError error) {
      webView.loadDataWithBaseURL(null,"网络连接失败!!!","text/html","utf-8",null);
     }
    }
  ){
   /*设置请求头*/
   @Override
   public Map<String, String> getHeaders() throws AuthFailureError {
    Map<String,String> map = new HashMap<String, String>();
    map.put("apikey","fc642e216cd19906f642ee930ce28174");
    return map;
   }
   /*解析网络请求结果的方法*/
   @Override
   protected Response<String> parseNetworkResponse(
     NetworkResponse response) {
    try {
     String jsonObject = new String(
       new String(response.data, "UTF-8"));
     return  Response.success(jsonObject, HttpHeaderParser.parseCacheHeaders(response));
    } catch (UnsupportedEncodingException e) {
     return Response.error(new ParseError(e));
    } catch (Exception je) {
     return Response.error(new ParseError(je));
    }
   }
   /*设置当前请求的优先级*/
   @Override
   public Priority getPriority() {
    return Priority.LOW;
   }
  };
  request.setTag("get");
  /*把请求对象放入请求队列*/
  queue.add(request);
 }
 /*post方法*/
 public void doStringVolley2(){
  /*创建请求队列*/
  //RequestQueue queue = Volley.newRequestQueue(this);
  /*创建请求对象*/
  StringRequest request = new StringRequest(
    Request.Method.POST,
    "http://www.baidu.com",
    new Response.Listener<String>() {
     @Override
     public void onResponse(String response) {
      String s = response;
      webView.getSettings().setDefaultTextEncodingName("utf-8");
      webView.getSettings().setJavaScriptEnabled(true);
      webView.loadDataWithBaseURL(null,s,"text/html","utf-8",null);
     }
    },
    new Response.ErrorListener() {
     @Override
     public void onErrorResponse(VolleyError error) {
      webView.loadDataWithBaseURL(null,"网络连接失败!!!","text/html","utf-8",null);
     }
    }
  ){
   /*重写params方法写参数*/
   @Override
   protected Map<String, String> getParams() throws AuthFailureError {
    Map<String,String> map = new HashMap<String, String>();
    map.put("num","10");
    map.put("page","1");
    map.put("word","%E6%9E%97%E4%B8%B9");
    return map;
   }
   /*设置请求对象优先级*/
   @Override
   public Priority getPriority() {
    return Priority.HIGH;
   }
  };
  request.setTag("post");
  /*把请求对象放入请求队列*/
  queue.add(request);
 }
 /*获取图片*/
 public void GetImg(){
  ImageRequest request = new ImageRequest(
    "https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo/bd_logo1_31bdc765.png",
    new Response.Listener<Bitmap>() {
     @Override
     public void onResponse(Bitmap response) {
      img.setImageBitmap(response);
     }
    },
    5000,
    5000,
    Bitmap.Config.ARGB_8888,
    new Response.ErrorListener() {
     @Override
     public void onErrorResponse(VolleyError error) {
      img.setImageResource(R.drawable.first5);
     }
    }
  );
  queue.add(request);
 }
 /*重写onStop方法,用来注销请求*/
 @Override
 protected void onStop() {
  super.onStop();
  /*取消当前请求队列的所有请求*/
  queue.cancelAll(this);
  /*取消当前请求队列tag为get的请求*/
  queue.cancelAll("get");
  /*取消当前请求队列tag为post的请求*/
  queue.cancelAll("post");
 }
}

以上就是android 网络请求库volley方法 的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

(0)

相关推荐

  • Android的HTTP操作库Volley的基本使用教程

    以前原本都用android内建的Library来进行GET.POST等等对API的连线与操作. 但最近想说来找找看有没有好用的library,应该可以事半功倍. 当初有找了三套比较多人用的 1.Android Asynchronous Http Client 2.okhttp square开发并且开源的,因为之前用过他们家的picasso,所以对这套满有好感的,只可惜使用方式不太喜欢 3.Volley Volley是Google在2013年Google I/O的时候发布的,到现在已经积累了很高的

  • 深入解读Android的Volley库的功能结构

    Volley 是一个 HTTP 库,它能够帮助 Android app 更方便地执行网络操作,最重要的是,它更快速高效.我们可以通过开源的 AOSP 仓库获取到 Volley . Volley 有如下的优点: 自动调度网络请求. 高并发网络连接. 通过标准的 HTTP cache coherence(高速缓存一致性)缓存磁盘和内存透明的响应. 支持指定请求的优先级. 撤销请求 API.我们可以取消单个请求,或者指定取消请求队列中的一个区域. 框架容易被定制,例如,定制重试或者回退功能. 强大的指

  • Android Volley框架使用源码分享

    过去在Android上网络通信都是使用的Xutils 因为用它可以顺道处理了图片和网络这两个方面,后来发觉Xutils里面使用的是HttpClient  而Google在6.0的版本上已经把HttpClient废除了,所以开始寻找新的网络框架,okhttp也用过,但是它是在作用在UI线程,使用起来还需要用handler 所以就先用着Volley框架了.  这里我先分析下Volley框架的简单网络请求的源码. 使用Volley请求网络数据的简单过程: RequestQueue queue = Vo

  • Android 开发中Volley详解及实例

    Android 开发中Volley详解及实例 最近在做项目的时候,各种get和post.简直要疯了,我这种啥都不了解的,不知道咋办了,然后百度看了下,可以用volley进行网络请求与获取,下面就介绍下volley的用法. volley有三种方式:JsonObjectRequest,JsonArrayRequest,StringRequest.其实都是差不多了,举一反三就ok了,这里我就讲下JsonObjectRequest. 方法如下: JsonObjectRequest jsonObjectR

  • 深入剖析Android的Volley库中的图片加载功能

    一.基本使用要点回顾 Volley框架在请求网络图片方面也做了很多工作,提供了好几种方法.本文介绍使用ImageLoader来进行网络图片的加载. ImageLoader的内部使用ImageRequest来实现,它的构造器可以传入一个ImageCache缓存形参,实现了图片缓存的功能,同时还可以过滤重复链接,避免重复发送请求. 下面是ImageLoader加载图片的实现方法: public void displayImg(View view){ ImageView imageView = (Im

  • Android Volley框架全面解析

     Volley简介 我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行HTTP通信,HttpURLConnection和HttpClient,几乎在任何项目的代码中我们都能看到这两个类的身影,使用率非常高. 不过HttpURLConnection和HttpClient的用法还是稍微有些复杂的,如果不进行适当封装的话,很容易就会写出不少重复代码.于是乎,一些Android网络

  • Android Volley图片加载功能详解

    Gituhb项目 Volley源码中文注释项目我已经上传到github,欢迎大家fork和start. 为什么写这篇博客 本来文章是维护在github上的,但是我在分析ImageLoader源码过程中与到了一个问题,希望大家能帮助解答. Volley获取网络图片  本来想分析Universal Image Loader的源码,但是发现Volley已经实现了网络图片的加载功能.其实,网络图片的加载也是分几个步骤: 1. 获取网络图片的url. 2. 判断该url对应的图片是否有本地缓存. 3. 有

  • Android的HTTP类库Volley入门学习教程

    1. 什么是Volley 我们平时在开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行HTTP通信,HttpURLConnection和HttpClient,几乎在任何项目的代码中我们都能看到这两个类的身影,使用率非常高. 不过HttpURLConnection和HttpClient的用法还是稍微有些复杂的,如果不进行适当封装的话,很容易就会写出不少重复代码.于是乎,一些Androi

  • Android开发中使用Volley库发送HTTP请求的实例教程

    Android Volley 是Google开发的一个网络lib,可以让你更加简单并且快速的访问网络数据.Volley库的网络请求都是异步的,你不必担心异步处理问题. Volley的优点: 请求队列和请求优先级 请求Cache和内存管理 扩展性性强 可以取消请求 下载和编译volley.jar 需要安装git,ant,android sdk clone代码: git clone https://android.googlesource.com/platform/frameworks/volley

  • android 网络请求库volley方法详解

    使用volley进行网络请求:需先将volley包导入androidstudio中 File下的Project Structrue,点加号导包 volley网络请求步骤: 1. 创建请求队列       RequestQueue queue = Volley.newRequestQueue(this); 2.创建请求对象(3种) StringRequest request = new StringRequest("请求方法","请求的网络地址","成功的网

  • Android 网络请求框架Volley实例详解

    Android 网络请求框架Volley实例详解 首先上效果图 Logcat日志信息on Reponse Volley特别适合数据量不大但是通信频繁的场景,像文件上传下载不适合! 首先第一步 用到的RequetQueue RequestQueue.Java RequestQueue请求队列首先得先说一下,ReuqestQueue是如何对请求进行管理的...RequestQueue是对所有的请求进行保存...然后通过自身的start()方法开启一个CacheDispatcher线程用于缓存调度,开

  • Swift网络请求库Alamofire使用详解

    前言 Alamofire是一个使用Swift开发的网络请求库,其开发团队是AFNetworking的原团队.它语法简洁,采用链式编程的思想,使用起来是相当的舒服.本质是基于NSURLSession进行封装.接下开我们就进入实战,开始学习Alamofire的使用. GET请求 常用的get请求示例以及请求结果 Alamofire.request("https://httpbin.org/get", method: .get, parameters: nil, encoding: URLE

  • react使用axios进行api网络请求的封装方法详解

    目录 前言 准备工作 开始封装axios config.js request.js 进行请求 总结 前言 最近写react项目使用到axios进行请求封装,在这里记录一下,希望可以帮助到初学的小伙伴 准备工作 进行请求需要使用axios,所以要先确定你已经安装完成了axios,查看package.json文件 如果没有,请先安装axios npm install axios 开始封装axios 首先在src目录下新建axios文件夹,这里我们新建两个文件,分别是config.js和request

  • Android中XUtils3框架使用方法详解(一)

    xUtils简介 xUtils 包含了很多实用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响... xUitls 最低兼容android 2.2 (api level 8) 今天给大家带来XUtils3的基本介绍,本文章的案例都是基于XUtils3的API语法进行的演示.相信大家对这个框架也都了解过, 下面简单介绍下XUtils3的一些基本知识. XUtils3一共有4大功能:注解模块,网络

  • 微信小程序之网络请求简单封装实例详解

    微信小程序之网络请求简单封装实例详解 在微信小程序中实现网络请求相对于Android来说感觉简单很多,我们只需要使用其提供的API就可以解决网络请求问题. 普通HTTPS请求(wx.request) 上传文件(wx.uploadFile) 下载文件(wx.downloadFile) WebSocket通信(wx.connectSocket) 为了数据安全,微信小程序网络请求只支持https,当然各个参数的含义就不在细说,不熟悉的话可以:可以去阅读官方文档的网络请求api,当我们使用request

  • Android VideoCache视频缓存的方法详解

    Android VideoCache视频缓存的方法详解 项目中遇到视频播放,需要加载网络url,不可能每次都进行网络加载,当然了,就需要用到我们的缓存机制 AndroidVideoCache AndroidVideoCache是一个视频/音频缓存库,利用本地代理实现了边下边播,使用起来非常简单. HttpProxyCacheServer是主要类,是一个代理服务器,可以配置缓存文件的数量.缓存文件的大小.缓存文件的目录和缓存文件命名算法,文件缓存均基于LRU算法,利用Builder来配置: //配

  • Android网络请求库android-async-http介绍

    Android网络请求库:android-async-http开源框架 之前有一篇描述了客户端请求服务器端的方式-Post的请求方式.今天介绍一个请求服务器的一个开源库-android-async-http库. 1. 概念: 这个网络请求库是基于Apache HttpClient库之上的一个异步网络请求处理库,网络处理均基于Android的非UI线程,通过回调方法(匿名内部类)处理请求结果. 2. 特征: (1).处理异步Http请求,并通过匿名内部类处理回调结果 **(2).**Http异步请

  • Android 中RxPermissions 的使用方法详解

    Android 中RxPermissions 的使用方法详解 以请求拍照.读取位置权限为例 module的build.gradle: compile 'com.tbruyelle.rxpermissions2:rxpermissions:0.9.4@aar' compile 'io.reactivex.rxjava2:rxjava:2.0.5' AndroidManifest.xml: <uses-permission android:name="android.permission.AC

  • Android 中Context的使用方法详解

    Android 中Context的使用方法详解 概要: Context字面意思是上下文,位于framework package的android.content.Context中,其实该类为LONG型,类似Win32中的Handle句柄.很多方法需要通过 Context才能识别调用者的实例:比如说Toast的第一个参数就是Context,一般在Activity中我们直接用this代替,代表调用者的实例为Activity,而到了一个button的onClick(View view)等方法时,我们用t

随机推荐