android 封装网络框架(java企业自己封装的框架)

Android网络框架OKGo封装本文讲述了Android网络框架OKGo封装,封装的框架适用于项目当中,适合新手操作,OKGO框架本身就以简单易上手而深受喜欢,而此文就是基于框架之上再次封装,废话不多说,直接开始吧!首先在我们的build.gradle中导入我们引用的框架dependencies{…implementation’com.lzy.net:okgo:3.0.4’i…

大家好,又见面了,我是你们的朋友全栈君。

Android网络框架OKGo封装

本文讲述了Android网络框架OKGo封装,封装的框架适用于项目当中,适合新手操作,OKGO框架本身就以简单易上手而深受喜欢,而此文就是基于框架之上再次封装,废话不多说,直接开始吧!

首先在我们的build.gradle中导入我们引用的框架

dependencies { 
   
...
implementation 'com.lzy.net:okgo:3.0.4'
implementation 'com.lzy.net:okserver:2.0.5'
...
}

下来就要在我们创建的Application文件中对OKGo进行相应的配置:
这里只进行简单的配置操作,如果想配置其他,可在网上查阅相关资料,在创建的Application文件的onCreate()方法实现初始化方法即可。

private void initOKGO() { 
   
    OkHttpClient.Builder builder = new OkHttpClient.Builder();
    HttpLoggingInterceptor loggingInterceptor = new HttpLoggingInterceptor("OkGo");
    loggingInterceptor.setPrintLevel(HttpLoggingInterceptor.Level.BODY);
    loggingInterceptor.setColorLevel(Level.INFO);
    builder.addInterceptor(loggingInterceptor);
    builder.readTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS);
    builder.writeTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS);
    builder.connectTimeout(OkGo.DEFAULT_MILLISECONDS, TimeUnit.MILLISECONDS);
    builder.cookieJar(new CookieJarImpl(new DBCookieStore(this)));
    HttpsUtils.SSLParams sslParams1 = HttpsUtils.getSslSocketFactory();
    builder.sslSocketFactory(sslParams1.sSLSocketFactory, sslParams1.trustManager);
    OkGo.getInstance().init(this)
            //设置OkHttpClient
            .setOkHttpClient(builder.build())
            //全局统一缓存模式
            .setCacheMode(CacheMode.NO_CACHE)
            //全局统一缓存时间
            .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE)
            //全局统一超时重连次数
            .setRetryCount(3);
}

有时候我们的需求是在网络请求中,我们需要给用户展示一个loading等待框,提示用户正在进行网络请求操作,下来我们就展示等待提示的代码:
DialogJsonCallback

public class DialogJsonCallback extends StringCallback { 
   


    private AlertDialog alertDialog;
    private Activity    activity;

    public DialogJsonCallback() { 
   

    }

    public DialogJsonCallback(Activity activity) { 
   
        super();
        initDialog(activity);
    }

    private void initDialog(Activity activity) { 
   

        AlertDialog.Builder builder = new AlertDialog.Builder(activity, R.style.matching_dialog);
        this.activity = activity;
        alertDialog = builder.create();
        alertDialog.setCanceledOnTouchOutside(false);
        alertDialog.setCancelable(false);
        activity.setFinishOnTouchOutside(false);
        View view = LayoutInflater.from(activity).inflate(R.layout.matching_dialog_layout, null);
        alertDialog.setView(view);
    }

    @Override
    public void onStart(Request<String, ? extends Request> request) { 
   
        super.onStart(request);
        if (alertDialog != null && !alertDialog.isShowing()) { 
   
            alertDialog.show();
            alertDialog.getWindow().setContentView(R.layout.matching_dialog_layout);

        }
    }

    @Override
    public void onFinish() { 
   
        super.onFinish();
        if (activity != null) { 
   
            if (!activity.isDestroyed()) { 
   
                if (alertDialog != null && alertDialog.isShowing()) { 
   
                    alertDialog.dismiss();
                }
            }
        }
    }

    @Override
    public void onSuccess(Response<String> response) { 
   

    }
}

其中的样式代码为:
R.style.matching_dialog

<style name="matching_dialog" parent="@android:style/Theme.Holo.Dialog">

    <!-- 是否有边框 -->
    <item name="android:windowFrame">@null</item>    <!--是否在悬浮Activity之上  -->
    <item name="android:windowIsFloating">true</item>    <!--标题  -->
    <item name="android:windowNoTitle">true</item>    <!--阴影  -->
    <item name="android:windowIsTranslucent">true</item>    <!--透明背景-->
    <item name="android:background">@android:color/transparent</item>    <!--窗口背景透明-->
    <item name="android:windowBackground">@android:color/transparent</item>    <!--弹窗背景是否变暗-->
    <item name="android:backgroundDimEnabled">false</item>


