perf:验证码 浏览器页面内容缓存到内存

pull/1846/head
Xwite 3 years ago
parent 20f4f450e9
commit 5f64023930
  1. 5
      app/src/main/java/io/legado/app/help/CacheManager.kt
  2. 10
      app/src/main/java/io/legado/app/ui/association/VerificationCodeDialog.kt
  3. 2
      app/src/main/java/io/legado/app/ui/browser/WebViewModel.kt

@ -35,6 +35,11 @@ object CacheManager {
}
}
fun putMemory(key: String, value: Any) {
val cache = Cache(key, value.toString(), 0)
memoryLruCache.put(key, cache)
}
fun get(key: String): String? {
return getFromMemory(key) ?: appDb.cacheDao.get(key, System.currentTimeMillis())
}

@ -19,7 +19,7 @@ import io.legado.app.utils.viewbindingdelegate.viewBinding
/**
* 图片验证码对话框
* 结果保存在数据库
* 结果保存在内存
* val key = "${sourceOrigin ?: ""}_verificationResult"
* CacheManager.get(key)
*/
@ -62,8 +62,8 @@ class VerificationCodeDialog() : BaseDialogFragment(R.layout.dialog_verification
}
tvOk.setOnClickListener {
val verificationCode = binding.verificationCode.text.toString()
verificationCode?.let {
CacheManager.put(key, it)
verificationCode.let {
CacheManager.putMemory(key, it)
dismiss()
}
}
@ -75,8 +75,8 @@ class VerificationCodeDialog() : BaseDialogFragment(R.layout.dialog_verification
override fun onDestroy() {
val sourceOrigin = arguments?.getString("sourceOrigin")
val key = "${sourceOrigin ?: ""}_verificationResult"
CacheManager.get(key) ?: CacheManager.put(key, "")
val key = "${sourceOrigin}_verificationResult"
CacheManager.get(key) ?: CacheManager.putMemory(key, "")
super.onDestroy()
activity?.finish()
}

@ -87,7 +87,7 @@ class WebViewModel(application: Application) : BaseViewModel(application) {
if (sourceVerificationEnable) {
val key = "${sourceOrigin}_verificationResult"
html = AnalyzeUrl(baseUrl, headerMapF = headerMap).getStrResponse(useWebView = false).body
CacheManager.put(key, html ?: "")
CacheManager.putMemory(key, html ?: "")
}
}

Loading…
Cancel
Save