forked from golang/hotime
调整配置项设置
This commit is contained in:
parent
babf6595ee
commit
253f836571
@ -4,6 +4,7 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"github.com/sirupsen/logrus"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
@ -17,6 +18,7 @@ type Application struct {
|
|||||||
MethodRouter
|
MethodRouter
|
||||||
Router
|
Router
|
||||||
contextBase
|
contextBase
|
||||||
|
Log logrus.Logger
|
||||||
Port string //端口号
|
Port string //端口号
|
||||||
TLSPort string //ssl访问端口号
|
TLSPort string //ssl访问端口号
|
||||||
connectListener []func(this *Context) bool //所有的访问监听,true按原计划继续使用,false表示有监听器处理
|
connectListener []func(this *Context) bool //所有的访问监听,true按原计划继续使用,false表示有监听器处理
|
||||||
@ -421,13 +423,13 @@ func (this *Application) crossDomain(context *Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
header := context.Resp.Header()
|
header := context.Resp.Header()
|
||||||
header.Set("Access-Control-Allow-Origin", "*")
|
//header.Set("Access-Control-Allow-Origin", "*")
|
||||||
header.Set("Access-Control-Allow-Methods", "*")
|
header.Set("Access-Control-Allow-Methods", "*")
|
||||||
header.Set("Access-Control-Allow-Credentials", "true")
|
header.Set("Access-Control-Allow-Credentials", "true")
|
||||||
header.Set("Access-Control-Expose-Headers", "*")
|
header.Set("Access-Control-Expose-Headers", "*")
|
||||||
header.Set("Access-Control-Allow-Headers", "X-Requested-With,Content-Type,Access-Token")
|
header.Set("Access-Control-Allow-Headers", "X-Requested-With,Content-Type,Access-Token")
|
||||||
|
|
||||||
if context.Config.GetString("crossDomain") != "*" {
|
if context.Config.GetString("crossDomain") != "auto" {
|
||||||
header.Set("Access-Control-Allow-Origin", this.Config.GetString("crossDomain"))
|
header.Set("Access-Control-Allow-Origin", this.Config.GetString("crossDomain"))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
2
cache/cache_redis.go
vendored
2
cache/cache_redis.go
vendored
@ -1,7 +1,7 @@
|
|||||||
package cache
|
package cache
|
||||||
|
|
||||||
import (
|
import (
|
||||||
. "code.hoteas.com/golang/hotime"
|
. "../../hotime"
|
||||||
"github.com/garyburd/redigo/redis"
|
"github.com/garyburd/redigo/redis"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
110
var.go
110
var.go
@ -8,14 +8,18 @@ var App = map[string]*Application{} //整个项目
|
|||||||
var Config = Map{
|
var Config = Map{
|
||||||
"debug": 1, //debug 0关闭1开启
|
"debug": 1, //debug 0关闭1开启
|
||||||
"logLevel": LOG_FMT,
|
"logLevel": LOG_FMT,
|
||||||
"dbHost": "127.0.0.1",
|
"db": Map{
|
||||||
"dbName": "test",
|
"sqlite": Map{
|
||||||
"dbUser": "root",
|
"path": "config/data.db",
|
||||||
"dbPwd": "root",
|
},
|
||||||
"dbPort": "3306",
|
},
|
||||||
"dbCached": 0, //0不开启缓存
|
"cache": Map{
|
||||||
"cacheShortTime": 60 * 60 * 2,
|
"memory": Map{
|
||||||
"cacheLongTime": 60 * 60 * 24 * 30,
|
"timeout": 60 * 60 * 2,
|
||||||
|
"db": true,
|
||||||
|
"session": true,
|
||||||
|
},
|
||||||
|
},
|
||||||
"error": Map{
|
"error": Map{
|
||||||
"1": "内部系统异常",
|
"1": "内部系统异常",
|
||||||
"2": "访问权限异常",
|
"2": "访问权限异常",
|
||||||
@ -25,30 +29,62 @@ var Config = Map{
|
|||||||
},
|
},
|
||||||
"tpt": "tpt",
|
"tpt": "tpt",
|
||||||
"defFile": []string{"index.html", "index.htm"},
|
"defFile": []string{"index.html", "index.htm"},
|
||||||
"modeRouterStrict": false, //路由严格模式/a/b/c
|
"modeRouterStrict": false,
|
||||||
"port": "80",
|
"port": "80",
|
||||||
"sessionName": "HOTIME",
|
"sessionName": "HOTIME",
|
||||||
"tlsPort": "0",
|
|
||||||
"tlsKey": "",
|
|
||||||
"tlsCert": "",
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var ConfigNote = Map{
|
var ConfigNote = Map{
|
||||||
"logLevel": "日志等级,0关闭,1打印",
|
"logLevel": "默认0,必须,0关闭,1打印,日志等级",
|
||||||
"logFile": "如果需要存储日志文件时使用,保存格式为:a/b/c/20060102150405.txt,将生成:a/b/c/年月日时分秒.txt,按需设置",
|
"logFile": "无默认,非必须,如果需要存储日志文件时使用,保存格式为:a/b/c/20060102150405.txt,将生成:a/b/c/年月日时分秒.txt,按需设置",
|
||||||
"debug": "是否开启debug模式,0关闭,其他开启,debug模式下日志展示更全", //debug 0关闭1开启
|
"debug": "默认1,必须,0关闭,其他开启,0用于生产环境;其他值用于开发测试,会显示更多内容并能够辅助研发,自动生成配置文件、代码等功能,web无缓存", //debug 0关闭1开启
|
||||||
"dbHost": "数据库ip地址默认127.0.0.1",
|
"db": Map{
|
||||||
"dbName": "数据库名称,sqlite为文件路径比如a/x.db",
|
"注释": "配置即启用,非必须,默认使用sqlite数据库",
|
||||||
"dbUser": "数据库用户名",
|
"mysql": Map{
|
||||||
"dbPwd": "数据库密码",
|
"注释": "除prefix及主从数据库slave项,其他全部必须",
|
||||||
"dbPort": "数据库端口",
|
"host": "默认127.0.0.1,必须,数据库ip地址",
|
||||||
"dbType": "如果需要使用自动数据库配置,请设置此项,手动配置数据库不需要,目前支持mysql,sqlite",
|
"name": "默认test,必须,数据库名称",
|
||||||
"dbCached": "是否开启数据库缓存0为关闭,其他开启", //0不开启缓存
|
"user": "默认root,必须,数据库用户名",
|
||||||
"redisHost": "如果需要使用redis服务时配置,默认服务ip:127.0.0.1",
|
"password": "默认root,必须,数据库密码",
|
||||||
"redisPort": "如果需要使用redis服务时配置,默认服务端口:6379",
|
"port": "默认3306,必须,数据库端口",
|
||||||
"redisPwd": "如果需要使用redis服务时配置,默认服务密码:123456",
|
"prefix": "默认空,非必须,数据表前缀",
|
||||||
"cacheShortTime": "两级缓存,短缓存存储时间60 * 60 * 2,一般为内存缓存",
|
"slave": Map{
|
||||||
"cacheLongTime": "两级缓存,长缓存存储时间60 * 60 * 24 * 30,一般为数据库或者redis缓存",
|
"注释": "从数据库配置,mysql里配置slave项即启用主从读写,减少数据库压力",
|
||||||
|
"host": "默认127.0.0.1,必须,数据库ip地址",
|
||||||
|
"name": "默认test,必须,数据库名称",
|
||||||
|
"user": "默认root,必须,数据库用户名",
|
||||||
|
"password": "默认root,必须,数据库密码",
|
||||||
|
"port": "默认3306,必须,数据库端口",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"sqlite": Map{
|
||||||
|
"path": "默认config/data.db,必须,数据库位置",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"cache": Map{
|
||||||
|
"注释": "可配置memory,db,redis,默认启用memory,默认优先级为memory>redis>db,memory与数据库缓存设置项一致,缓存数据填充会自动反方向反哺,加入memory缓存过期将自动从redis更新,但memory永远不会更新redis,如果是集群建议不要开启memory,配置即启用",
|
||||||
|
"memory": Map{
|
||||||
|
"timeout": "默认60 * 60 * 2,必须,过期时间,超时自动删除",
|
||||||
|
"db": "默认true,非必须,缓存数据库,启用后能减少数据库的读写压力",
|
||||||
|
"session": "默认true,非必须,缓存web session,同时缓存session保持的用户缓存",
|
||||||
|
"sort": "默认0,非必须,优先级,数值越大优先级越高,默认优先级为memory>redis>db,",
|
||||||
|
},
|
||||||
|
"db": Map{
|
||||||
|
"timeout": "默认60 * 60 * 24 * 30,必须,过期时间,超时自动删除",
|
||||||
|
"db": "默认true,非必须,缓存数据库,启用后能减少数据库的读写压力",
|
||||||
|
"session": "默认true,非必须,缓存web session,同时缓存session保持的用户缓存",
|
||||||
|
"sort": "默认0,非必须,优先级,数值越大优先级越高,默认优先级为memory>redis>db,",
|
||||||
|
},
|
||||||
|
"redis": Map{
|
||||||
|
"host": "默认服务ip:127.0.0.1,必须,如果需要使用redis服务时配置,",
|
||||||
|
"port": "默认服务端口:6379,必须,如果需要使用redis服务时配置,",
|
||||||
|
"password": "默认密码空,必须,如果需要使用redis服务时配置,默认密码空",
|
||||||
|
"timeout": "memory默认60 * 60 * 30,db默认60 * 60 * 24 * 30,必须,过期时间,超时自动删除",
|
||||||
|
"db": "默认true,非必须,缓存数据库,启用后能减少数据库的读写压力",
|
||||||
|
"session": "默认true,非必须,缓存web session,同时缓存session保持的用户缓存",
|
||||||
|
"sort": "默认0,非必须,优先级,数值越大优先级越高,默认优先级为memory>redis>db,",
|
||||||
|
},
|
||||||
|
},
|
||||||
"error": Map{
|
"error": Map{
|
||||||
"1": "内部系统异常,在环境配置,文件访问权限等基础运行环境条件不足造成严重错误时使用",
|
"1": "内部系统异常,在环境配置,文件访问权限等基础运行环境条件不足造成严重错误时使用",
|
||||||
"2": "访问权限异常,没有登录或者登录异常等时候使用",
|
"2": "访问权限异常,没有登录或者登录异常等时候使用",
|
||||||
@ -57,14 +93,14 @@ var ConfigNote = Map{
|
|||||||
"5": "数据结果异常,一般用于无法给出response要求的格式要求下使用,比如response需要的是string格式但你只能提供int数据时",
|
"5": "数据结果异常,一般用于无法给出response要求的格式要求下使用,比如response需要的是string格式但你只能提供int数据时",
|
||||||
"注释": "web服务内置错误提示,自定义异常建议10开始",
|
"注释": "web服务内置错误提示,自定义异常建议10开始",
|
||||||
},
|
},
|
||||||
"tpt": "静态文件目录,默认为程序目录下tpt目录",
|
"tpt": "默认tpt,必须,web静态文件目录,默认为程序目录下tpt目录",
|
||||||
"defFile": "默认访问文件,默认访问index.html或者index.htm文件",
|
"defFile": "默认访问index.html或者index.htm文件,必须,默认访问文件类型",
|
||||||
"crossDomain": "如果需要跨域设置,空字符串为不开启,*为开启所有网站允许跨域,http://www.baidu.com为指定域允许跨域", //是否开启跨域
|
"crossDomain": "默认空 非必须,空字符串为不开启,如果需要跨域设置,auto为智能开启所有网站允许跨域,http://www.baidu.com为指定域允许跨域", //是否开启跨域
|
||||||
"modeRouterStrict": "路由严格模式false,为大小写忽略必须匹配,true必须大小写匹配", //路由严格模式/a/b/c
|
"modeRouterStrict": "默认false,必须,路由严格模式false,为大小写忽略必须匹配,true必须大小写匹配", //路由严格模式/a/b/c
|
||||||
"connectLogShow": "如果需要web访问链接、访问ip、访问时间打印,0为关闭其他数字开启此功能",
|
"connectLogShow": "默认true,非必须,访问日志如果需要web访问链接、访问ip、访问时间打印,false为关闭true开启此功能",
|
||||||
"sessionName": "设置session的cookie名默认HOTIME",
|
"sessionName": "默认HOTIME,必须,设置session的cookie名",
|
||||||
"port": "web服务开启Http端口,0为不启用http服务,默认80",
|
"port": "默认80,必须,web服务开启Http端口,0为不启用http服务,默认80",
|
||||||
"tlsPort": "web服务https端口,0为不启用https服务",
|
"tlsPort": "默认443,非必须,web服务https端口,0为不启用https服务",
|
||||||
"tlsKey": "https密钥",
|
"tlsKey": "默认空,非必须,https密钥",
|
||||||
"tlsCert": "https证书",
|
"tlsCert": "默认空,非必须,https证书",
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user