网络HTTP

HTTP Network Request Library

A Retrofit-based HTTP network request encapsulation library that provides simple and easy-to-use API interfaces with complete network request functionality.
基于Retrofit的HTTP网络请求封装库,提供简单易用的API接口和完整的网络请求功能。

Features

功能特点

  • Built on Retrofit2 and OkHttp
  • 基于Retrofit2和OkHttp构建
  • Support for common HTTP request methods (GET, POST, PUT, DELETE, etc.)
  • 支持常见的HTTP请求方法(GET、POST、PUT、DELETE等)
  • Unified request and response handling
  • 统一的请求和响应处理
  • Flexible request configuration
  • 灵活的请求配置
  • Custom request headers
  • 自定义请求头
  • Log interception and printing
  • 日志拦截和打印
  • Thread-safe singleton implementation
  • 线程安全的单例实现

Integration

集成方式

Gradle

dependencies {implementation 'io.github.vance0901:http:1.0.0'
}

加入网络权限 Add network permissions

    <uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

Usage

使用方法

1. Initialization

1. 初始化

Initialize in the Application class:
在Application类中初始化:

HttpConfig config = new HttpConfig.Builder().baseUrl("https://api.example.com/").connectTimeout(10000).readTimeout(10000).writeTimeout(10000).debug(BuildConfig.DEBUG).logLevel(BuildConfig.DEBUG ? HttpLoggingInterceptor.Level.BODY : HttpLoggingInterceptor.Level.NONE).build();HttpManager.init(config);

2. Define API Interfaces

2. 定义API接口

public interface ApiService {// GET request example// GET请求示例@GET("users/{id}")Call<BaseResponse<UserInfo>> getUserInfo(@Path("id") long id);// GET request with query parameters// 带查询参数的GET请求@GET("users")Call<BaseResponse<List<UserInfo>>> getUserList(@Query("page") int page, @Query("size") int size);// POST request example - form submission// POST请求示例 - 表单提交@FormUrlEncoded@POST("users/login")Call<BaseResponse<LoginResponse>> login(@Field("username") String username,@Field("password") String password);// POST request example - JSON submission// POST请求示例 - JSON提交@POST("users/create")Call<BaseResponse<UserInfo>> createUser(@Body UserInfo userInfo);// PUT request example// PUT请求示例@PUT("users/{id}")Call<BaseResponse<UserInfo>> updateUser(@Path("id") long id, @Body UserInfo userInfo);// DELETE request example// DELETE请求示例@DELETE("users/{id}")Call<BaseResponse<Void>> deleteUser(@Path("id") long id);// DELETE request with body// 带请求体的DELETE请求@HTTP(method = "DELETE", path = "users", hasBody = true)Call<BaseResponse<Void>> batchDeleteUsers(@Body List<Long> userIds);
}

3. Create API Service Class

3. 创建API服务类

public class UserService extends BaseApiService<ApiService> {private static volatile UserService instance;private UserService() {super();}public static UserService getInstance() {if (instance == null) {synchronized (UserService.class) {if (instance == null) {instance = new UserService();}}}return instance;}@Overrideprotected Class<ApiService> getApiServiceClass() {return ApiService.class;}// GET request example// GET请求示例public void getUserInfo(long userId, RequestCallback<UserInfo> callback) {executeRequest(apiService.getUserInfo(userId), callback);}// GET request with parameters example// 带参数的GET请求示例public void getUserList(int page, int size, RequestCallback<List<UserInfo>> callback) {executeRequest(apiService.getUserList(page, size), callback);}// POST request example// POST请求示例public void login(String username, String password, RequestCallback<LoginResponse> callback) {executeRequest(apiService.login(username, password), callback);}// POST request with JSON example// 带JSON的POST请求示例public void createUser(UserInfo userInfo, RequestCallback<UserInfo> callback) {executeRequest(apiService.createUser(userInfo), callback);}// PUT request example// PUT请求示例public void updateUser(long userId, UserInfo userInfo, RequestCallback<UserInfo> callback) {executeRequest(apiService.updateUser(userId, userInfo), callback);}// DELETE request example// DELETE请求示例public void deleteUser(long userId, RequestCallback<Void> callback) {executeRequest(apiService.deleteUser(userId), callback);}// DELETE request with body example// 带请求体的DELETE请求示例public void batchDeleteUsers(List<Long> userIds, RequestCallback<Void> callback) {executeRequest(apiService.batchDeleteUsers(userIds), callback);}
}

4. Make Network Requests

4. 发起网络请求

