Tutoriel de démarrage Android | okhttp + Retrofit comment annuler une demande

Android Yasuko. 2021-11-25 18:04:36
tutoriel marrage android okhttp retrofit

Dans une interface,L'utilisateur a lancé une demande de réseau,Pour une raison ou une autre, l'utilisateur a quitté l'interface actuelle avant que la demande de réseau ne soit terminée,Il est préférable d'annuler cette demande de réseau.Comment trouver cette demande de réseau et l'annuler?

Préface

Dans une interface,L'utilisateur a lancé une demande de réseau,Pour une raison ou une autre, l'utilisateur a quitté l'interface actuelle avant que la demande de réseau ne soit terminée,Il est préférable d'annuler cette demande de réseau.Pour OkHttp Dis,Plus précisément, l'appelCallDecancelMéthodes.

Comment trouver cette demande de réseau et l'annuler?

Les opérations sont généralement divisées en3Pas:

  • Première étape,Lors de l'établissement de la demande,Demande(request)Ajouter un marqueur;
  • Deuxième étape,Selon le marquage,Trouver la demande;
  • Enfin,Annuler cette demande.

OkHttpDanstag

Pour annuler une demande,OkHttpPeut être utilisé dans cancel Méthodes.

OkHttp De request Les objets ont tag.Peut être basé surtagPour marquer la demande..

//Set tags for your requests when you build them:
Request request = new Request.Builder().
url(url).tag("requestKey").build();
//When you want to cancel:
//A) go through the queued calls and cancel if the tag matches:
for (Call call : mHttpClient.dispatcher().queuedCalls()) {
if (call.request().tag().equals("requestKey"))
call.cancel();
}
//B) go through the running calls and cancel if the tag matches:
for (Call call : mHttpClient.dispatcher().runningCalls()) {
if (call.request().tag().equals("requestKey"))
call.cancel();
}

Retrofit L'interface pour annuler la demande n'est pas affichée dans . Comment trouver la demande de réseau cible ?

Retrofit Ajouter une personnalisation header

Pour chaque page (Activity,Fragment)Questions connexes request Ajouter une personnalisation header. Voilà. OkHttpClientAjouter un intercepteur. Marquer l'état de vie de la page . Si la page est détruite , Alors annulez request.

Par GithubOnAndroid Exemples de projets

Ajouter un marqueur

Tenir un ConcurrentHashMap Pour marquer l'état de survie de la page .

private static ConcurrentHashMap<String, Boolean> actLiveMap = new ConcurrentHashMap<>(); // MarquageActivitySurvie ou non
public static void markPageAlive(String actName) {
actLiveMap.put(actName, true);
}
public static void markPageDestroy(String actName) {
actLiveMap.put(actName, false);
}
Activity Enregistrer l'état de l'interface dans

Pour le moment Activity Nom..Chaque Activity Le tagname doit être unique .

private static final String MY_ACT_NAME = "xxx1Activity";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
NetworkCenter.markPageAlive(MY_ACT_NAME);
// ...
}
@Override
protected void onDestroy() {
super.onDestroy();
NetworkCenter.markPageDestroy(MY_ACT_NAME);
// ...
}
OkHttpClient Ajouter un intercepteur

Voilà. OkHttpClient Ajouter un intercepteur, Vérifiez la survie de la page dans l'intercepteur . Après inspection, Personnalisez ça headerSupprimer.

public static final String HEADER_ACT_NAME = "Activity-Name"; // MarquageActivity Nom de l'interface
private Interceptor lifeInterceptor = new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request();
String actName = request.header(HEADER_ACT_NAME);
if (!TextUtils.isEmpty(actName)) {
Log.d(TAG, "lifeInterceptor: actName: " + actName);
Boolean actLive = actLiveMap.get(actName);
if (actLive == null || !actLive) {
chain.call().cancel();
Log.d(TAG, "lifeInterceptor: Demande d'annulation, actName: " + actName);
} else {
Log.d(TAG, "lifeInterceptor: Demande d'initiation, actName: " + actName);
}
}
Request newRequest = request.newBuilder().removeHeader(HEADER_ACT_NAME).build();
return chain.proceed(newRequest);
}
};
OkHttpClient = new OkHttpClient.Builder()
.readTimeout(10, TimeUnit.SECONDS)
.connectTimeout(10, TimeUnit.SECONDS)
.addInterceptor(lifeInterceptor) // Ajouter un intercepteur
.build();

call.cancel() Après, Ne pars plus Retrofit De subscribe Méthodes.

Ajouter header
@GET("users/{owner}/repos")
Observable<List<UserRepo>> userRepo(
@Header(NetworkCenter.HEADER_ACT_NAME) @Nullable String actName,
@Path("owner") String owner,
@Query("sort") String sortType);

