dio_client.dart 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. import 'package:dio/dio.dart';
  2. import 'package:pretty_dio_logger/pretty_dio_logger.dart';
  3. import 'package:sino_med_cloud/core/constants/api_constants.dart';
  4. import 'package:sino_med_cloud/core/network/interceptors/auth_interceptor.dart';
  5. import 'package:sino_med_cloud/core/network/interceptors/error_interceptor.dart';
  6. /// Dio 客户端 - 统一网络请求管理
  7. class DioClient {
  8. static final Dio _dio = Dio(
  9. BaseOptions(
  10. baseUrl: ApiConstants.baseUrl,
  11. connectTimeout: Duration(seconds: ApiConstants.connectTimeout),
  12. receiveTimeout: Duration(seconds: ApiConstants.receiveTimeout),
  13. sendTimeout: Duration(seconds: ApiConstants.sendTimeout),
  14. headers: {
  15. ApiConstants.contentType: ApiConstants.applicationJson,
  16. },
  17. ),
  18. );
  19. static Dio get dio {
  20. // 确保拦截器只添加一次
  21. if (_dio.interceptors.isEmpty) {
  22. _dio.interceptors.addAll([
  23. AuthInterceptor(), // 认证拦截器(添加 Token)
  24. ErrorInterceptor(), // 错误拦截器(统一错误处理)
  25. PrettyDioLogger( // 日志拦截器(美化输出)
  26. requestHeader: true,
  27. requestBody: true,
  28. responseBody: true,
  29. responseHeader: false,
  30. error: true,
  31. compact: true,
  32. ),
  33. // 如果需要自定义日志,可以使用 LogInterceptor 替代 PrettyDioLogger
  34. // LogInterceptor(),
  35. ]);
  36. }
  37. return _dio;
  38. }
  39. /// 重置 Dio 实例(用于重新配置)
  40. static void reset() {
  41. _dio.interceptors.clear();
  42. }
  43. // ==================== GET 请求 ====================
  44. /// GET 请求
  45. ///
  46. /// [path] 请求路径(相对于 baseUrl)
  47. /// [queryParameters] 查询参数
  48. /// [options] 请求选项
  49. ///
  50. /// 返回 [Response] 对象
  51. static Future<Response<T>> get<T>(
  52. String path, {
  53. Map<String, dynamic>? queryParameters,
  54. Options? options,
  55. CancelToken? cancelToken,
  56. ProgressCallback? onReceiveProgress,
  57. }) async {
  58. try {
  59. final response = await dio.get<T>(
  60. path,
  61. queryParameters: queryParameters,
  62. options: options,
  63. cancelToken: cancelToken,
  64. onReceiveProgress: onReceiveProgress,
  65. );
  66. return response;
  67. } on DioException catch (e) {
  68. // 错误已由 ErrorInterceptor 处理,直接抛出
  69. rethrow;
  70. }
  71. }
  72. // ==================== POST 请求 ====================
  73. /// POST 请求
  74. ///
  75. /// [path] 请求路径(相对于 baseUrl)
  76. /// [data] 请求体数据
  77. /// [queryParameters] 查询参数
  78. /// [options] 请求选项
  79. ///
  80. /// 返回 [Response] 对象
  81. static Future<Response<T>> post<T>(
  82. String path, {
  83. dynamic data,
  84. Map<String, dynamic>? queryParameters,
  85. Options? options,
  86. CancelToken? cancelToken,
  87. ProgressCallback? onSendProgress,
  88. ProgressCallback? onReceiveProgress,
  89. }) async {
  90. try {
  91. final response = await dio.post<T>(
  92. path,
  93. data: data,
  94. queryParameters: queryParameters,
  95. options: options,
  96. cancelToken: cancelToken,
  97. onSendProgress: onSendProgress,
  98. onReceiveProgress: onReceiveProgress,
  99. );
  100. return response;
  101. } on DioException catch (e) {
  102. // 错误已由 ErrorInterceptor 处理,直接抛出
  103. rethrow;
  104. }
  105. }
  106. // ==================== DELETE 请求 ====================
  107. /// DELETE 请求
  108. ///
  109. /// [path] 请求路径(相对于 baseUrl)
  110. /// [data] 请求体数据(可选)
  111. /// [queryParameters] 查询参数
  112. /// [options] 请求选项
  113. ///
  114. /// 返回 [Response] 对象
  115. static Future<Response<T>> delete<T>(
  116. String path, {
  117. dynamic data,
  118. Map<String, dynamic>? queryParameters,
  119. Options? options,
  120. CancelToken? cancelToken,
  121. }) async {
  122. try {
  123. final response = await dio.delete<T>(
  124. path,
  125. data: data,
  126. queryParameters: queryParameters,
  127. options: options,
  128. cancelToken: cancelToken,
  129. );
  130. return response;
  131. } on DioException catch (e) {
  132. // 错误已由 ErrorInterceptor 处理,直接抛出
  133. rethrow;
  134. }
  135. }
  136. // ==================== PUT 请求====================
  137. /// PUT 请求
  138. ///
  139. /// [path] 请求路径(相对于 baseUrl)
  140. /// [data] 请求体数据
  141. /// [queryParameters] 查询参数
  142. /// [options] 请求选项
  143. ///
  144. /// 返回 [Response] 对象
  145. static Future<Response<T>> put<T>(
  146. String path, {
  147. dynamic data,
  148. Map<String, dynamic>? queryParameters,
  149. Options? options,
  150. CancelToken? cancelToken,
  151. ProgressCallback? onSendProgress,
  152. ProgressCallback? onReceiveProgress,
  153. }) async {
  154. try {
  155. final response = await dio.put<T>(
  156. path,
  157. data: data,
  158. queryParameters: queryParameters,
  159. options: options,
  160. cancelToken: cancelToken,
  161. onSendProgress: onSendProgress,
  162. onReceiveProgress: onReceiveProgress,
  163. );
  164. return response;
  165. } on DioException catch (e) {
  166. // 错误已由 ErrorInterceptor 处理,直接抛出
  167. rethrow;
  168. }
  169. }
  170. // ==================== PATCH 请求 ====================
  171. /// PATCH 请求
  172. ///
  173. /// [path] 请求路径(相对于 baseUrl)
  174. /// [data] 请求体数据
  175. /// [queryParameters] 查询参数
  176. /// [options] 请求选项
  177. ///
  178. /// 返回 [Response] 对象
  179. static Future<Response<T>> patch<T>(
  180. String path, {
  181. dynamic data,
  182. Map<String, dynamic>? queryParameters,
  183. Options? options,
  184. CancelToken? cancelToken,
  185. ProgressCallback? onSendProgress,
  186. ProgressCallback? onReceiveProgress,
  187. }) async {
  188. try {
  189. final response = await dio.patch<T>(
  190. path,
  191. data: data,
  192. queryParameters: queryParameters,
  193. options: options,
  194. cancelToken: cancelToken,
  195. onSendProgress: onSendProgress,
  196. onReceiveProgress: onReceiveProgress,
  197. );
  198. return response;
  199. } on DioException catch (e) {
  200. // 错误已由 ErrorInterceptor 处理,直接抛出
  201. rethrow;
  202. }
  203. }
  204. }