XGoServer, серверная структура, основанная на xorm.

задняя часть Go сервер
XGoServer, серверная структура, основанная на xorm.

Автор: Линь Гуаньхун / Призраки под рукой

Самородки: https://juejin.cn/user/1785262612681997

Блог: http://www.cnblogs.com/linguanh/

Гитхаб: https://github.com/af913337456/

Облачная колонка Tencent: https://cloud.tencent.com/developer/user/1148436/activities


Адрес в открытом доступе:GitHub.com/afan913337456…

ты можешь использовать это

  • Просто и быстро создать свой собственный сервер
  • Расширенные расширения модулей, такие как jwt, модули токенов. Передача данных с шифрованием и т. д.

имеют

  • лог модуль,alecthomas/log4go
  • Модуль маршрутизации,gorilla/mux
  • Принятие жесткого хранилища / мягкого хранилищаxormРамка
  • Интеграция общих структур выходных данных на стороне сервера, таких как json
Если вы хотите вывести json напрямую клиенту, вот так
func main()  {
    router := new (mux.Router)
    router.HandleFunc("/",test2).Methods("GET")
    core.HttpListen(router) 
}
func test2(w http.ResponseWriter,r *http.Request)  {
    // 非常简单的例子, 操作放在内部 , 可以使用 request 来获取自己的参数,再直接组织输出
    core.HandlerMapWithOutputJson(w, func() map[string]interface{} {
    	m :=  map[string]interface{}{}
    	m["msg"] = "blow me a kiss"
    	return m
    })
}
// 结果 : {"msg":"blow me a kiss"}
Взаимодействовать с базой данных
func test3(w http.ResponseWriter,r *http.Request)  {
	core.HandlerMapWithOutputJson(w, func() map[string]interface{} {
		// 插入一条评论
		item := &model.Comment{
			Id	:util.NewId(),         // 评论 id
			UserId	:"123456",             // 评论人 id
			Name	:"LinGuanHong",        // 评论人名称
			Content	:"hello word",         // 评论内容
		}
		affect,_ := core.Engine.Insert(item)  // 执行插入,传入 struct 引用
		m :=  map[string]interface{}{}
		if affect > 0 {
			m["ret"] = "insert success"
			comments := make([]model.Comment, 0)
			core.Engine.Find(&comments)   // select 出来,获取所有评论输出
			m["msg"] = comments
		}else{
			m["ret"] = "insert failed"
		}
		return m
	})
}

输出的结果是:
{
  "msg": [
    {
      "id": "1kubpgh9pprrucy11e456fyytw",
      "UserId": "123456",
      "name": "LinGuanHong",
      "content": "hello word"
    }
  ],
  "ret": "insert success"
}

руководство

Каталог выглядит следующим образом

---- config
---- core
---- model
---- threeLibs
---- util
---- server.go

1 дюймconfigположить файл конфигурации

  • 服务端配置 json 文件--server.json,
  • 日志配置文件-- log.json, как показано ниже, все они будут в运行程序后会自动解析和读取

2 threeLibsКаталог размещает зависимые сторонние библиотеки, такие как xorm, без необходимости

3 modelпоместить структуру объекта данных

{
  "Host": "127.0.0.1",
  "Port": ":8884",
  "FilePort":":8885",
  "DbName":"lgh",
  "DbUser":"root",
  "DbPw":"123456",
  "DbPort":"3306"
}
{
  "EnableConsole": true,
  "ConsoleLevel": "DEBUG",
  "EnableFile": true,
  "FileLevel": "INFO",
  "FileFormat": "",
  "FileLocation": ""
}

Начните с очень простого примера:

func main()  {
    router := new (mux.Router)
    router.HandleFunc("/",test).Methods("GET")
    /** 在下面添加你的路由 */
    /** add your routine func below */ 
    core.HttpListen(router)  // 简单的 http 监听,当然也提供了 https
}
func test(w http.ResponseWriter,r *http.Request)  {
    fmt.Fprintf(w,"======= hello world! =======")
}

// http 监听
func HttpListen(router *mux.Router)  {
	SimpleInit()  // 此处自动初始化 ---------- ①
	url := config.ServerConfig.Host+config.ServerConfig.Port
	util.LogInfo("服务启动于 : "+url)
	err := http.ListenAndServe(url,router)
	if err !=nil {
		util.LogInfo("http error ===> : "+err.Error())
		return
	}
}
// 绑定配置 json 的信息 以及 初始化 xorm mysql数据库引擎
func SimpleInit() bool {
	if config.BindServerConfig() {
		fmt.Println("BindServerConfig ==================> success")
		config.ConfigureLog(&config.LogConfig)
		CreateDefaultMysqlEngine(
			"mysql",
			config.ServerConfig.DbUser,
			config.ServerConfig.DbPw,
			config.ServerConfig.DbName)
		return true
	}else{
		fmt.Println("BindServerConfig ===> failed")
		return false
	}
}

Встроенная функция интеграции общей структуры выходных данных на стороне сервера

type FinalResult struct {
	Data interface{}
}

type RetChannel chan FinalResult

func HandlerStruct(handle func() interface{}) *interface{} {
	RetChannel := make(RetChannel, 1)
	go func() {
		result := FinalResult{}
		data := handle()
		result.Data = &data
		RetChannel <- result
		close(RetChannel)
	}()
	ret := <-RetChannel
	return ret.Data.(*interface{})
}

func HandlerMap(handle func() map[string]interface{}) *map[string]interface{} {
	RetChannel := make(RetChannel, 1)
	go func() {
		result := FinalResult{}
		data := handle()
		result.Data = &data
		RetChannel <- result
		close(RetChannel)
	}()
	ret := <-RetChannel
	return ret.Data.(*map[string]interface{})
}

func HandlerStructWithOutputJson(w http.ResponseWriter,handle func() interface{})  {
	RetChannel := make(RetChannel, 1)
	go func() {
		result := FinalResult{}
		data := handle()
		result.Data = &data
		RetChannel <- result
		close(RetChannel)
	}()
	ret := <-RetChannel
	mapRet := ret.Data.(*interface{})
	util.RenderJson(w,mapRet)
}

func HandlerMapWithOutputJson(w http.ResponseWriter,handle func() map[string]interface{}){
	RetChannel := make(RetChannel, 1)
	go func() {
		result := FinalResult{}
		data := handle()
		result.Data = &data
		RetChannel <- result
		close(RetChannel)
	}()
	ret := <-RetChannel
	mapRet := ret.Data.(*map[string]interface{})
	util.RenderJson(w,mapRet)
}

Вот об этом