From 9dfe0cd3cfc3320f38aa96bc85edba9f2d9c9ff0 Mon Sep 17 00:00:00 2001
From: Mark Chan <45706356+WindowsMEMZ@users.noreply.github.com>
Date: Fri, 15 Dec 2023 23:01:59 +0800
Subject: [PATCH] Fix Search Issue (#28)
* Update SearchView.swift
* Fast merge main to fix/search (#29)
* Update DarockBili_Watch_App_UI_Tests.swift
* Update ui-test.yml
* Update ui-test.yml
* Update DarockBili_Watch_App_UI_Tests.swift
* Update status-check.yml
* Update DarockBili_Watch_App_UI_Tests.swift
* Update SearchView.swift
* Update DarockBiliApp.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update DarockBili_Watch_App_UI_Tests.swift
* Update SearchView.swift
* Update SearchView.swift
* Update SearchView.swift
---
.../DarockBili_Watch_App_UI_Tests.swift | 13 +++
DarockBili Watch App/DarockBiliApp.swift | 2 +-
DarockBili Watch App/InMain/SearchView.swift | 81 ++++++++++++-------
3 files changed, 65 insertions(+), 31 deletions(-)
diff --git a/DarockBili Watch App UI Tests/DarockBili_Watch_App_UI_Tests.swift b/DarockBili Watch App UI Tests/DarockBili_Watch_App_UI_Tests.swift
index 92aabff9a..0ee6b5ecc 100644
--- a/DarockBili Watch App UI Tests/DarockBili_Watch_App_UI_Tests.swift
+++ b/DarockBili Watch App UI Tests/DarockBili_Watch_App_UI_Tests.swift
@@ -51,6 +51,19 @@ final class DarockBili_Watch_App_UI_Tests: XCTestCase {
app.navigationBars.buttons.element(boundBy: 0).tap()
sleep(1)
// Backed to suggestions view
+ app.navigationBars.buttons["SearchButton"].firstMatch.tap()
+ sleep(1)
+ if app.buttons["SearchDebugButton"].exists {
+ app.buttons["SearchDebugButton"].tap()
+ sleep(5)
+ takeScreenshot(of: app, named: "DebugSearch")
+ print(app.debugDescription)
+ app.buttons["关闭"].firstMatch.tap()
+ sleep(1)
+ }
+ app.buttons["关闭"].firstMatch.tap()
+ sleep(1)
+ // Backed to suggestions view
app.otherElements["MainTabView"].swipeLeft()
sleep(1)
takeScreenshot(of: app, named: "PersonalCenter")
diff --git a/DarockBili Watch App/DarockBiliApp.swift b/DarockBili Watch App/DarockBiliApp.swift
index af5fdc1ef..0a39971e4 100644
--- a/DarockBili Watch App/DarockBiliApp.swift
+++ b/DarockBili Watch App/DarockBiliApp.swift
@@ -25,7 +25,7 @@ import SDWebImageSVGCoder
import SDWebImageWebPCoder
//!!!: Debug Setting, Set false Before Release
-var debug = false
+var debug = true
var pShowTipText = ""
var pShowTipSymbol = ""
diff --git a/DarockBili Watch App/InMain/SearchView.swift b/DarockBili Watch App/InMain/SearchView.swift
index b4305e70d..9ac87a1e0 100644
--- a/DarockBili Watch App/InMain/SearchView.swift
+++ b/DarockBili Watch App/InMain/SearchView.swift
@@ -39,6 +39,15 @@ struct SearchMainView: View {
searchText = ""
}
.accessibilityIdentifier("SearchInput")
+ if debug {
+ Button(action: {
+ searchText = "Darock"
+ isSearchPresented = true
+ }, label: {
+ Text("Debug Search")
+ })
+ .accessibilityIdentifier("SearchDebugButton")
+ }
}
if searchHistory.count != 0 {
Section(header: Text("历史记录")) {
@@ -68,6 +77,7 @@ struct SearchView: View {
@State var users = [[String: Any]]()
@State var isUserDetailPresented = [Bool]()
@State var isLoaded = false
+ @State var debugResponse = ""
var body: some View {
ScrollView {
VStack {
@@ -112,42 +122,53 @@ struct SearchView: View {
ForEach(0...videos.count - 1, id: \.self) { i in
VideoCard(videos[i])
}
+ } else if debugResponse != "" {
+ Text("似乎在搜索时遇到了一些问题,以下是详细信息")
+ Text(debugResponse)
}
}
}
.onAppear {
if !isLoaded {
- AF.request("bilibili.com").response { response in
- let headers: HTTPHeaders = [
- "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
- "accept-encoding": "gzip, deflate, br",
- "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
- "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.30 Safari/537.36 Edg/84.0.522.11",
- "sec-fetch-dest": "document",
- "sec-fetch-mode": "navigate",
- "sec-fetch-site": "none",
- "sec-fetch-user": "?1",
- "upgrade-insecure-requests": "1",
- "referer": "https://www.bilibili.com/",
- "cookie": "SESSDATA=\(sessdata); bili_jct=\(biliJct); DedeUserID=\(dedeUserID); DedeUserID__ckMd5=\(dedeUserID__ckMd5)"
- ]
- DarockKit.Network.shared.requestJSON("https://api.bilibili.com/x/web-interface/search/all/v2?keyword=\(keyword)", headers: headers) { respJson, isSuccess in
- if isSuccess {
- debugPrint(respJson)
- let userDatas = respJson["data"]["result"][8]["data"]
- for user in userDatas {
- isUserDetailPresented.append(false)
- users.append(["Name": user.1["uname"].string ?? "[加载失败]", "Pic": "https:" + (user.1["upic"].string ?? "E"), "ID": String(user.1["mid"].int ?? -1), "Fans": String(user.1["fans"].int ?? -1), "VideoCount": String(user.1["videos"].int ?? -1), "Videos": { () -> [[String: String]] in
- var tVideos = [[String: String]]()
- for video in user.1["res"] {
- tVideos.append(["Pic": "https:" + (video.1["pic"].string ?? "E"), "Title": video.1["title"].string ?? "[加载失败]", "BV": video.1["bvid"].string ?? "E", "UP": user.1["uname"].string ?? "[加载失败]", "View": video.1["play"].string ?? "-1", "Danmaku": String(video.1["coin"].int ?? -1)])
+ debugResponse = ""
+ DarockKit.Network.shared.requestJSON("https://api.bilibili.com/x/frontend/finger/spi") { respJson, isSuccess in
+ if isSuccess {
+ let headers: HTTPHeaders = [
+ "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
+ "accept-encoding": "gzip, deflate, br",
+ "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
+ "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.30 Safari/537.36 Edg/84.0.522.11",
+ "sec-fetch-dest": "document",
+ "sec-fetch-mode": "navigate",
+ "sec-fetch-site": "none",
+ "sec-fetch-user": "?1",
+ "upgrade-insecure-requests": "1",
+ "referer": "https://www.bilibili.com/",
+ "cookie": "SESSDATA=\(sessdata); bili_jct=\(biliJct); DedeUserID=\(dedeUserID); DedeUserID__ckMd5=\(dedeUserID__ckMd5); buvid3=\(respJson["data"]["b_3"].string ?? ""); buvid4=\(respJson["data"]["b_4"].string ?? "")"
+ ]
+ biliWbiSign(paramEncoded: "keyword=\(keyword)".base64Encoded()) { signed in
+ if let signed {
+ DarockKit.Network.shared.requestJSON("https://api.bilibili.com/x/web-interface/wbi/search/all/v2?\(signed)", headers: headers) { respJson, isSuccess in
+ if isSuccess {
+ debugPrint(respJson)
+ let userDatas = respJson["data"]["result"][8]["data"]
+ for user in userDatas {
+ isUserDetailPresented.append(false)
+ users.append(["Name": user.1["uname"].string ?? "[加载失败]", "Pic": "https:" + (user.1["upic"].string ?? "E"), "ID": String(user.1["mid"].int ?? -1), "Fans": String(user.1["fans"].int ?? -1), "VideoCount": String(user.1["videos"].int ?? -1), "Videos": { () -> [[String: String]] in
+ var tVideos = [[String: String]]()
+ for video in user.1["res"] {
+ tVideos.append(["Pic": "https:" + (video.1["pic"].string ?? "E"), "Title": video.1["title"].string ?? "[加载失败]", "BV": video.1["bvid"].string ?? "E", "UP": user.1["uname"].string ?? "[加载失败]", "View": video.1["play"].string ?? "-1", "Danmaku": String(video.1["coin"].int ?? -1)])
+ }
+ return tVideos
+ }()])
+ }
+ let videoDatas = respJson["data"]["result"][11]["data"]
+ for video in videoDatas {
+ videos.append(["Pic": "https:" + video.1["pic"].string!, "Title": video.1["title"].string!.replacingOccurrences(of: "", with: "").replacingOccurrences(of: "", with: ""), "View": String(video.1["play"].int!), "Danmaku": String(video.1["danmaku"].int!), "UP": video.1["author"].string!, "BV": video.1["bvid"].string!])
+ }
+ debugResponse = respJson.debugDescription
}
- return tVideos
- }()])
- }
- let videoDatas = respJson["data"]["result"][11]["data"]
- for video in videoDatas {
- videos.append(["Pic": "https:" + video.1["pic"].string!, "Title": video.1["title"].string!.replacingOccurrences(of: "", with: "").replacingOccurrences(of: "", with: ""), "View": String(video.1["play"].int!), "Danmaku": String(video.1["danmaku"].int!), "UP": video.1["author"].string!, "BV": video.1["bvid"].string!])
+ }
}
}
}