mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
@@ -1,4 +1,3 @@
|
||||
import 'dart:convert';
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:PiliPlus/common/constants.dart';
|
||||
@@ -405,15 +404,25 @@ class MemberHttp {
|
||||
'timezone_offset': '-480',
|
||||
'features': 'itemOpusStyle,listOnlyfans',
|
||||
'platform': 'web',
|
||||
'web_location': '333.999',
|
||||
'web_location': '333.1387',
|
||||
'dm_img_list': '[]',
|
||||
'dm_img_str': dmImgStr,
|
||||
'dm_cover_img_str': dmCoverImgStr,
|
||||
'dm_img_inter': '{"ds":[],"wh":[0,0,0],"of":[0,0,0]}',
|
||||
'x-bili-device-req-json': jsonEncode({"platform": "web", "device": "pc"}),
|
||||
'x-bili-web-req-json': jsonEncode({"spm_id": "333.999"}),
|
||||
'x-bili-device-req-json':
|
||||
'{"platform":"web","device":"pc","spmid":"333.1387"}',
|
||||
});
|
||||
var res = await Request().get(Api.memberDynamic, queryParameters: params);
|
||||
var res = await Request().get(
|
||||
Api.memberDynamic,
|
||||
queryParameters: params,
|
||||
options: Options(
|
||||
headers: {
|
||||
'user-agent': UaType.pc.ua,
|
||||
'origin': 'https://space.bilibili.com',
|
||||
'referer': 'https://space.bilibili.com/$mid/dynamic',
|
||||
},
|
||||
),
|
||||
);
|
||||
if (res.data['code'] == 0) {
|
||||
try {
|
||||
DynamicsDataModel data = DynamicsDataModel.fromJson(res.data['data']);
|
||||
|
||||
@@ -12,6 +12,7 @@ import 'package:PiliPlus/models_new/pgc/pgc_info_model/result.dart';
|
||||
import 'package:PiliPlus/models_new/search/search_rcmd/data.dart';
|
||||
import 'package:PiliPlus/models_new/search/search_trending/data.dart';
|
||||
import 'package:PiliPlus/utils/extension.dart';
|
||||
import 'package:PiliPlus/utils/request_utils.dart';
|
||||
import 'package:PiliPlus/utils/wbi_sign.dart';
|
||||
import 'package:dio/dio.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
@@ -56,6 +57,8 @@ class SearchHttp {
|
||||
int? pubBegin,
|
||||
int? pubEnd,
|
||||
required String qvId,
|
||||
String? gaiaVtoken,
|
||||
required ValueChanged<String> onSuccess,
|
||||
}) async {
|
||||
var params = await WbiSign.makSign({
|
||||
'search_type': searchType.name,
|
||||
@@ -78,15 +81,16 @@ class SearchHttp {
|
||||
'from_spmid': 333.337,
|
||||
'platform': 'pc',
|
||||
'source_tag': 3,
|
||||
'gaia_vtoken': '',
|
||||
'qv_id': qvId,
|
||||
'web_location': 1430654,
|
||||
'gaia_vtoken': ?gaiaVtoken,
|
||||
});
|
||||
var res = await Request().get(
|
||||
Api.searchByType,
|
||||
queryParameters: params,
|
||||
options: Options(
|
||||
headers: {
|
||||
if (gaiaVtoken != null) 'cookie': 'x-bili-gaia-vtoken=$gaiaVtoken',
|
||||
'user-agent': UaType.pc.ua,
|
||||
'origin': 'https://search.bilibili.com',
|
||||
'referer':
|
||||
@@ -98,7 +102,9 @@ class SearchHttp {
|
||||
if (resData is Map) {
|
||||
if (resData['code'] == 0) {
|
||||
final Map<String, dynamic> dataData = resData['data'];
|
||||
if (dataData.containsKey('v_voucher')) {
|
||||
final vVoucher = dataData['v_voucher'];
|
||||
if (vVoucher != null) {
|
||||
RequestUtils.validate(vVoucher, onSuccess);
|
||||
return const Error('触发风控');
|
||||
}
|
||||
dynamic data;
|
||||
|
||||
@@ -71,12 +71,22 @@ class SearchPanelController<R extends SearchNumData<T>, T>
|
||||
|
||||
@override
|
||||
List<T>? getDataList(R response) {
|
||||
searchResultController?.count[searchType.index] = response.numResults ?? 0;
|
||||
return response.list;
|
||||
}
|
||||
|
||||
@override
|
||||
bool customHandleResponse(bool isRefresh, Success<R> response) {
|
||||
if (isRefresh) {
|
||||
searchResultController?.count[searchType.index] =
|
||||
response.response.numResults ?? 0;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
final qvId = Utils.generateRandomString(32);
|
||||
|
||||
String? gaiaVtoken;
|
||||
|
||||
@override
|
||||
Future<LoadingState<R>> customGetData() => SearchHttp.searchByType<R>(
|
||||
searchType: searchType,
|
||||
@@ -91,6 +101,11 @@ class SearchPanelController<R extends SearchNumData<T>, T>
|
||||
pubBegin: pubBegin,
|
||||
pubEnd: pubEnd,
|
||||
qvId: qvId,
|
||||
gaiaVtoken: gaiaVtoken,
|
||||
onSuccess: (String gaiaVtoken) {
|
||||
this.gaiaVtoken = gaiaVtoken;
|
||||
queryData(page == 1);
|
||||
},
|
||||
);
|
||||
|
||||
@override
|
||||
|
||||
@@ -22,6 +22,7 @@ import 'package:PiliPlus/pages/common/multi_select/multi_select_controller.dart'
|
||||
import 'package:PiliPlus/pages/dynamics_tab/controller.dart';
|
||||
import 'package:PiliPlus/pages/group_panel/view.dart';
|
||||
import 'package:PiliPlus/pages/later/controller.dart';
|
||||
import 'package:PiliPlus/pages/login/geetest/geetest_webview_dialog.dart';
|
||||
import 'package:PiliPlus/utils/accounts.dart';
|
||||
import 'package:PiliPlus/utils/context_ext.dart';
|
||||
import 'package:PiliPlus/utils/extension.dart';
|
||||
@@ -484,26 +485,32 @@ abstract class RequestUtils {
|
||||
String vVoucher,
|
||||
ValueChanged<String> onSuccess,
|
||||
) async {
|
||||
if (Platform.isLinux) {
|
||||
return;
|
||||
}
|
||||
|
||||
final res = await ValidateHttp.gaiaVgateRegister(vVoucher);
|
||||
if (!res['status']) {
|
||||
SmartDialog.showToast("${res['msg']}");
|
||||
return;
|
||||
}
|
||||
|
||||
if (res['data'] == null) {
|
||||
final resData = res['data'];
|
||||
if (resData == null) {
|
||||
SmartDialog.showToast("null data");
|
||||
return;
|
||||
}
|
||||
|
||||
CaptchaDataModel captchaData = CaptchaDataModel();
|
||||
|
||||
String? geeGt = res['data']?['geetest']?['gt'];
|
||||
String? geeChallenge = res['data']?['geetest']?['challenge'];
|
||||
captchaData.token = res['data']?['token'];
|
||||
final geetest = resData?['geetest'];
|
||||
String? gt = geetest?['gt'];
|
||||
String? challenge = geetest?['challenge'];
|
||||
captchaData.token = resData?['token'];
|
||||
|
||||
bool isGeeArgumentValid() {
|
||||
return geeGt?.isNotEmpty == true &&
|
||||
geeChallenge?.isNotEmpty == true &&
|
||||
return gt?.isNotEmpty == true &&
|
||||
challenge?.isNotEmpty == true &&
|
||||
captchaData.token?.isNotEmpty == true;
|
||||
}
|
||||
|
||||
@@ -512,9 +519,47 @@ abstract class RequestUtils {
|
||||
return;
|
||||
}
|
||||
|
||||
Future<void> gaiaVgateValidate() async {
|
||||
final res = await ValidateHttp.gaiaVgateValidate(
|
||||
challenge: captchaData.geetest?.challenge,
|
||||
seccode: captchaData.seccode,
|
||||
token: captchaData.token,
|
||||
validate: captchaData.validate,
|
||||
);
|
||||
if (res['status']) {
|
||||
if (res['data']?['is_valid'] == 1) {
|
||||
final griskId = res['data']?['grisk_id'];
|
||||
if (griskId != null) {
|
||||
onSuccess(griskId);
|
||||
}
|
||||
} else {
|
||||
SmartDialog.showToast('invalid');
|
||||
}
|
||||
} else {
|
||||
SmartDialog.showToast(res['msg']);
|
||||
}
|
||||
}
|
||||
|
||||
if (Utils.isDesktop) {
|
||||
final json = await Get.dialog<Map<String, dynamic>>(
|
||||
GeetestWebviewDialog(gt!, challenge!),
|
||||
);
|
||||
if (json != null) {
|
||||
captchaData
|
||||
..validate = json['geetest_validate']
|
||||
..seccode = json['geetest_seccode']
|
||||
..geetest = GeetestData(
|
||||
challenge: json['geetest_challenge'],
|
||||
gt: gt,
|
||||
);
|
||||
gaiaVgateValidate();
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
var registerData = Gt3RegisterData(
|
||||
challenge: geeChallenge,
|
||||
gt: geeGt,
|
||||
challenge: challenge,
|
||||
gt: gt,
|
||||
success: true,
|
||||
);
|
||||
|
||||
@@ -529,28 +574,15 @@ abstract class RequestUtils {
|
||||
if (code == "1") {
|
||||
// 发送 message["result"] 中的数据向 B 端的业务服务接口进行查询
|
||||
SmartDialog.showToast('验证成功');
|
||||
final result = message['result'];
|
||||
captchaData
|
||||
..validate = message['result']?['geetest_validate']
|
||||
..seccode = message['result']?['geetest_seccode'];
|
||||
String? challenge = message['result']?['geetest_challenge'];
|
||||
final res = await ValidateHttp.gaiaVgateValidate(
|
||||
challenge: challenge,
|
||||
seccode: captchaData.seccode,
|
||||
token: captchaData.token,
|
||||
validate: captchaData.validate,
|
||||
);
|
||||
if (res['status']) {
|
||||
if (res['data']?['is_valid'] == 1) {
|
||||
final griskId = res['data']?['grisk_id'];
|
||||
if (griskId != null) {
|
||||
onSuccess(griskId);
|
||||
}
|
||||
} else {
|
||||
SmartDialog.showToast('invalid');
|
||||
}
|
||||
} else {
|
||||
SmartDialog.showToast(res['msg']);
|
||||
}
|
||||
..validate = result?['geetest_validate']
|
||||
..seccode = result?['geetest_seccode']
|
||||
..geetest = GeetestData(
|
||||
challenge: result?['geetest_challenge'],
|
||||
gt: gt!,
|
||||
);
|
||||
gaiaVgateValidate();
|
||||
} else {
|
||||
// 终端用户完成验证失败,自动重试 If the verification fails, it will be automatically retried.
|
||||
if (kDebugMode) debugPrint("Captcha result code : $code");
|
||||
|
||||
Reference in New Issue
Block a user