mirror of
https://github.com/bggRGjQaUbCoE/PiliPlus.git
synced 2026-06-01 00:28:18 +08:00
fix: decompress
This commit is contained in:
@@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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());
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
Reference in New Issue
Block a user