AndroidDéveloppement:Frame Source Analysis Video Reference

版权声明
本文为[Android Yasuko.]所创,转载请带上原文链接,感谢
https://javamana.com/2021/11/20211125180118170y.html

  1. 6年老猿带你掌握Spring Boot实现定时任务的动态增删启停
  2. disruptor笔记之六:常见场景,java教程从入门到精通pdf百度云
  3. Pourquoi InnoDB n'utilise - t - il pas un cache LRU naïf?
  4. Java Reflection (2): quelques opérations de base de reflection
  5. 6年老猿帶你掌握Spring Boot實現定時任務的動態增删啟停
  6. Les singes âgés vous permettent de maîtriser le démarrage et l'arrêt dynamiques des tâches programmées par Spring boot
  7. Docker From Beginning to Practice Series IV - docker Container chorégraphe Clean docker Composition
  8. 编写 java 程序,为家用电脑 ipv6 自动更新 goddy dns 记录(ddns)
  9. java jvm-old gc耗时几十s,导致系统告警
  10. Disruptor note 6: scénario commun, tutoriel Java de l'introduction à la maîtrise du PDF Baidu Cloud
  11. 编写Java程序启动脚本最佳实践
  12. How to get the correct Linux user's documents, music videos and other directories?
  13. Java JVM Old GC prend des dizaines de s, ce qui provoque une alarme système
  14. Écrivez un programme Java pour mettre à jour automatiquement les enregistrements DNS goddy (ddns) pour l'ordinateur domestique IPv6
  15. 編寫Java程序啟動脚本最佳實踐
  16. Meilleures pratiques pour écrire des scripts de démarrage de programmes Java
  17. Notes sur springcloud Eureka
  18. Ajout, suppression et modification simples de mybatis
  19. MySQL Learning - Logging System Redo log and Bin log
  20. Springboot Common comments | @ configuration
  21. Mécanisme d'expiration du cache redis et d'élimination de la mémoire
  22. Analyse concise du code source redis 01 - configuration de l'environnement
  23. Java - carte mémoire de l'objet
  24. Redis source Concise Analysis 02 - SDS String
  25. Why did docker lose to kubernetes? Docker employee readme!
  26. Spring cloud gateway practice 2: more routing configuration methods
  27. Principe de mise en œuvre ultime du mécanisme de concurrence Java sous - jacent
  28. [démarrer avec Java 100 exemples] 13. Modifier l’extension de fichier - remplacement de chaîne
  29. Java期末作业——王者荣耀的洛克王国版游戏
  30. Elasticsearch聚合学习之五:排序结果不准的问题分析,阿里巴巴java性能调优实战
  31. Java期末作業——王者榮耀的洛克王國版遊戲
  32. Java final work - King's Glory Rock Kingdom Game
  33. 【网络编程】TCP 网络应用程序开发
  34. 【网络编程入门】什么是 IP、端口、TCP、Socket?
  35. 【網絡編程入門】什麼是 IP、端口、TCP、Socket?
  36. [Introduction à la programmation réseau] qu'est - ce que IP, port, TCP et socket?
  37. [programmation réseau] développement d'applications réseau TCP
  38. [Java Basics] comprendre les génériques
  39. Dix outils open source que les architectes de logiciels Java devraient maîtriser!!
  40. Java经典面试题详解,突围金九银十面试季(附详细答案,mysql集群架构部署方案
  41. java架构之路(多线程)synchronized详解以及锁的膨胀升级过程,mysql数据库实用教程pdf
  42. java整理,java高级特性编程及实战第一章
  43. java教程——反射,mongodb下载教程
  44. Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day12,zookeeper原理作用
  45. Java后端互联网500道中高级面试题(含答案),linux钩子技术
  46. java8 Stream API及常用方法,java初级程序员面试
  47. java-集合-Map(双列)——迪迦重制版,2021Java开发社招面试解答之性能优化
  48. Flink处理函数实战之二:ProcessFunction类,java线程面试题目
  49. flex 布局详解,【Java面试题
  50. Linux basic command learning
  51. Why did docker lose to kubernetes? Docker employee readme!
  52. MySQL安装
  53. Elastic Search Aggregate Learning five: Problem Analysis of Uncertainty of sequencing results, Alibaba Java Performance Tuning Practical
  54. Installing, configuring, starting and accessing rabbitmq under Linux
  55. Oracle SQL injection summary
  56. Installation MySQL
  57. L'exposition à la photo d'essai sur la route i7 du nouveau vaisseau amiral de BMW Pure Electric a également été comparée à celle de Xiaopeng p7.
  58. spring JTA 关于异常处理的时机问题
  59. Le problème du temps de traitement des exceptions dans la JTA printanière
  60. Do you really know MySQL order by