OkHttp使用实例

OkHttp使用实例

依赖

  • OkHttp包
    • compile 'com.squareup.okhttp3:okhttp:3.6.0'
  • OkHttp依赖包
    • compile 'com.squareup.okio:okio:1.11.0'
  • json处理包
    • compile 'com.google.code.gson:gson:2.8.0'
  • 图示

具体例子【封装的两个类,可以直接调用】

  • get方式为例【重在理解原理】

    import android.app.Activity;
    import java.io.IOException;
    import okhttp3.Call;
    import okhttp3.Callback;
    import okhttp3.OkHttpClient;
    import okhttp3.Request;
    import okhttp3.Response;
    
    public class OkHttpManager extends Activity {
        private Activity activity;
    
        public OkHttpManager(Activity activity) {
            this.activity = activity;
        }
    
        public void get(String url) {
            OkHttpClient client = new OkHttpClient();
            Request request = new Request.Builder().get().url(url).build();
            Call call = client.newCall(request);
            call.enqueue(new Callback() {
                @Override
                public void onFailure(Call call, IOException e) {
                    ToastUtil.showToast(activity, "Get 失败");
                }
                @Override
                public void onResponse(Call call, final Response response) throws IOException {
                    final String responseStr = response.body().string();
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            ToastUtil.showToast(activity, responseStr);
                        }
                    });
                }
            });
        }
    }
    
  • 弹出框辅助类

    import android.app.Activity;
    import android.util.Log;
    import android.widget.Toast;
    
    public class ToastUtil {
    
        public static void showToast(final Activity activity, final String message) {
            if ("main".equals(Thread.currentThread().getName())) {
                Log.e("ToastUtil", "主线程!");
                Toast.makeText(activity, message, Toast.LENGTH_SHORT).show();
            } else {
                activity.runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        Log.e("ToastUtil", "不在主线程!");
                        Toast.makeText(activity, message, Toast.LENGTH_SHORT).show();
                    }
                });
            }
        }
    
    }

OkHttp是一个开源的HTTP客户端库,用于在Android应用程序中进行网络请求。下面是一个使用OkHttp的应用实例: ```kotlin import okhttp3.Call import okhttp3.Callback import okhttp3.OkHttpClient import okhttp3.Request import okhttp3.Response import java.io.IOException class OkHttpManager(private val activity: Activity) { fun get(url: String) { val client = OkHttpClient() val request = Request.Builder().get().url(url).build() client.newCall(request).enqueue(object : Callback { override fun onFailure(call: Call, e: IOException) { ToastUtil.showToast(activity, "Get 失败") } override fun onResponse(call: Call, response: Response) { val responseStr = response.body()?.string() activity.runOnUiThread { ToastUtil.showToast(activity, responseStr) } } }) } } ``` 以上代码示例了如何使用OkHttp发送一个GET请求,并在响应返回后处理结果。其中,`OkHttpManager`是一个封装了OkHttp操作的类,`get`方法接收一个URL参数,创建一个GET请求,并异步执行。在响应返回时,通过回调方法处理成功或失败的情况,并在UI线程上显示响应结果。 请注意,这只是一个简单的示例,实际应用中可能还需要处理更多的错误和异常情况,以及其他类型的请求和响应。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [OkHttp日常使用实战篇](https://blog.csdn.net/sinat_35241409/article/details/118912417)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [OkHttp使用实例](https://blog.csdn.net/eieiei438/article/details/80062984)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乘风御浪云帆之上

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值