4.1 POST Request Example
4.1 POST请求示例
UserService.getInstance().login("username", "password", new RequestCallback<LoginResponse>() {@Overridepublic void onStart() {// Show loading state// 显示加载状态}@Overridepublic void onSuccess(LoginResponse data) {// Handle successful response// 处理成功响应}@Overridepublic void onError(int code, String message) {// Handle error response// 处理错误响应}@Overridepublic void onComplete() {// Request completed// 请求完成}
});
4.2 GET Request Example
4.2 GET请求示例
UserService.getInstance().getUserInfo(123, new RequestCallback<UserInfo>() {@Overridepublic void onStart() {// Show loading state// 显示加载状态}@Overridepublic void onSuccess(UserInfo data) {// Handle user information// 处理用户信息String username = data.getUsername();String email = data.getEmail();}@Overridepublic void onError(int code, String message) {// Handle errors, e.g., user not found// 处理错误,例如用户未找到}@Overridepublic void onComplete() {// Request completed// 请求完成}
});
4.3 PUT Request Example
4.3 PUT请求示例
// Create user information to update
// 创建要更新的用户信息
UserInfo userInfo = new UserInfo();
userInfo.setUsername("newUsername");
userInfo.setEmail("new.email@example.com");UserService.getInstance().updateUser(123, userInfo, new RequestCallback<UserInfo>() {@Overridepublic void onStart() {// Show updating state// 显示更新状态}@Overridepublic void onSuccess(UserInfo data) {// Handle updated user information// 处理更新后的用户信息}@Overridepublic void onError(int code, String message) {// Handle update failure// 处理更新失败}@Overridepublic void onComplete() {// Update request completed// 更新请求完成}
});
4.4 DELETE Request Example
4.4 DELETE请求示例
UserService.getInstance().deleteUser(123, new RequestCallback<Void>() {@Overridepublic void onStart() {// Show deleting state// 显示删除状态}@Overridepublic void onSuccess(Void data) {// Handle successful deletion// 处理成功删除}@Overridepublic void onError(int code, String message) {// Handle deletion failure// 处理删除失败}@Overridepublic void onComplete() {// Deletion request completed// 删除请求完成}
});

5. Managing Request Headers

5. 管理请求头

5.1 Setting Global Authentication Token
5.1 设置全局认证令牌
// Set a global authentication token that will be used for all requests
// 设置一个全局认证令牌,用于所有请求
HttpManager.getInstance().setGlobalToken("your-auth-token-here");
5.2 Adding Custom Headers
5.2 添加自定义请求头
// Add a single custom header
// 添加单个自定义请求头
HttpManager.getInstance().addGlobalHeader("Custom-Header", "Header-Value");// Add multiple headers at once
// 一次添加多个请求头
Map<String, String> headers = new HashMap<>();
headers.put("X-API-Key", "api-key-value");
headers.put("Accept-Language", "en-US");
HttpManager.getInstance().addGlobalHeaders(headers);
5.3 Removing Headers
5.3 移除请求头
// Remove a specific header
// 移除特定请求头
HttpManager.getInstance().removeGlobalHeader("Custom-Header");// Clear all global headers
// 清除所有全局请求头
HttpManager.getInstance().clearGlobalHeaders();
5.4 Example: Managing Authentication Token After Login
5.4 示例:登录后管理认证令牌
UserService.getInstance().login("username", "password", new RequestCallback<LoginResponse>() {@Overridepublic void onStart() {// Show loading state// 显示加载状态}@Overridepublic void onSuccess(LoginResponse data) {// After successful login, set the authentication token// 登录成功后,设置认证令牌if (data != null && data.getToken() != null) {HttpManager.getInstance().setGlobalToken(data.getToken());}// Handle other login response data// 处理其他登录响应数据}@Overridepublic void onError(int code, String message) {// Handle login failure// 处理登录失败}@Overridepublic void onComplete() {// Login request completed// 登录请求完成}
});

Design Patterns

设计模式

This library uses multiple design patterns:
此库使用多种设计模式:

  • Singleton Pattern: HttpManager
  • 单例模式HttpManager
  • Builder Pattern: HttpConfig.Builder
  • 构建者模式HttpConfig.Builder
  • Factory Pattern: HttpManager.createApi()
  • 工厂模式HttpManager.createApi()
  • Observer Pattern: RequestCallback
  • 观察者模式RequestCallback
  • Template Method Pattern: BaseApiService
  • 模板方法模式BaseApiService
  • Strategy Pattern: Different request strategies through different API interfaces
  • 策略模式:通过不同的API接口实现不同的请求策略
  • Proxy Pattern: HeaderInterceptor
  • 代理模式HeaderInterceptor

Project Structure

项目结构

com.vance0901.zhuhai.network.http
├── HttpManager.java               // HTTP Manager
│                                  // HTTP管理器
│                                  
├── callback                       // Callback interfaces
│                                  // 回调接口
│   └── RequestCallback.java       // Request callback interface
│                                  // 请求回调接口
├── config                         // Configuration classes
│                                  // 配置类
│   └── HttpConfig.java            // HTTP configuration class
│                                  // HTTP配置类
├── interceptor                    // Interceptors
│                                  // 拦截器
│   └── HeaderInterceptor.java     // Request header interceptor
│                                  // 请求头拦截器
├── model                          // Data models
│                                  // 数据模型
│   └── BaseResponse.java          // Base response class
│                                  // 基础响应类
└── service                        // Service classes// 服务类└── BaseApiService.java        // Base API service class// 基础API服务类
JAVA开发者或其他开发人员使用请参考:
https://central.sonatype.com/artifact/io.github.vance0901/http/overview
For JAVA developers or other developers to use, please refer to:
https://central.sonatype.com/artifact/io.github.vance0901/http/overview
更多详细用法请查看demo。 For more detailed usage, please refer to the demo.

代码链接:

https://github.com/vance0901/ZhuHaiHttp

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/71571.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/71571.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

os-copilot安装和使用体验测评

简介&#xff1a; OS Copilot是阿里云基于大模型构建的Linux系统智能助手&#xff0c;支持自然语言问答、命令执行和系统运维调优。本文介绍其产品优势、功能及使用方法&#xff0c;并分享个人开发者在云服务器资源管理中的实际应用体验。通过-t/-f/管道功能&#xff0c;OS Cop…

Python Flask框架学习汇编

1、入门级&#xff1a; 《Python Flask Web 框架入门》 这篇博文条理清晰&#xff0c;由简入繁&#xff0c;案例丰富&#xff0c;分十五节详细讲解了Flask框架&#xff0c;强烈推荐&#xff01; 《python的简单web框架flask【附例子】》 讲解的特别清楚&#xff0c;每一步都…

【HarmonyOS Next之旅】DevEco Studio使用指南(一)

目录 1 -> 工具简介 1.1 -> 概述 1.2 -> HarmonyOS应用/服务开发流程 1.2.1 -> 开发准备 1.2.2 -> 开发应用/服务 1.2.3 -> 运行、调试和测试应用/服务 1.2.4 -> 发布应用/服务 2 -> 工程介绍 2.1 -> APP包结构 2.2 -> 切换工程视图 …

Manus开源平替-开源通用智能体

原文链接:https://i68.ltd/notes/posts/250306-opensource-agi-agent/ OWL-比Manus还强的全能开源Agent OWL: Optimized Workforce Learning for General Multi-Agent Assistance in Real-World Task Automation&#xff0c;现实世界中执行自动化任务的通用多代理辅助优化学习…

【3.2-3.8学习周报】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 摘要Abstract一、方法介绍1.任务适应性持续预训练&#xff08;TACP&#xff09;2.领域自适应连续预训练&#xff08;DACP&#xff09;3.ETS-DACP和ETA-DACP 二、实验…

【Linux】用户和组

思考 使用useradd在Linux下面创建一个用户&#xff0c;默认情况下&#xff0c;会自动创建一个同名组&#xff0c;并且加入其中&#xff0c;那么是先创建用户呢&#xff1f;还是先创建组呢&#xff1f; 很简单&#xff0c;我们实践一下不就知道了&#xff0c;如下所示&#xff…

新编大学应用英语综合教程2 U校园全套参考答案

全套答案获取&#xff1a; 链接&#xff1a;https://pan.quark.cn/s/389618f53143

SAP 顾问的五年职业规划

SAP 顾问的职业发展受到技术进步、企业需求变化和全球经济环境的影响&#xff0c;因此制定长远规划充满挑战。面对 SAP 产品路线图的不确定性&#xff0c;如向 S/4HANA 和 Business Technology Platform (BTP) 的转变&#xff0c;顾问必须具备灵活性&#xff0c;以保持竞争力和…

图像生成-ICCV2019-SinGAN: Learning a Generative Model from a Single Natural Image

图像生成-ICCV2019-SinGAN: Learning a Generative Model from a Single Natural Image 文章目录 图像生成-ICCV2019-SinGAN: Learning a Generative Model from a Single Natural Image主要创新点模型架构图生成器生成器源码 判别器判别器源码 损失函数需要源码讲解的私信我 S…

Networking Based ISAC Hardware Testbed and Performance Evaluation

文章目录 Applications and Challenges of Networked SensingCooperation Mechanism in Networked SensingChallenges and Key Enabling Technologies 5G NR Frame Structure Based ISAC ApproachSignals Available for Radio SensingMulti-Dimensiona Resource Optimization S…

2025年主流原型工具测评:墨刀、Axure、Figma、Sketch

2025年主流原型工具测评&#xff1a;墨刀、Axure、Figma、Sketch 要说2025年国内产品经理使用的主流原型设计工具&#xff0c;当然是墨刀、Axure、Figma和Sketch了&#xff0c;但是很多刚入行的产品经理不了解自己适合哪些工具&#xff0c;本文将从核心优势、局限短板、协作能…

我代表中国受邀在亚马逊云科技全球云计算大会re:Invent中技术演讲

大家好我是小李哥&#xff0c;本名叫李少奕&#xff0c;目前在一家金融行业公司担任首席云计算工程师。去年5月很荣幸在全球千万名开发者中被选为了全球亚马逊云科技认证技术专家&#xff08;AWS Hero&#xff09;&#xff0c;是近10年来大陆地区仅有的第9名大陆专家。同时作为…

LeetCode 解题思路 12(Hot 100)

解题思路&#xff1a; 定义三个指针&#xff1a; prev&#xff08;前驱节点&#xff09;、current&#xff08;当前节点&#xff09;、nextNode&#xff08;临时保存下一个节点&#xff09;遍历链表&#xff1a; 每次将 current.next 指向 prev&#xff0c;移动指针直到 curre…

Ubuntu搭建最简单WEB服务器

安装apache2 sudo apt install apache2 检查状态 $ sudo systemctl status apache2 ● apache2.service - The Apache HTTP ServerLoaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor prese>Active: active (running) since Thu 2025-03-06 09:51:10…

Linux 软硬链接

目录 软硬链接 软链接 硬链接 软硬链接的区别 硬链接场景 软连接场景 软硬链接 软链接 我们可以通过以下命令创建一个文件的软连接 ln -s mytest softlink-mytest 通过 ls -i -l 命令我们可以看到&#xff0c;软链接文件的inode号与源文件的inode号是不同的&#xff0c…

不同开发语言之for循环的用法、区别总结

一、Objective-C &#xff08;1&#xff09;标准的c风格 for (int i 0; i < 5; i) {NSLog("i %d", i); } &#xff08;2&#xff09;for in循环。 NSArray *array ["apple", "banana", "orange"]; for (NSString *fruit in …

计算机毕设-基于springboot的物业管理系统的设计与实现(附源码+lw+ppt+开题报告)

博主介绍&#xff1a;✌多个项目实战经验、多个大型网购商城开发经验、在某机构指导学员上千名、专注于本行业领域✌ 技术范围&#xff1a;Java实战项目、Python实战项目、微信小程序/安卓实战项目、爬虫大数据实战项目、Nodejs实战项目、PHP实战项目、.NET实战项目、Golang实战…

景联文科技:以精准数据标注赋能AI进化,构筑智能时代数据基石

在人工智能技术席卷全球的浪潮中&#xff0c;高质量数据已成为驱动AI模型进化的核心燃料。作为全球领先的AI数据服务解决方案提供商&#xff0c;景联文科技深耕数据标注领域多年&#xff0c;以技术为基、以专业为本&#xff0c;致力于为全球客户提供全场景、高精度、多模态的数…

批量合并 Word 文档,支持合并成一个 Word,也支持按文件夹合并

我们经常会碰到需要将多个 Word 文档批量合并成一个 Word 文档的场景&#xff0c;比如需要合并后打印、合并后方便整理存档等等。如果是人工的操作&#xff0c;会非常的麻烦。因此我们通常会借助一些批量处理脚本或者寻找批量处理的工具来帮我们实现批量合并 Word 文档的操作。…

数据安全基石:备份文件的重要性与自动化实践

在数字化时代&#xff0c;数据已成为企业和个人不可或缺的重要资产。无论是企业的运营数据、客户资料&#xff0c;还是个人的学习资料、家庭照片&#xff0c;这些数据都承载着巨大的价值。然而&#xff0c;数据的安全问题也日益凸显&#xff0c;硬件故障、软件错误、人为失误以…