</style>

用到的布局文件为:
布局文件为一个简单的.gif图提示用户
R.layout.matching_dialog_layout

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@drawable/logout_bg_round">

        <pl.droidsonroids.gif.GifImageView
            android:id="@+id/gif_icon_matching"
            android:layout_width="48dp"
            android:layout_height="48dp"
            android:src="@mipmap/icon_matching"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"/>

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:padding="12dp"
            android:text="@string/in_the_match"
            android:textColor="@color/black"
            android:textSize="14sp"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/gif_icon_matching"/>

</androidx.constraintlayout.widget.ConstraintLayout>

下来就是对OKGO框架进行网络请求的封装:

首先我们先定义网络请求回传的接口,当网络请求成功或失败时,对返回数据进行回调:

HttpRquestInter

public interface HttpRequestInter<T> { 
   


    void onError(String des);

    void onResponse(T responseObj);
}

下来我们封装OKGo的网络请求操作,包括get,post,以及文件上传:

public class HttpRequest { 
   

/** * OKGo Get请求 * @param url * @param params * @param classz * @param requestInter * @param <T> */
public static <T> void getRequets(Activity activity, String url, Map<String, String> params, final Class classz, final HttpRquestInter<T> requestInter) { 
   
  
  OkGo.<T>get(url)
            .headers("公共请求头部", " ")
            .headers("公共请求头部", " ")
            .params(params)
            .execute((Callback<T>) new DialogJsonCallback(activity) { 
   
                @Override
                public void onError(Response<String> response) { 
   
                    try { 
   
                        requestInter.onError(response.body());
                    } catch (Exception e1) { 
   
                        e1.printStackTrace();
                    }
                }

                @Override
                public void onSuccess(Response<String> response) { 
   
                //请求返回数据可根据需求更改判断
                   requestInter.onResponse((T) new Gson().fromJson(response.body(), classz));
       }
            });
}


/** * OKGo post请求 * @param url * @param params * @param classz * @param requestInter * @param <T> */
public static <T> void postRequest(Activity activity, String url, Map<String, String> params, final Class classz, final HttpRquestInter<T> requestInter) { 
   

  OkGo.<T>post(url)
            .headers("公共请求头部", "")
            .headers("公共请求头部", "")
            .params(params)
            .execute((Callback<T>) new DialogJsonCallback(activity) { 
   
                @Override
                public void onError(Response<String> response) { 
   
 
                    try { 
   
                        requestInter.onError(response.body());
                    } catch (Exception e1) { 
   
                        e1.printStackTrace();
                    }
                }

                @Override
                public void onSuccess(Response<String> response) { 
   
                //请求返回数据可根据需求更改判断
                   requestInter.onResponse((T) new Gson().fromJson(response.body(), classz));
             }
            });
}


/** * OKGo 文件上传 * @param url * @param files * @param classz * @param requestInter * @param <T> */
public static <T> void fileUpload(Activity activity, String url, String fileKey, File files, String fileName, final Class classz, final HttpRquestInter<T> requestInter) { 
   
    HttpParams httpParams = new HttpParams();
    httpParams.put(fileKey, files, fileName);
    OkGo.<T>post(url)
            .headers("公共请求头部", "")
            .headers("公共请求头部", "")
            .params(httpParams)
            .isMultipart(true)
            .execute((Callback<T>) new DialogJsonCallback(activity) { 
   
                @Override
                public void onError(Response<String> response) { 
   
                  
                    try { 
   
                        requestInter.onError(response.body());
                    } catch (Exception e1) { 
   
                        e1.printStackTrace();
                    }
                }

                @Override
                public void onSuccess(Response<String> response) { 
   
                  //请求返回数据可根据需求更改判断
                   requestInter.onResponse((T) new Gson().fromJson(response.body(), classz));
                     }
            });
}

}

我们可以创建一个公共的类来整理我们的网络请求参数

