mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
fix: failed to load member info
This commit is contained in:
@@ -42,12 +42,14 @@ class MemberHttp {
|
|||||||
static Future memberInfo({
|
static Future memberInfo({
|
||||||
int? mid,
|
int? mid,
|
||||||
String token = '',
|
String token = '',
|
||||||
|
dynamic wwebid,
|
||||||
}) async {
|
}) async {
|
||||||
Map params = await WbiSign().makSign({
|
Map params = await WbiSign().makSign({
|
||||||
'mid': mid,
|
'mid': mid,
|
||||||
'token': token,
|
'token': token,
|
||||||
'platform': 'web',
|
'platform': 'web',
|
||||||
'web_location': 1550101,
|
'web_location': 1550101,
|
||||||
|
'w_webid': wwebid,
|
||||||
});
|
});
|
||||||
var res = await Request().get(
|
var res = await Request().get(
|
||||||
Api.memberInfo,
|
Api.memberInfo,
|
||||||
|
|||||||
@@ -1,3 +1,7 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:PiliPalaX/http/constants.dart';
|
||||||
|
import 'package:PiliPalaX/http/init.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:get/get.dart';
|
import 'package:get/get.dart';
|
||||||
@@ -10,6 +14,8 @@ import 'package:PiliPalaX/models/member/coin.dart';
|
|||||||
import 'package:PiliPalaX/models/member/info.dart';
|
import 'package:PiliPalaX/models/member/info.dart';
|
||||||
import 'package:PiliPalaX/utils/storage.dart';
|
import 'package:PiliPalaX/utils/storage.dart';
|
||||||
import 'package:share_plus/share_plus.dart';
|
import 'package:share_plus/share_plus.dart';
|
||||||
|
import 'package:html/dom.dart' as dom;
|
||||||
|
import 'package:html/parser.dart' as html_parser;
|
||||||
|
|
||||||
import '../video/detail/introduction/widgets/group_panel.dart';
|
import '../video/detail/introduction/widgets/group_panel.dart';
|
||||||
|
|
||||||
@@ -29,6 +35,7 @@ class MemberController extends GetxController {
|
|||||||
RxInt attribute = (-1).obs;
|
RxInt attribute = (-1).obs;
|
||||||
RxString attributeText = '关注'.obs;
|
RxString attributeText = '关注'.obs;
|
||||||
RxList<MemberCoinsDataModel> recentCoinsList = <MemberCoinsDataModel>[].obs;
|
RxList<MemberCoinsDataModel> recentCoinsList = <MemberCoinsDataModel>[].obs;
|
||||||
|
String? wwebid;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void onInit() async {
|
void onInit() async {
|
||||||
@@ -45,9 +52,10 @@ class MemberController extends GetxController {
|
|||||||
|
|
||||||
// 获取用户信息
|
// 获取用户信息
|
||||||
Future<Map<String, dynamic>> getInfo() async {
|
Future<Map<String, dynamic>> getInfo() async {
|
||||||
|
await getWwebid();
|
||||||
await getMemberStat();
|
await getMemberStat();
|
||||||
await getMemberView();
|
await getMemberView();
|
||||||
var res = await MemberHttp.memberInfo(mid: mid);
|
var res = await MemberHttp.memberInfo(mid: mid, wwebid: wwebid);
|
||||||
if (res['status']) {
|
if (res['status']) {
|
||||||
memberInfo.value = res['data'];
|
memberInfo.value = res['data'];
|
||||||
face.value = res['data'].face;
|
face.value = res['data'].face;
|
||||||
@@ -55,6 +63,20 @@ class MemberController extends GetxController {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future getWwebid() async {
|
||||||
|
try {
|
||||||
|
dynamic response =
|
||||||
|
await Request().get('${HttpString.spaceBaseUrl}/$mid/dynamic');
|
||||||
|
dom.Document document = html_parser.parse(response.data);
|
||||||
|
dom.Element? scriptElement =
|
||||||
|
document.querySelector('script#__RENDER_DATA__');
|
||||||
|
wwebid = jsonDecode(
|
||||||
|
Uri.decodeComponent(scriptElement?.text ?? ''))['access_id'];
|
||||||
|
} catch (e) {
|
||||||
|
print('failed to get wwebid: $e');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 获取用户状态
|
// 获取用户状态
|
||||||
Future<Map<String, dynamic>> getMemberStat() async {
|
Future<Map<String, dynamic>> getMemberStat() async {
|
||||||
var res = await MemberHttp.memberStat(mid: mid);
|
var res = await MemberHttp.memberStat(mid: mid);
|
||||||
|
|||||||
Reference in New Issue
Block a user