Nohttp详细使用文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NoHttp 是专门做Android网络请求与下载的框架。支持HTTP/HTTPS,自动维持Cookie,异步/同步请求,大文件/多文件上传,文件下载;支持304缓存,302/303重定向,支持代理服务器。NoHttp特性:支持HTTP/HTTPS,自动维持Cookie,异步/同步请求,大文件/多文件上传,文件下载,上传下载均有进度。支持304缓存,自定义缓存,302/303重定向,支持代理服务器访问地址(如: Google)。NoHttp是队列,自动为请求排队,可以取消指定请求, 可以取消队列所有请求,亦可以停止队列。支持请求String、Bitmap、Json、JavaBean,可自定义扩展请求类型。Request对象包涵参数、文件、请求头等;Response对象包涵响应内容,响应头等信息,Cookie。使用Gradle构建时添加依赖:// 引用最新版 compile 'com.yolanda.nohttp:nohttp: ' // 或则引用指定版本 compile 'com.yolanda.nohttp:nohttp:1.0.0'一. 请求1.请求String数据// 请求对象 Request request = NoHttp.createStringRequest(url, requestMethod); //添加请求头 request.addHeader("AppVersioin", "2.0"); // 添加请求参数 request.add("userName", "yolanda"); //上传文件 request.add("file", new FileBinary(file)); ...2.请求Json数据// JsonObject Request request = NoHttp.createJsonObjectRequest(url, reqeustMethod); queue.add(what, request, responseListener); … // JsonArray Request request = NoHttp.createJsonArrayRequest(url, reqeustMethod); queue.add(what, request, responseListener);3. 请求Bitmap数据Request request = NoHttp.createImageRequest(url, requestMethod); ...4. 取消请求取消单个请求Request request = NoHttp.createStringRequest(url); ... request.cancel();从队列中取消指定的请求Request request = NoHttp.createStringRequest(url); request.setCancelSign(sign); … queue.cancelBySign(sign);取消队列中所有请求queue.cancelAll();停止队列RequestQueue queue = NoHttp.newRequestQueue(); ... queue.stop();5. 同步请求// 在当前线程发起请求,在线程这么使用 Request request = NoHttp.createStringRequest(url); Response response = NoHttp.startRequestSync(request); if (response.isSucceed()) {     // 请求成功 } else {     // 请求失败 }二. 缓存1. Http标准协议的缓存,比如响应码是304时现在很多公司使用了RESTFUL风格来写Http API,所以这个是必须有的。Request request = NoHttp.createJsonObjectRequest(url); // NoHttp本身是RESTFUL风格的标准Http协议,所以这里不用设置或者设置为DEFAULT request.setCacheMode(CacheMode.DEFAULT); ...2. 当请求服务器失败的时候,读取缓存Request request = NoHttp.createJsonObjectRequest(url); // 非标准Http协议,改变缓存模式为REQUEST_FAILED_READ_CACHE request.setCacheMode(CacheMode.REQUEST_FAILED_READ_CACHE); ...3. 如果发现有缓存直接成功,没有缓存才请求服务器我们知道ImageLoader的核心除了内存优化外,剩下一个就是发现把内地有图片则直接使用,没有则请求服务器,所以NoHttp这一点非常使用做一个ImageLoader。Request request = NoHttp.createJsonObjectRequest(url); // 非标准Http协议,改变缓存模式为IF_NONE_CACHE_REQUEST request.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST); ...请求图片,缓存图片。// 如果没有缓存才去请求服务器,否则使用缓存,缓存图片演示 Request request = NoHttp.createImageRequest(imageUrl); request.setCacheMode(CacheMode.IF_NONE_CACHE_REQUEST); ...4. 仅仅读取缓存Request request = NoHttp.createJsonObjectRequest(url); // 非标准Http协议,改变缓存模式为ONLY_READ_CACHE request.setCacheMode(CacheMode.ONLY_READ_CACHE); ...注意:缓存不管是String、Json、图片还是任何请求都可以被NoHttp缓存二、响应OnResponseListener responseListener = new OnResponseListener() {     @Override     public void onStart(int what) {         // 请求开始时,可以显示一个Dialog     }     @Override     public void onFinish(int what) {         // 请求接受时,关闭Dialog     }     @Override     public void onSucceed(int what, Response response) {         // 接受请求结果         String result = response.get();         // Bitmap imageHead = response.get(); // 如果是bitmap类型,都是同样的用法     }     @Override     public void onFailed(int what, String url, Object tag, Exception exception, ...) {         // 请求失败或者发生异常         // 这里根据exception处理不同的错误,比如超时、网络不好等     } };三. 自定义请求类型: FastJsonRequest1.定义请求对象public class FastJsonRequest extends RestRequestor { public FastJsonRequest(String url) {     super(url); } public FastJsonRequest(String url, RequestMethod requestMethod) {     super(url, requestMethod); } @Override public JSONObject parseResponse(String url, Headers headers, byte[] responseBody) {     String result = StringRequest.parseResponseString(url, headers, responseBody);     JSONObject jsonObject = null;     if (!TextUtils.isEmpty(result)) {         jsonObject = JSON.parseObject(result);     } else {         // 这里默认的错误可以定义为你们自己的数据格式         jsonObject = JSON.toJSON("{}");     }     return jsonObject; } @Override public String getAccept() {     // 告诉服务器你接受什么类型的数据, 会添加到请求头的Accept中     return "application/json;q=1"; } }2.使用自定义请求-和NoHttp默认请求没有区别Request mRequest = new FastJsonRequest(url, requestMethod); queue.add(what, mRequest, responseListener);五. 下载文件发起下载请求//下载文件 downloadRequest = NoHttp.createDownloadRequest(url, fielDir, fileName, true, false); // what 区分下载 // downloadRequest 下载请求对象 // downloadListener 下载监听 CallServer.getDownloadInstance().add(0, downloadRequest, downloadListener);暂停或者停止下载downloadRequest.cancel();监听下载过程private DownloadListener downloadListener = new DownloadListener() {     @Override     public void onStart(int what, boolean resume, long preLenght, Headers header, long count) {     }     @Override     public void onProgress(int what, int progress, long downCount) {         // 更新下载进度     }     @Override     public void onFinish(int what, String filePath) {     }     @Override     public void onDownloadError(int what, StatusCode code, CharSequence message) {     }     @Override     public void onCancel(int what) {     } }; 标签:NoHttp
Spring Boot混淆是一种将Java代码混淆以保护知识产权和源代码的技术。混淆可以使反编译代码变得更加困难,从而使攻击者难以理解和修改代码。以下是一些Spring Boot混淆的方法: 1. 使用ProGuard进行混淆:ProGuard是一个流行的Java混淆器,可以将Java代码压缩和混淆,从而使反编译代码变得更加困难。可以在Spring Boot项目中使用ProGuard插件来进行混淆。 ```java buildscript { dependencies { classpath 'net.sf.proguard:proguard-gradle:6.2.2' } } plugins { id 'net.ltgt.errorprone' version '0.0.15' id 'org.springframework.boot' version '2.5.4' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'java' id 'application' id 'com.github.johnrengelman.shadow' version '7.0.0' id 'com.gorylenko.gradle-git-properties' version '2.2.0' id 'org.sonarqube' version '3.3' id 'jacoco' id 'idea' id 'org.springframework.boot.experimental.thin-launcher' version '1.0.26.RELEASE' id 'io.spring.nohttp' version '0.1.2' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'io.spring.dependency-management-platform' version '1.0.11.RELEASE' id 'org.springframework.boot.experimental.thin-launcher' version '1.0.26.RELEASE' id 'io.spring.nohttp' version '0.1.2' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'io.spring.dependency-management-platform' version '1.0.11.RELEASE' } dependencies { implementation 'org.springframework.boot:spring-boot-starter-web' testImplementation 'org.springframework.boot:spring-boot-starter-test' } task proguard(type: proguard.gradle.ProGuardTask) { configuration 'proguard.conf' injars 'build/libs/spring-boot-app.jar' outjars 'build/libs/spring-boot-app-proguarded.jar' } build.finalizedBy(proguard) ``` 2. 使用Obfuscator进行混淆:Obfuscator是另一种流行的Java混淆器,可以将Java代码压缩和混淆,从而使反编译代码变得更加困难。可以在Spring Boot项目中使用Obfuscator插件来进行混淆。 ```java buildscript { repositories { mavenCentral() } dependencies { classpath 'com.github.wvengen:proguard-gradle:6.2.2' } } plugins { id 'java' id 'application' id 'com.github.johnrengelman.shadow' version '7.0.0' id 'com.gorylenko.gradle-git-properties' version '2.2.0' id 'org.sonarqube' version '3.3' id 'jacoco' id 'idea' id 'org.springframework.boot.experimental.thin-launcher' version '1.0.26.RELEASE' id 'io.spring.nohttp' version '0.1.2' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'io.spring.dependency-management-platform' version '1.0.11.RELEASE' } dependencies { implementation 'org.springframework.boot:spring-boot-starter-web' testImplementation 'org.springframework.boot:spring-boot-starter-test' } task obfuscate(type: proguard.gradle.ProGuardTask) { configuration 'proguard.conf' injars 'build/libs/spring-boot-app.jar' outjars 'build/libs/spring-boot-app-obfuscated.jar' } build.finalizedBy(obfuscate) ``` 3. 使用Jscrambler进行混淆:Jscrambler是一种商业混淆器,可以将Java代码压缩和混淆,从而使反编译代码变得更加困难。可以在Spring Boot项目中使用Jscrambler插件来进行混淆。 ```java buildscript { repositories { mavenCentral() } dependencies { classpath 'com.jscrambler:jscrambler-gradle-plugin:5.8.0' } } plugins { id 'java' id 'application' id 'com.github.johnrengelman.shadow' version '7.0.0' id 'com.gorylenko.gradle-git-properties' version '2.2.0' id 'org.sonarqube' version '3.3' id 'jacoco' id 'idea' id 'org.springframework.boot.experimental.thin-launcher' version '1.0.26.RELEASE' id 'io.spring.nohttp' version '0.1.2' id 'io.spring.dependency-management' version '1.0.11.RELEASE' id 'io.spring.dependency-management-platform' version '1.0.11.RELEASE' } dependencies { implementation 'org.springframework.boot:spring-boot-starter-web' testImplementation 'org.springframework.boot:spring-boot-starter-test' } jscrambler { files { source = fileTree('src/main/java') } keys { accessKey = 'your-access-key' secretKey = 'your-secret-key' } params { applicationTypes = 'web' languageSpecifications = 'es6' transformations = 'string-splitting' } } build.finalizedBy(jscrambler) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值