log-recorder.html 35 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474
  1. <!doctype html>
  2. <html lang="zh" class="no-js">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <meta name="description" content="Net document">
  7. <meta name="author" content="劉強東">
  8. <link rel="prev" href="fastest.html">
  9. <link rel="next" href="log-notice.html">
  10. <link rel="icon" href="img/book-open.svg">
  11. <meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.5.48">
  12. <title>日志插件 - Net</title>
  13. <link rel="stylesheet" href="assets/stylesheets/main.6f8fc17f.min.css">
  14. <link rel="stylesheet" href="assets/stylesheets/palette.06af60db.min.css">
  15. <script src="https://unpkg.com/iframe-worker/shim"></script>
  16. <link rel="stylesheet" href="css/extra.css">
  17. <script>__md_scope=new URL(".",location),__md_hash=e=>[...e].reduce(((e,_)=>(e<<5)-e+_.charCodeAt(0)),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
  18. </head>
  19. <body dir="ltr" data-md-color-scheme="default" data-md-color-primary="white" data-md-color-accent="indigo">
  20. <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
  21. <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
  22. <label class="md-overlay" for="__drawer"></label>
  23. <div data-md-component="skip">
  24. <a href="#logrecordinterceptor" class="md-skip">
  25. 跳转至
  26. </a>
  27. </div>
  28. <div data-md-component="announce">
  29. </div>
  30. <header class="md-header md-header--shadow" data-md-component="header">
  31. <nav class="md-header__inner md-grid" aria-label="页眉">
  32. <a href="index.html" title="Net" class="md-header__button md-logo" aria-label="Net" data-md-component="logo">
  33. <img src="img/book-open.svg" alt="logo">
  34. </a>
  35. <label class="md-header__button md-icon" for="__drawer">
  36. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z"/></svg>
  37. </label>
  38. <div class="md-header__title" data-md-component="header-title">
  39. <div class="md-header__ellipsis">
  40. <div class="md-header__topic">
  41. <span class="md-ellipsis">
  42. Net
  43. </span>
  44. </div>
  45. <div class="md-header__topic" data-md-component="header-topic">
  46. <span class="md-ellipsis">
  47. 日志插件
  48. </span>
  49. </div>
  50. </div>
  51. </div>
  52. <form class="md-header__option" data-md-component="palette">
  53. <input class="md-option" data-md-color-media="(prefers-color-scheme: light)" data-md-color-scheme="default" data-md-color-primary="white" data-md-color-accent="indigo" aria-hidden="true" type="radio" name="__palette" id="__palette_0">
  54. </form>
  55. <script>var palette=__md_get("__palette");if(palette&&palette.color){if("(prefers-color-scheme)"===palette.color.media){var media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent")}for(var[key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
  56. <label class="md-header__button md-icon" for="__search">
  57. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
  58. </label>
  59. <div class="md-search" data-md-component="search" role="dialog">
  60. <label class="md-search__overlay" for="__search"></label>
  61. <div class="md-search__inner" role="search">
  62. <form class="md-search__form" name="search">
  63. <input type="text" class="md-search__input" name="query" aria-label="搜索" placeholder="搜索" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
  64. <label class="md-search__icon md-icon" for="__search">
  65. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
  66. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
  67. </label>
  68. <nav class="md-search__options" aria-label="查找">
  69. <a href="javascript:void(0)" class="md-search__icon md-icon" title="分享" aria-label="分享" data-clipboard data-clipboard-text="" data-md-component="search-share" tabindex="-1">
  70. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M18 16.08c-.76 0-1.44.3-1.96.77L8.91 12.7c.05-.23.09-.46.09-.7s-.04-.47-.09-.7l7.05-4.11c.54.5 1.25.81 2.04.81a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3c0 .24.04.47.09.7L8.04 9.81C7.5 9.31 6.79 9 6 9a3 3 0 0 0-3 3 3 3 0 0 0 3 3c.79 0 1.5-.31 2.04-.81l7.12 4.15c-.05.21-.08.43-.08.66 0 1.61 1.31 2.91 2.92 2.91s2.92-1.3 2.92-2.91A2.92 2.92 0 0 0 18 16.08"/></svg>
  71. </a>
  72. <button type="reset" class="md-search__icon md-icon" title="清空当前内容" aria-label="清空当前内容" tabindex="-1">
  73. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>
  74. </button>
  75. </nav>
  76. <div class="md-search__suggest" data-md-component="search-suggest"></div>
  77. </form>
  78. <div class="md-search__output">
  79. <div class="md-search__scrollwrap" tabindex="0" data-md-scrollfix>
  80. <div class="md-search-result" data-md-component="search-result">
  81. <div class="md-search-result__meta">
  82. 正在初始化搜索引擎
  83. </div>
  84. <ol class="md-search-result__list" role="presentation"></ol>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. </div>
  90. <div class="md-header__source">
  91. <a href="https://github.com/liangjingkanji/Net" title="前往仓库" class="md-source" data-md-component="source">
  92. <div class="md-source__icon md-icon">
  93. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.7.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc.--><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81"/></svg>
  94. </div>
  95. <div class="md-source__repository">
  96. GitHub
  97. </div>
  98. </a>
  99. </div>
  100. </nav>
  101. </header>
  102. <div class="md-container" data-md-component="container">
  103. <main class="md-main" data-md-component="main">
  104. <div class="md-main__inner md-grid">
  105. <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
  106. <div class="md-sidebar__scrollwrap">
  107. <div class="md-sidebar__inner">
  108. <nav class="md-nav md-nav--primary" aria-label="导航栏" data-md-level="0">
  109. <label class="md-nav__title" for="__drawer">
  110. <a href="index.html" title="Net" class="md-nav__button md-logo" aria-label="Net" data-md-component="logo">
  111. <img src="img/book-open.svg" alt="logo">
  112. </a>
  113. Net
  114. </label>
  115. <div class="md-nav__source">
  116. <a href="https://github.com/liangjingkanji/Net" title="前往仓库" class="md-source" data-md-component="source">
  117. <div class="md-source__icon md-icon">
  118. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.7.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc.--><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81"/></svg>
  119. </div>
  120. <div class="md-source__repository">
  121. GitHub
  122. </div>
  123. </a>
  124. </div>
  125. <ul class="md-nav__list" data-md-scrollfix>
  126. <li class="md-nav__item">
  127. <a href="index.html" class="md-nav__link">
  128. <span class="md-ellipsis">
  129. 使用
  130. </span>
  131. </a>
  132. </li>
  133. <li class="md-nav__item">
  134. <a href="coroutine-request.html" class="md-nav__link">
  135. <span class="md-ellipsis">
  136. 协程请求
  137. </span>
  138. </a>
  139. </li>
  140. <li class="md-nav__item">
  141. <a href="scope.html" class="md-nav__link">
  142. <span class="md-ellipsis">
  143. 作用域
  144. </span>
  145. </a>
  146. </li>
  147. <li class="md-nav__item">
  148. <a href="sync-request.html" class="md-nav__link">
  149. <span class="md-ellipsis">
  150. 同步请求
  151. </span>
  152. </a>
  153. </li>
  154. <li class="md-nav__item">
  155. <a href="request.html" class="md-nav__link">
  156. <span class="md-ellipsis">
  157. 请求参数
  158. </span>
  159. </a>
  160. </li>
  161. <li class="md-nav__item">
  162. <a href="config.html" class="md-nav__link">
  163. <span class="md-ellipsis">
  164. 全局配置
  165. </span>
  166. </a>
  167. </li>
  168. <li class="md-nav__item md-nav__item--pruned md-nav__item--nested">
  169. <a href="converter.html" class="md-nav__link">
  170. <span class="md-ellipsis">
  171. 请求结果
  172. </span>
  173. <span class="md-nav__icon md-icon"></span>
  174. </a>
  175. </li>
  176. <li class="md-nav__item md-nav__item--pruned md-nav__item--nested">
  177. <a href="auto-dialog.html" class="md-nav__link">
  178. <span class="md-ellipsis">
  179. 自动化
  180. </span>
  181. <span class="md-nav__icon md-icon"></span>
  182. </a>
  183. </li>
  184. <li class="md-nav__item">
  185. <a href="thread.html" class="md-nav__link">
  186. <span class="md-ellipsis">
  187. 切换线程
  188. </span>
  189. </a>
  190. </li>
  191. <li class="md-nav__item">
  192. <a href="view-model.html" class="md-nav__link">
  193. <span class="md-ellipsis">
  194. ViewModel
  195. </span>
  196. </a>
  197. </li>
  198. <li class="md-nav__item">
  199. <a href="track.html" class="md-nav__link">
  200. <span class="md-ellipsis">
  201. 异常追踪
  202. </span>
  203. </a>
  204. </li>
  205. <li class="md-nav__item md-nav__item--pruned md-nav__item--nested">
  206. <a href="error.html" class="md-nav__link">
  207. <span class="md-ellipsis">
  208. 错误处理
  209. </span>
  210. <span class="md-nav__icon md-icon"></span>
  211. </a>
  212. </li>
  213. <li class="md-nav__item">
  214. <a href="okhttp-client.html" class="md-nav__link">
  215. <span class="md-ellipsis">
  216. OkHttpClient
  217. </span>
  218. </a>
  219. </li>
  220. <li class="md-nav__item">
  221. <a href="interceptor.html" class="md-nav__link">
  222. <span class="md-ellipsis">
  223. 拦截器
  224. </span>
  225. </a>
  226. </li>
  227. <li class="md-nav__item">
  228. <a href="https.html" class="md-nav__link">
  229. <span class="md-ellipsis">
  230. Https证书
  231. </span>
  232. </a>
  233. </li>
  234. <li class="md-nav__item">
  235. <a href="cookie.html" class="md-nav__link">
  236. <span class="md-ellipsis">
  237. Cookie
  238. </span>
  239. </a>
  240. </li>
  241. <li class="md-nav__item">
  242. <a href="cache.html" class="md-nav__link">
  243. <span class="md-ellipsis">
  244. 缓存
  245. </span>
  246. </a>
  247. </li>
  248. <li class="md-nav__item">
  249. <a href="tag.html" class="md-nav__link">
  250. <span class="md-ellipsis">
  251. 标签/额外
  252. </span>
  253. </a>
  254. </li>
  255. <li class="md-nav__item">
  256. <a href="upload-file.html" class="md-nav__link">
  257. <span class="md-ellipsis">
  258. 上传文件
  259. </span>
  260. </a>
  261. </li>
  262. <li class="md-nav__item">
  263. <a href="download-file.html" class="md-nav__link">
  264. <span class="md-ellipsis">
  265. 下载文件
  266. </span>
  267. </a>
  268. </li>
  269. <li class="md-nav__item">
  270. <a href="progress.html" class="md-nav__link">
  271. <span class="md-ellipsis">
  272. 进度监听
  273. </span>
  274. </a>
  275. </li>
  276. <li class="md-nav__item">
  277. <a href="cancel.html" class="md-nav__link">
  278. <span class="md-ellipsis">
  279. 取消请求
  280. </span>
  281. </a>
  282. </li>
  283. <li class="md-nav__item">
  284. <a href="repeat-request.html" class="md-nav__link">
  285. <span class="md-ellipsis">
  286. 重复请求
  287. </span>
  288. </a>
  289. </li>
  290. <li class="md-nav__item">
  291. <a href="debounce.html" class="md-nav__link">
  292. <span class="md-ellipsis">
  293. 搜索节流
  294. </span>
  295. </a>
  296. </li>
  297. <li class="md-nav__item">
  298. <a href="fastest.html" class="md-nav__link">
  299. <span class="md-ellipsis">
  300. 最快请求结果
  301. </span>
  302. </a>
  303. </li>
  304. <li class="md-nav__item md-nav__item--active">
  305. <input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
  306. <label class="md-nav__link md-nav__link--active" for="__toc">
  307. <span class="md-ellipsis">
  308. 日志插件
  309. </span>
  310. <span class="md-nav__icon md-icon"></span>
  311. </label>
  312. <a href="log-recorder.html" class="md-nav__link md-nav__link--active">
  313. <span class="md-ellipsis">
  314. 日志插件
  315. </span>
  316. </a>
  317. <nav class="md-nav md-nav--secondary" aria-label="目录">
  318. <label class="md-nav__title" for="__toc">
  319. <span class="md-nav__icon md-icon"></span>
  320. 目录
  321. </label>
  322. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  323. <li class="md-nav__item">
  324. <a href="#logrecordinterceptor" class="md-nav__link">
  325. <span class="md-ellipsis">
  326. LogRecordInterceptor
  327. </span>
  328. </a>
  329. </li>
  330. <li class="md-nav__item">
  331. <a href="#_1" class="md-nav__link">
  332. <span class="md-ellipsis">
  333. 安装插件
  334. </span>
  335. </a>
  336. <nav class="md-nav" aria-label="安装插件">
  337. <ul class="md-nav__list">
  338. <li class="md-nav__item">
  339. <a href="#1" class="md-nav__link">
  340. <span class="md-ellipsis">
  341. 1. 安装插件
  342. </span>
  343. </a>
  344. </li>
  345. <li class="md-nav__item">
  346. <a href="#2" class="md-nav__link">
  347. <span class="md-ellipsis">
  348. 2. 打开窗口
  349. </span>
  350. </a>
  351. </li>
  352. </ul>
  353. </nav>
  354. </li>
  355. <li class="md-nav__item">
  356. <a href="#_2" class="md-nav__link">
  357. <span class="md-ellipsis">
  358. 自定义日志
  359. </span>
  360. </a>
  361. </li>
  362. <li class="md-nav__item">
  363. <a href="#_3" class="md-nav__link">
  364. <span class="md-ellipsis">
  365. 日志过滤
  366. </span>
  367. </a>
  368. </li>
  369. <li class="md-nav__item">
  370. <a href="#_4" class="md-nav__link">
  371. <span class="md-ellipsis">
  372. 其他网络框架
  373. </span>
  374. </a>
  375. </li>
  376. </ul>
  377. </nav>
  378. </li>
  379. <li class="md-nav__item">
  380. <a href="log-notice.html" class="md-nav__link">
  381. <span class="md-ellipsis">
  382. 日志通知
  383. </span>
  384. </a>
  385. </li>
  386. <li class="md-nav__item">
  387. <a href="timing.html" class="md-nav__link">
  388. <span class="md-ellipsis">
  389. 限时/定时请求
  390. </span>
  391. </a>
  392. </li>
  393. <li class="md-nav__item">
  394. <a href="callback.html" class="md-nav__link">
  395. <span class="md-ellipsis">
  396. Callback
  397. </span>
  398. </a>
  399. </li>
  400. <li class="md-nav__item">
  401. <a href="interval.html" class="md-nav__link">
  402. <span class="md-ellipsis">
  403. 轮询器/倒计时
  404. </span>
  405. </a>
  406. </li>
  407. <li class="md-nav__item">
  408. <a href="https://github.com/liangjingkanji/Net/discussions" class="md-nav__link">
  409. <span class="md-ellipsis">
  410. 社区讨论
  411. </span>
  412. </a>
  413. </li>
  414. <li class="md-nav__item">
  415. <a href="issues.html" class="md-nav__link">
  416. <span class="md-ellipsis">
  417. 常见问题
  418. </span>
  419. </a>
  420. </li>
  421. <li class="md-nav__item">
  422. <a href="updates.html" class="md-nav__link">
  423. <span class="md-ellipsis">
  424. 更新日志
  425. </span>
  426. </a>
  427. </li>
  428. <li class="md-nav__item">
  429. <a href="api/index.html" class="md-nav__link">
  430. <span class="md-ellipsis">
  431. 3.x文档
  432. </span>
  433. </a>
  434. </li>
  435. </ul>
  436. </nav>
  437. </div>
  438. </div>
  439. </div>
  440. <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
  441. <div class="md-sidebar__scrollwrap">
  442. <div class="md-sidebar__inner">
  443. <nav class="md-nav md-nav--secondary" aria-label="目录">
  444. <label class="md-nav__title" for="__toc">
  445. <span class="md-nav__icon md-icon"></span>
  446. 目录
  447. </label>
  448. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  449. <li class="md-nav__item">
  450. <a href="#logrecordinterceptor" class="md-nav__link">
  451. <span class="md-ellipsis">
  452. LogRecordInterceptor
  453. </span>
  454. </a>
  455. </li>
  456. <li class="md-nav__item">
  457. <a href="#_1" class="md-nav__link">
  458. <span class="md-ellipsis">
  459. 安装插件
  460. </span>
  461. </a>
  462. <nav class="md-nav" aria-label="安装插件">
  463. <ul class="md-nav__list">
  464. <li class="md-nav__item">
  465. <a href="#1" class="md-nav__link">
  466. <span class="md-ellipsis">
  467. 1. 安装插件
  468. </span>
  469. </a>
  470. </li>
  471. <li class="md-nav__item">
  472. <a href="#2" class="md-nav__link">
  473. <span class="md-ellipsis">
  474. 2. 打开窗口
  475. </span>
  476. </a>
  477. </li>
  478. </ul>
  479. </nav>
  480. </li>
  481. <li class="md-nav__item">
  482. <a href="#_2" class="md-nav__link">
  483. <span class="md-ellipsis">
  484. 自定义日志
  485. </span>
  486. </a>
  487. </li>
  488. <li class="md-nav__item">
  489. <a href="#_3" class="md-nav__link">
  490. <span class="md-ellipsis">
  491. 日志过滤
  492. </span>
  493. </a>
  494. </li>
  495. <li class="md-nav__item">
  496. <a href="#_4" class="md-nav__link">
  497. <span class="md-ellipsis">
  498. 其他网络框架
  499. </span>
  500. </a>
  501. </li>
  502. </ul>
  503. </nav>
  504. </div>
  505. </div>
  506. </div>
  507. <div class="md-content" data-md-component="content">
  508. <article class="md-content__inner md-typeset">
  509. <h1>日志插件</h1>
  510. <p>以下两种日志插件</p>
  511. <table>
  512. <thead>
  513. <tr>
  514. <th><a href="https://github.com/itkacher/OkHttpProfiler">Okhttp Profiler</a></th>
  515. <th><a href="https://developer.android.com/studio/profile/network-profiler?hl=zh-cn">Profiler</a></th>
  516. </tr>
  517. </thead>
  518. <tbody>
  519. <tr>
  520. <td>列表显示</td>
  521. <td>动态曲线图</td>
  522. </tr>
  523. <tr>
  524. <td>添加<code>LogRecordInterceptor</code>拦截器</td>
  525. <td>默认记录所有OkHttp的请求</td>
  526. </tr>
  527. <tr>
  528. <td>原理是插件捕获LogCat日志, 线上环境需关闭</td>
  529. <td>无法捕获启动一瞬间的请求</td>
  530. </tr>
  531. </tbody>
  532. </table>
  533. <h2 id="logrecordinterceptor">LogRecordInterceptor<a class="headerlink" href="#logrecordinterceptor" title="Permanent link">&para;</a></h2>
  534. <p>添加日志拦截器</p>
  535. <div class="language-kotlin highlight"><pre><span></span><code><span id="__span-0-1"><a id="__codelineno-0-1" name="__codelineno-0-1" href="#__codelineno-0-1"></a><span class="n">NetConfig</span><span class="p">.</span><span class="na">initialize</span><span class="p">(</span><span class="n">Api</span><span class="p">.</span><span class="na">HOST</span><span class="p">,</span><span class="w"> </span><span class="k">this</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
  536. </span><span id="__span-0-2"><a id="__codelineno-0-2" name="__codelineno-0-2" href="#__codelineno-0-2"></a><span class="hll"><span class="w"> </span><span class="n">addInterceptor</span><span class="p">(</span><span class="n">LogRecordInterceptor</span><span class="p">(</span><span class="n">BuildConfig</span><span class="p">.</span><span class="na">DEBUG</span><span class="p">))</span>
  537. </span></span><span id="__span-0-3"><a id="__codelineno-0-3" name="__codelineno-0-3" href="#__codelineno-0-3"></a><span class="p">}</span>
  538. </span></code></pre></div>
  539. <table>
  540. <thead>
  541. <tr>
  542. <th>构造参数</th>
  543. <th>描述</th>
  544. </tr>
  545. </thead>
  546. <tbody>
  547. <tr>
  548. <td>enabled</td>
  549. <td>是否启用日志</td>
  550. </tr>
  551. <tr>
  552. <td>requestByteCount</td>
  553. <td>请求日志信息最大字节数, 默认1MB</td>
  554. </tr>
  555. <tr>
  556. <td>responseByteCount</td>
  557. <td>响应日志信息最大字节数, 默认4MB</td>
  558. </tr>
  559. </tbody>
  560. </table>
  561. <p>此时仅LogCat输出日志, 要预览请安装插件</p>
  562. <h2 id="_1">安装插件<a class="headerlink" href="#_1" title="Permanent link">&para;</a></h2>
  563. <h3 id="1">1. 安装插件<a class="headerlink" href="#1" title="Permanent link">&para;</a></h3>
  564. <p>在插件市场搜索: "<code>Okhttp Profiler</code>"</p>
  565. <p><img src="https://i.loli.net/2021/08/14/pmld3qn49Xozvbx.png" width="100%"/></p>
  566. <h3 id="2">2. 打开窗口<a class="headerlink" href="#2" title="Permanent link">&para;</a></h3>
  567. <p>安装以后在AndroidStudio右下角打开窗口</p>
  568. <p><img src="https://i.loli.net/2021/08/14/p2r7o3tqlUSnCms.png" width="80%"/></p>
  569. <div class="admonition warning">
  570. <p class="admonition-title">不显示日志</p>
  571. <p>请在请求前确保有打开过插件窗口, 如果依然不显示可以反复打开/关闭窗口</p>
  572. <p>每次AS更新可能要该插件作者适配, 发现无效请<a href="https://github.com/itkacher/OkHttpProfiler/issues">反馈给作者更新</a></p>
  573. </div>
  574. <p>使用效果</p>
  575. <p><img src="https://i.loli.net/2021/08/14/Uo9G3wXuv5VFTgn.png" width="100%"/></p>
  576. <table>
  577. <thead>
  578. <tr>
  579. <th>标题</th>
  580. <th>描述</th>
  581. </tr>
  582. </thead>
  583. <tbody>
  584. <tr>
  585. <td>Device</td>
  586. <td>选择调试设备</td>
  587. </tr>
  588. <tr>
  589. <td>Process</td>
  590. <td>选择展示记录的进程</td>
  591. </tr>
  592. <tr>
  593. <td><img src="https://i.loli.net/2021/08/14/QozLn48B12MI37E.png" width="10%"/> 抓取</td>
  594. <td>一般情况不需要使用, 假设没有及时更新请点击图标</td>
  595. </tr>
  596. <tr>
  597. <td><img src="https://i.loli.net/2021/08/14/hy8Kkwmpc5CGxlu.png" width="10%"/> 清空</td>
  598. <td>清空记录</td>
  599. </tr>
  600. </tbody>
  601. </table>
  602. <h2 id="_2">自定义日志<a class="headerlink" href="#_2" title="Permanent link">&para;</a></h2>
  603. <p>继承<code>LogRecordInterceptor</code>复写函数实现自定义</p>
  604. <ol>
  605. <li>复写<code>getRequestLog</code>返回请求参数</li>
  606. <li>复写<code>getResponseLog</code>返回响应参数</li>
  607. </ol>
  608. <p>初始化时添加自己的拦截器</p>
  609. <div class="language-kotlin highlight"><pre><span></span><code><span id="__span-1-1"><a id="__codelineno-1-1" name="__codelineno-1-1" href="#__codelineno-1-1"></a><span class="n">NetConfig</span><span class="p">.</span><span class="na">initialize</span><span class="p">(</span><span class="n">Api</span><span class="p">.</span><span class="na">HOST</span><span class="p">,</span><span class="w"> </span><span class="k">this</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
  610. </span><span id="__span-1-2"><a id="__codelineno-1-2" name="__codelineno-1-2" href="#__codelineno-1-2"></a><span class="w"> </span><span class="n">addInterceptor</span><span class="p">(</span><span class="n">MyLogRecordInterceptor</span><span class="p">(</span><span class="n">BuildConfig</span><span class="p">.</span><span class="na">DEBUG</span><span class="p">))</span>
  611. </span><span id="__span-1-3"><a id="__codelineno-1-3" name="__codelineno-1-3" href="#__codelineno-1-3"></a><span class="p">}</span>
  612. </span></code></pre></div>
  613. <h2 id="_3">日志过滤<a class="headerlink" href="#_3" title="Permanent link">&para;</a></h2>
  614. <p><img src="https://i.loli.net/2021/08/14/EG7yZYqa86ezMTC.png" width="350"/></p>
  615. <p>不想网络日志影响其他日志查看, 可以添加<code>OKPREL_</code>为日志折叠规则
  616. <img src="https://i.loli.net/2021/08/14/KH3wcgk5AFYDeXd.png" width="100%"/></p>
  617. <h2 id="_4">其他网络框架<a class="headerlink" href="#_4" title="Permanent link">&para;</a></h2>
  618. <p><code>LogRecordInterceptor</code>属于OkHttp拦截器, 其他网络请求框架也可以使用</p>
  619. <p>或者直接使用<code>LogRecorder</code>输出日志</p>
  620. <table>
  621. <thead>
  622. <tr>
  623. <th>LogRecorder</th>
  624. <th>描述</th>
  625. </tr>
  626. </thead>
  627. <tbody>
  628. <tr>
  629. <td>generateId</td>
  630. <td>产生一个唯一标识符, 用于判断为同一网络请求</td>
  631. </tr>
  632. <tr>
  633. <td>recordRequest</td>
  634. <td>记录请求信息</td>
  635. </tr>
  636. <tr>
  637. <td>recordResponse</td>
  638. <td>记录响应信息</td>
  639. </tr>
  640. <tr>
  641. <td>recordException</td>
  642. <td>记录请求异常信息</td>
  643. </tr>
  644. </tbody>
  645. </table>
  646. </article>
  647. </div>
  648. <script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
  649. </div>
  650. <button type="button" class="md-top md-icon" data-md-component="top" hidden>
  651. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M13 20h-2V8l-5.5 5.5-1.42-1.42L12 4.16l7.92 7.92-1.42 1.42L13 8z"/></svg>
  652. 回到页面顶部
  653. </button>
  654. </main>
  655. <!-- Footer -->
  656. <footer class="md-footer">
  657. <!-- Link to previous and/or next page -->
  658. <nav class="md-footer__inner md-grid" aria-label="footer.title">
  659. <!-- Link to previous page -->
  660. <a href="fastest.html" class="md-footer__link md-footer__link--prev" rel="prev">
  661. <div class="md-footer__button md-icon">
  662. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
  663. </div>
  664. <div class="md-footer__title">
  665. <div class="md-ellipsis">
  666. <span class="md-footer__direction">
  667. 上一页
  668. </span>
  669. 最快请求结果
  670. </div>
  671. </div>
  672. </a>
  673. <!-- Link to next page -->
  674. <a href="log-notice.html" class="md-footer__link md-footer__link--next" rel="next">
  675. <div class="md-footer__title">
  676. <div class="md-ellipsis">
  677. <span class="md-footer__direction">
  678. 下一页
  679. </span>
  680. 日志通知
  681. </div>
  682. </div>
  683. <div class="md-footer__button md-icon">
  684. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11z"/></svg>
  685. </div>
  686. </a>
  687. </nav>
  688. <!-- Further information -->
  689. <div class="md-footer-meta md-typeset">
  690. <div class="md-footer-meta__inner md-grid">
  691. <!-- Copyright and theme information -->
  692. <div class="md-footer-copyright">
  693. <a href="https://github.com/liangjingkanji" target="_blank" rel="noopener">
  694. <div class="md-footer-copyright__highlight">
  695. Copyright &copy; 2018 - 2023 劉強東
  696. </div>
  697. </a>
  698. </div>
  699. <!-- Social links -->
  700. <div class="md-social">
  701. <a href="https://github.com/liangjingkanji" target="_blank" rel="noopener" title="github.com" class="md-social__link">
  702. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><!--! Font Awesome Free 6.7.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc.--><path d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6m-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3m44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9M244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8M97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1m-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7m32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1m-11.4-14.7c-1.6 1-1.6 3.6 0 5.9s4.3 3.3 5.6 2.3c1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2"/></svg>
  703. </a>
  704. <a href="https://raw.githubusercontent.com/liangjingkanji/liangjingkanji/master/img/group-qrcode.png" target="_blank" rel="noopener" title="raw.githubusercontent.com" class="md-social__link">
  705. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 6.7.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc.--><path d="M433.754 420.445c-11.526 1.393-44.86-52.741-44.86-52.741 0 31.345-16.136 72.247-51.051 101.786 16.842 5.192 54.843 19.167 45.803 34.421-7.316 12.343-125.51 7.881-159.632 4.037-34.122 3.844-152.316 8.306-159.632-4.037-9.045-15.25 28.918-29.214 45.783-34.415-34.92-29.539-51.059-70.445-51.059-101.792 0 0-33.334 54.134-44.859 52.741-5.37-.65-12.424-29.644 9.347-99.704 10.261-33.024 21.995-60.478 40.144-105.779C60.683 98.063 108.982.006 224 0c113.737.006 163.156 96.133 160.264 214.963 18.118 45.223 29.912 72.85 40.144 105.778 21.768 70.06 14.716 99.053 9.346 99.704"/></svg>
  706. </a>
  707. <a href="https://github.com/liangjingkanji/Net/discussions" target="_blank" rel="noopener" title="github.com" class="md-social__link">
  708. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><!--! Font Awesome Free 6.7.1 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2024 Fonticons, Inc.--><path d="M391.17 103.47h-38.63v109.7h38.63ZM285 103h-38.63v109.75H285ZM120.83 0 24.31 91.42v329.16h115.83V512l96.53-91.42h77.25L487.69 256V0Zm328.24 237.75-77.22 73.12h-77.24l-67.6 64v-64h-86.87V36.58h308.93Z"/></svg>
  709. </a>
  710. </div>
  711. </div>
  712. </div>
  713. </footer>
  714. </div>
  715. <div class="md-dialog" data-md-component="dialog">
  716. <div class="md-dialog__inner md-typeset"></div>
  717. </div>
  718. <script id="__config" type="application/json">{"base": ".", "features": ["navigation.top", "navigation.prune", "navigation.footer", "navigation.instant", "search.highlight", "search.suggest", "search.share", "content.code.copy", "content.code.annotate"], "search": "assets/javascripts/workers/search.6ce7567c.min.js", "translations": {"clipboard.copied": "\u5df2\u590d\u5236", "clipboard.copy": "\u590d\u5236", "search.result.more.one": "\u5728\u8be5\u9875\u4e0a\u8fd8\u6709 1 \u4e2a\u7b26\u5408\u6761\u4ef6\u7684\u7ed3\u679c", "search.result.more.other": "\u5728\u8be5\u9875\u4e0a\u8fd8\u6709 # \u4e2a\u7b26\u5408\u6761\u4ef6\u7684\u7ed3\u679c", "search.result.none": "\u6ca1\u6709\u627e\u5230\u7b26\u5408\u6761\u4ef6\u7684\u7ed3\u679c", "search.result.one": "\u627e\u5230 1 \u4e2a\u7b26\u5408\u6761\u4ef6\u7684\u7ed3\u679c", "search.result.other": "# \u4e2a\u7b26\u5408\u6761\u4ef6\u7684\u7ed3\u679c", "search.result.placeholder": "\u952e\u5165\u4ee5\u5f00\u59cb\u641c\u7d22", "search.result.term.missing": "\u7f3a\u5c11", "select.version": "\u9009\u62e9\u5f53\u524d\u7248\u672c"}}</script>
  719. <script src="assets/javascripts/bundle.83f73b43.min.js"></script>
  720. </body>
  721. </html>