fix: decompress

This commit is contained in:
My-Responsitories
2025-10-14 21:20:31 +08:00
parent c3fa976b26
commit 25483d71e9
2 changed files with 25 additions and 20 deletions

View File

@@ -102,7 +102,7 @@ class Request {
headers: { headers: {
'user-agent': 'Dart/3.6 (dart:io)', // Http2Adapter不会自动添加标头 'user-agent': 'Dart/3.6 (dart:io)', // Http2Adapter不会自动添加标头
}, },
responseDecoder: responseDecoder, // Http2Adapter没有自动解压 responseDecoder: _responseDecoder, // Http2Adapter没有自动解压
persistentConnection: true, persistentConnection: true,
); );
@@ -269,24 +269,21 @@ class Request {
} }
} }
static String responseDecoder( static List<int> responseBytesDecoder(
List<int> responseBytes,
Map<String, List<String>> headers,
) => switch (headers['content-encoding']?.firstOrNull) {
'gzip' => _gzipDecoder.decodeBytes(responseBytes),
'br' => _brotilDecoder.convert(responseBytes),
_ => responseBytes,
};
static String _responseDecoder(
List<int> responseBytes, List<int> responseBytes,
RequestOptions options, RequestOptions options,
ResponseBody responseBody, ResponseBody responseBody,
) { ) => utf8.decode(
switch (responseBody.headers['content-encoding']?.firstOrNull) { responseBytesDecoder(responseBytes, responseBody.headers),
case 'gzip': allowMalformed: true,
return utf8.decode( );
_gzipDecoder.decodeBytes(responseBytes),
allowMalformed: true,
);
case 'br':
return utf8.decode(
_brotilDecoder.convert(responseBytes),
allowMalformed: true,
);
default:
return utf8.decode(responseBytes, allowMalformed: true);
}
}
} }

View File

@@ -1,8 +1,8 @@
import 'dart:async'; import 'dart:async';
import 'dart:io'; import 'dart:io';
import 'dart:math'; import 'dart:math';
import 'dart:typed_data';
import 'package:PiliPlus/common/constants.dart';
import 'package:PiliPlus/common/widgets/button/icon_button.dart'; import 'package:PiliPlus/common/widgets/button/icon_button.dart';
import 'package:PiliPlus/common/widgets/custom_icon.dart'; import 'package:PiliPlus/common/widgets/custom_icon.dart';
import 'package:PiliPlus/common/widgets/custom_sliver_persistent_header_delegate.dart'; import 'package:PiliPlus/common/widgets/custom_sliver_persistent_header_delegate.dart';
@@ -43,6 +43,7 @@ import 'package:canvas_danmaku/canvas_danmaku.dart';
import 'package:dio/dio.dart'; import 'package:dio/dio.dart';
import 'package:file_picker/file_picker.dart'; import 'package:file_picker/file_picker.dart';
import 'package:floating/floating.dart'; import 'package:floating/floating.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart';
@@ -993,11 +994,17 @@ class HeaderControlState extends State<HeaderControl> {
item.subtitleUrl!.http2https, item.subtitleUrl!.http2https,
options: Options( options: Options(
responseType: ResponseType.bytes, responseType: ResponseType.bytes,
headers: Constants.baseHeaders,
extra: {'account': const NoAccount()}, extra: {'account': const NoAccount()},
), ),
); );
if (res.statusCode == 200) { if (res.statusCode == 200) {
final bytes = res.data!; final bytes = Uint8List.fromList(
Request.responseBytesDecoder(
res.data!,
res.headers.map,
),
);
final name = final name =
'${introController.videoDetail.value.title}-${videoDetailCtr.bvid}-${videoDetailCtr.cid.value}-${item.lanDoc}.json'; '${introController.videoDetail.value.title}-${videoDetailCtr.bvid}-${videoDetailCtr.cid.value}-${item.lanDoc}.json';
final path = await FilePicker.platform.saveFile( final path = await FilePicker.platform.saveFile(
@@ -1016,6 +1023,7 @@ class HeaderControlState extends State<HeaderControl> {
SmartDialog.showToast("已保存"); SmartDialog.showToast("已保存");
} }
} catch (e) { } catch (e) {
if (kDebugMode) rethrow;
SmartDialog.showToast(e.toString()); SmartDialog.showToast(e.toString());
} }
}, },