合并查询

This commit is contained in:
2023-08-13 05:48:21 +08:00
parent 0575d14494
commit 1b8321349e
10 changed files with 106 additions and 96 deletions

89
main.go
View File

@@ -12,6 +12,84 @@ import (
"github.com/gorilla/mux"
)
//// 獲取查詢參數(int64 類型)
//func ParamInt(value string, defaultValue int64) int64 {
// if value == "" {
// return defaultValue
// }
// if v, err := strconv.ParseInt(value, 10, 64); err == nil {
// return v
// }
// return defaultValue
//}
//
//func getlist(w http.ResponseWriter, r *http.Request) {
// listview := struct {
// Name string `json:"name"`
// Page int64 `json:"page"`
// PageSize int64 `json:"pageSize"`
// Total int64 `json:"total"`
// Next bool `json:"next"`
// List interface{} `json:"list"`
// }{
// Name: mux.Vars(r)["name"],
// Page: ParamInt(r.URL.Query().Get("page"), 1),
// PageSize: ParamInt(r.URL.Query().Get("pageSize"), 10),
// Total: 0,
// Next: false,
// List: make([]interface{}, 0),
// }
//
// // 选择对应的模型
// switch listview.Name {
// case "sessions":
// listview.List = []models.Session{}
// case "users":
// listview.List = []models.User{}
// case "models":
// listview.List = []models.Model{}
// case "images":
// listview.List = []models.Image{}
// case "tags":
// listview.List = []models.Tag{}
// case "servers":
// listview.List = []models.Server{}
// case "datasets":
// listview.List = []models.Dataset{}
// default:
// fmt.Fprintf(w, "404")
// return
// }
//
// // 从数据库中获取数据
// db := configs.ORMDB()
// //if task := r.URL.Query().Get("task"); task != "" {
// // db = db.Where("task = ?", task)
// //}
// //if status := r.URL.Query().Get("status"); status != "" {
// // db = db.Where("status = ?", status)
// //}
// //if user_id := r.URL.Query().Get("user_id"); user_id != "" {
// // db = db.Where("user_id = ?", user_id)
// //}
// //if model_id := r.URL.Query().Get("model_id"); model_id != "" {
// // db = db.Where("model_id = ?", model_id)
// //}
// //// 获取指定用户喜欢的对象(图像)
// //if like := r.URL.Query().Get("like"); like != "" {
// // list, _ := models.LikeImage.GetA(like)
// // db = db.Where("id in (?)", list)
// //}
// // 分页数据
// db = db.Offset(int((listview.Page - 1) * listview.PageSize)).Limit(int(listview.PageSize))
// db.Find(&listview.List).Count(&listview.Total)
//
// // 轉換爲JSON並返回
// data, _ := json.MarshalIndent(listview, "", " ")
// w.Header().Set("Content-Type", "application/json; charset=utf-8")
// w.Write(data)
//}
func main() {
runtime.GOMAXPROCS(runtime.NumCPU())
log.SetFlags(log.Lshortfile | log.LstdFlags)
@@ -36,6 +114,7 @@ func main() {
// 設定路由
r.HandleFunc("/api", routers.GetDocs).Methods("GET")
//r.HandleFunc("/api/{name}", getlist).Methods("GET")
r.HandleFunc("/api/sessions", routers.SessionsGet).Methods("GET")
r.HandleFunc("/api/sessions", routers.SessionsPost).Methods("POST")
@@ -95,19 +174,9 @@ func main() {
r.HandleFunc("/img/{id}", routers.WebpGet).Methods("GET")
// 設定靜態資源 (前端) 位于dist目录下
//cacheTime := 7 * 24 * time.Hour
r.PathPrefix("/images/").Handler(http.FileServer(http.Dir("./data/")))
//.Headers("Cache-Control", fmt.Sprintf("max-age=%d", int(cacheTime.Seconds())))
r.PathPrefix("/").Handler(http.FileServer(http.Dir("./dist/")))
//// 設定靜態資源 (前端) 位于dist目录下, 并且为 图片和 js/css 设置缓存时间为7天
//cacheTime := 7 * 24 * time.Hour
//r.PathPrefix("/images/").Handler(http.StripPrefix("/images/", http.FileServer(http.Dir("./data/images/")))).Headers("Cache-Control", fmt.Sprintf("max-age=%d", int(cacheTime.Seconds()))).Methods("GET")
//r.PathPrefix("/static/").Handler(http.StripPrefix("/static/", http.FileServer(http.Dir("./dist/static/")))).Headers("Cache-Control", fmt.Sprintf("max-age=%d", int(cacheTime.Seconds()))).Methods("GET")
//r.PathPrefix("/favicon.ico").Handler(http.StripPrefix("/", http.FileServer(http.Dir("./dist/favicon.ico")))).Headers("Cache-Control", fmt.Sprintf("max-age=%d", int(cacheTime.Seconds()))).Methods("GET")
//r.PathPrefix("/").Handler(http.StripPrefix("/", http.FileServer(http.Dir("./dist/")))).Methods("GET")
//r.PathPrefix("/").Handler(http.StripPrefix("/", http.FileServer(http.Dir("./dist/")))).Headers("Cache-Control", fmt.Sprintf("max-age=%d", int(cacheTime.Seconds()))).Methods("GET")
log.Println("Web Server is running on http://localhost:8080")
if err := http.ListenAndServe(":8080", r); err != nil {
log.Fatal(err)