public class RequestBodyManager { 
   
 
 //登录
 public static Map<String, String> buildLoginPostParam(String userName, String passWord) { 
   
    Map<String, String> defaults = new HashMap<>();
    defaults.put("userName", userName;
    defaults.put("passWord", passWord);
    return defaults;
}

}

最后我们演示一下模拟登录的代码:


public void loginPost(String userName, String passWord) { 
   

    Map<String, String> loginMap = RequestBodyManager.buildLoginPostParam(userName, passWord);
    HttpRequest.postRequest(getView(), Constants.LOGIN, loginMap, LoginResponse.class, new HttpRquestInter<LoginResponse>() { 
   
        @Override
        public void onError(String des) { 
   
            getView().loginFailure(des);
        }

        @Override
        public void onResponse(LoginResponse responseObj) { 
   
            getView().loginSuccess(responseObj);
        }
    });
}

其中的getView()方法就是获取当前界面的Context,可以参考我之前的封装MVP代码。
最后把LoginResponse.class的代码也贴出来,可以根据这个更改。

LoginResponse

public class LoginResponse extends BaseModel<LoginInfo> { 
   
}

只是简单的这一行代码,LoginInfo根据自己项目需求更改。

其中Get和Post的代码大概一致,下来讲述一下文件上传:

public void uploadFile(String fileKey, File file, String fileName) { 
   

    HttpRequest.fileUpload(getView(), Constants.CHANGE_PHOTO, fileKey, file, fileName, UploadResponse.class, new HttpRquestInter<UploadResponse>() { 
   
        @Override
        public void onError(String des) { 
   
            getView().uploadPhotoFail(des);
        }

        @Override
        public void onResponse(UploadResponse responseObj) { 
   
            if (responseObj.status) { 
   
                getView().uploadPhotoSuccess(responseObj);
            } else { 
   
                getView().uploadPhotoFail(responseObj.errors);
            }
        }
    });

}

以上就是封装OKGO的全部内容,如有不足之处,还请各位包涵!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128656.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • [精选]图文详解到底什么是三次握手四次挥手「建议收藏」

    [精选]图文详解到底什么是三次握手四次挥手

    2022年2月19日
    44
  • 微信定位精灵服务器或网络异常,为什么微信定位精灵定位不了怎么办?

    微信定位精灵服务器或网络异常,为什么微信定位精灵定位不了怎么办?方法如下:1、下载“微信定位精灵”软件,安装;2、按图示设置如下,然后缩小地图,把光标定位在大马或任意地方,点击左上角的圆形定位按键完成定位,点右上角的菜单栏,选择“启动微信”,接下来的正常操作就行了。3、打开手机网络,关掉手机的网络定位,GPS等等。打开精灵,看见地图中间有个十字架,那就是你将要定位的地方,比如你的朋友身边。5.点击左上角的定位按钮。一秒你就穿越了。6、打开右边的启动微信。找身边…

    2022年5月7日
    97
  • Vsftpd服务器企业实战

    Vsftpd服务器企业实战

    2021年6月12日
    117
  • flex布局: 一行显示固定个数,强制换行且均匀分布(超出的分布靠左)

    flex布局: 一行显示固定个数,强制换行且均匀分布(超出的分布靠左)如图需求 1 一行显示 3 个 2 强制换行 3 宽度不写死 4 高度固定 html divclass mycards divclass card item divclass card item divclass card item divclass card item divclass mycards

    2025年11月29日
    7
  • Spring中bean的生命周期(最详细)

    Spring中bean的生命周期(最详细)SpringBean的生命周期是Spring面试热点问题。SpringBean的生命周期指的是从一个普通的Java类变成Bean的过程,深知Spring源码的人都知道这个给面试官讲的话大可讲30分钟以上,如果你不没有学习过Spring的源码,可能就知道Aware接口和调用init方法这样的生命周期,所以这个问题既考察对Spring的微观了解,又考察对Spring的宏观认识,想要答好并不容易!本文希望能够从源码角度入手,帮助面试者彻底搞定SpringBean的生命周期。首先你要明白一点,Sp

    2022年7月15日
    15
  • matlab保存所有图,Matlab中图片保存的5种方法

    matlab保存所有图,Matlab中图片保存的5种方法matlab的绘图和可视化能力是不用多说的,可以说在业内是家喻户晓的。Matlab提供了丰富的绘图函数,比如ez**系类的简易绘图函数,surf、mesh系类的数值绘图函数等几十个。另外其他专业工具箱也提供了专业绘图函数,这些值得大家深入学习好久。今天我只是讨论下如何保存这些由Matlab绘制出来的图像呢?当然借助第三方截图软件,就算了!1、使用imwrite函数如图像是img,则可以使用im…

    2025年9月7日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号