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