package main import ( "fmt" "net/http" "os" "strings" ) var strValues string var strUvalues string var password string func init() { password = os.Getenv("PASSWORD") if password == "" { password = "123456" } } func filterCookieValues(cookieValues string, keepKeys []string) string { newCookieValues := "" pairs := strings.Split(cookieValues, ";") for _, pair := range pairs { parts := strings.Split(pair, "=") key := strings.TrimSpace(parts[0]) value := strings.Join(parts[1:], "=") if contains(keepKeys, key) { newCookieValues += key + "=" + value + "; " } } newCookieValues = newCookieValues[:len(newCookieValues)-2] return newCookieValues } func contains(keys []string, key string) bool { for _, k := range keys { if k == key { return true } } return false } func handleSET(w http.ResponseWriter, req *http.Request) { pwd := req.URL.Query().Get("pwd") if pwd == "" || pwd!= password { w.WriteHeader(http.StatusUnauthorized) w.Write([]byte("Invalid password")) return } keepKeys := []string{"_U", "MUID", "KievRPSSecAuth", "cct", "buid", "ak_bmsc", "bm_sv", "_RwBf", "SRCHHPGUSR", "WLS"} keepKeysU := []string{"_U", "WLS"} cookieValues := req.Header.Get("Cookie-Values") setValue := filterCookieValues(cookieValues, keepKeys) getUValue := filterCookieValues(cookieValues, keepKeysU) if setValue!= "" { strValues = setValue if getUValue!= "" &&!strings.Contains(strUvalues, getUValue) { strUvalues += ";" + getUValue } w.Write([]byte("Set value successfully")) } else { w.WriteHeader(http.StatusBadRequest) w.Write([]byte("No Cookie-Values in header")) } } func handleGET(w http.ResponseWriter, req *http.Request) { pwd := req.URL.Query().Get("pwd") if pwd == "" || pwd!= password { w.WriteHeader(http.StatusUnauthorized) w.Write([]byte("Invalid password")) return } result := `{"result": {"cookies": "` + strValues + `"}}` w.Header().Set("Content-Type", "application/json") w.Write([]byte(fmt.Sprintf("%v", result))) } func handleCLS(w http.ResponseWriter, req *http.Request) { pwd := req.URL.Query().Get("pwd") if pwd == "" || pwd!= password { w.WriteHeader(http.StatusUnauthorized) w.Write([]byte("Invalid password")) return } replacedStr := strings.ReplaceAll(strUvalues, ";", "
") strValues = "" strUvalues = "" w.Write([]byte("Clear value successfully\n" + replacedStr)) } func handleHisU(w http.ResponseWriter, req *http.Request) { pwd := req.URL.Query().Get("pwd") if pwd == "" || pwd!= password { w.WriteHeader(http.StatusUnauthorized) w.Write([]byte("Invalid password")) return } replacedStr := strings.ReplaceAll(strUvalues, ";", "
") w.Write([]byte("Ukey History:\n" + replacedStr)) } func handleRoot(w http.ResponseWriter, req *http.Request) { w.Write([]byte("Please visit /SET, /GET, or /CLS with?pwd=xxxxxx")) } // 新增处理 /q 的函数 func handleQ(w http.ResponseWriter, req *http.Request) { url := req.URL.Query().Get("url") if url == "" { w.WriteHeader(http.StatusBadRequest) w.Write([]byte("URL is required")) return } keepKeys := []string{"_U", "MUID", "KievRPSSecAuth", "cct", "buid", "ak_bmsc", "bm_sv", "_RwBf", "SRCHHPGUSR", "WLS"} client := &http.Client{} req, err := http.NewRequest("GET", url, nil) if err!= nil { w.WriteHeader(http.StatusInternalServerError) w.Write([]byte(err.Error())) return } req.Header.Set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36 Edg/120.0.0.0") req.Header.Set("Accept-Language", "zh-CN,zh;q=0.9") resp, err := client.Do(req) if err!= nil { w.WriteHeader(http.StatusInternalServerError) w.Write([]byte(err.Error())) return } defer resp.Body.Close() setCookieArray := resp.Header["Set-Cookie"] cookies := "" if setCookieArray!= nil { // 只保留键值对,并替换 & 为 _ cookies = setCookieArray[0] pairs := strings.Split(cookies, ";") keyValuePair := pairs[0] keyValuePair = strings.ReplaceAll(keyValuePair, "&", "_") cookies = keyValuePair } setValue := filterCookieValues(cookies, keepKeys) result := `{"result": {"cookies": "` + setValue + `"}}` w.Header().Set("Content-Type", "application/json") w.Write([]byte(fmt.Sprintf("%v", result))) } func main() { port := ":7860" http.HandleFunc("/SET", handleSET) http.HandleFunc("/GET", handleGET) http.HandleFunc("/CLS", handleCLS) http.HandleFunc("/HisU", handleHisU) http.HandleFunc("/", handleRoot) // 新增处理 /q 的路由 http.HandleFunc("/q", handleQ) fmt.Printf("Server is running on port %s\n", port) http.ListenAndServe(port, nil) }