Skip to content

Latest commit

 

History

History
422 lines (370 loc) · 19.7 KB

version.MD

File metadata and controls

422 lines (370 loc) · 19.7 KB

dotweb版本记录:

Version 1.3.7

  • 新增Classic初始化App方式,调整New初始化内容
  • 调整日志启用开关默认为false,可以通过SetEnabledLog(true)或者SetDevelopmentMode()启用
  • dotweb.New()仅初始化必要的组件,移除打印Logo,移除启动日志
  • dotweb.Classic()方式下,默认启用日志,默认启用RequestLog中间件,默认打印logo以及启动日志
  • dotweb.SetDevelopmentMode()在原有启用屏幕打印的基础上,增加默认开启日志开关
  • 新增 example/start
  • 2017-11-10 21:30

Version 1.3.6

  • 升级Redis库,当前版本为redigo V1.2.0
  • 修改Redis工具类中,pool的创建方法由Dial调整为DialUrl
  • 废弃:Redis连接字符串形式10.0.1.11:6379 不可再使用
  • 变更:Redis连接字符串形式变更为:redis://:[email protected]:6379/0
  • 更新 example/session
  • 2017-11-08 09:00

Version 1.3.5

  • 提升UUID性能,调整UUID算法,新增UUID包
  • HttpServer新增设置是否启用唯一请求ID,默认不开启,开启后使用32位UUID,通过ctx.RequestID获取
  • 提供HttpServer.SetEnabledRequestID()函数
  • 提供uuid.V1\V2\V3\V4四类算法
  • move example/exception to devfeel/dotweb-example
  • move example/uploadfile to devfeel/dotweb-example
  • add cookbook link
  • 2017-11-02 16:00

Version 1.3.4

  • 增强Render实现,新增多模板支持
  • Context新增AddView接口,用于传入多模板
  • 模板统一基于Renderer().SetTemplatePath设置的相对文件名
  • 特别的:布局模板需放在第一个被解析,比如:
  • ctx.AddView("_layout/layout.html") err := ctx.View("dashbord/index.html")
  • 2017-10-31 10:00

Version 1.3.4

  • 增强Render实现,新增多模板支持
  • Context新增AddView接口,用于传入多模板
  • 模板统一基于Renderer().SetTemplatePath设置的相对文件名
  • 特别的:布局模板需放在第一个被解析,比如:
  • ctx.AddView("_layout/layout.html") err := ctx.View("dashbord/index.html")
  • 2017-10-31 10:00

Version 1.3.3

  • fixed for #70 UPDATE default http port 80 to 8080
  • 增加StandardHandle,统一自定义Handle场景
  • 2017-10-14 20:00

Version 1.3.2

  • 主要新增设置启用详细请求数据控制,新增MethodNotAllowedHandler自定义能力,完善数据统计逻辑
  • 新增设置启用详细请求数据控制:
    1. ServerStateInfo增加EnabledDetailRequestData,用于控制是否启用详细请求数据统计
    1. config.ServerConfig增加EnabledDetailRequestData设置,支持配置文件控制
    1. HttpServer增加SetEnabledDetailRequestData函数,用于代码设置是否启用详细请求数据统计
    1. fixed #63 状态数据,当url较多时,导致内存占用过大
  • 新增MethodNotAllowedHandler自定义能力
    1. dotweb增加DefaultMethodNotAllowedHandler、SetMethodNotAllowedHandle函数
    1. fixed #64 增加MethodNotAllowed自定义处理
  • 完善数据统计逻辑
    1. 404请求不计入详细请求数据统计
  • 2017-10-13 12:00

Version 1.3.1

  • 增加HttpServer.ServerFile,以支持server快捷设置静态文件目录
  • 2017-10-11 22:00

Version 1.3

  • 国庆迭代第三波
  • 增加TLS支持
  • 1)ServerConfig增加EnabledTLS\TLSCertFile\TLSKeyFile三个配置项
  • 2)HttpServer增加SetEnabledTLS方法
  • 3)增加example/tls目录
  • 移除:移除DotWeb.StartWithConfig方法,使用配置方式时需显式调用dotweb.SetConfig方法
  • 进一步完善默认日志输出
  • 2017-10-07 22:00

Version 1.2.1

  • 启动日志增加dotweb ASCII art logo
  • 调整默认日志的时间毫秒段为4位
  • 2017-10-05 22:00

Version 1.2

  • 国庆特别版 - 2017年的国庆,恰逢中秋双节,祝愿国家繁荣昌盛,祝愿代码艺术家们双节快乐!
  • 主要新增HttpModule模块、新增ServerConfig:EnabledIgnoreFavicon、完善HttpContext、完善debug日志输出
  • 【新增】HttpModule模块,提供路由之前全局级别的自定义代码能力
  • 1、新增module文件,将原dotweb文件中HttpMoule定义转移至module文件,新增Name属性
  • 2、新增getIgnoreFaviconModule函数用于创建基础Module用于EnabledIgnoreFavicon特性
  • 3、HttpServer新增RegisterModule函数,用于注册自定义HttpModule
  • 4、增加代码示例-根据参数动态变更访问路由 - package: example/httpmodule
  • 【新增】忽视favicon文件请求能力
  • 1、通过ServerConfig:EnabledIgnoreFavicon设置,默认不启用
  • 2、当启用该选项时,请求/facicon.ico文件时,将默认反馈空
  • 3、配置文件server节点增加enabledignorefavicon设置项
  • 【完善】HttpContext,使相关接口更清晰
  • 1、新增WriteHtml、WriteHtmlC函数,默认设置Context-Type:text/html; charset=utf-8
  • 3、注意,若在同一个请求期间,多次调用WriteHtml与WriteString,以最后一次调用的Context-Type为准
  • 【完善】debug日志输出,使dotweb启动过程更清晰
  • 1、新增Group创建日志
  • 2、新增ServerConfig设置日志
  • 3、新增设置Session参数日志
  • 4、新增Session初始化日志
  • 5、新增RegisterModule日志
  • 2017-10-03 14:00

Version 1.1

  • 主要新增集成基础统计数据
  • 【新增】dotweb/state接口,提供基础统计数据,主要数据说明:
  • 1、ServerStartTime 服务启动时间
  • 2、TotalRequestCount 服务启动以来累计请求数(排除了"/dotweb/"下系统自有页面的访问数)
  • 3、TotalErrorCount 服务启动以来累计错误数
  • 4、IntervalRequestData 按1分钟为间隔,默认保存最近60分钟,每分钟的请求数(排除了"/dotweb/"下系统自有页面的访问数)
  • 5、DetailRequestPageData 服务启动以来,每个页面的累计请求数(排除了"/dotweb/"下系统自有页面的访问数)
  • 6、IntervalErrorData 按1分钟为间隔,默认保存最近60分钟,每分钟的错误数
  • 7、DetailErrorPageData 服务启动以来,每个页面的累计错误数
  • 8、DetailErrorData 服务启动以来,每个异常的累计数
  • 9、DetailHttpCodeData 服务启动以来,每个Http状态码的累计数
  • 10、可通过 {host}/dotweb/state 获取数据
  • 【新增】dotweb/state/interval接口,提供按分钟级的基础数据查询
  • 主要数据说明:
  • 1、Time 表示查询时间的字符串,最小单位为分钟,例如:201709251200
  • 2、RequestCount 单位时间内累计请求数(排除了"/dotweb/"下系统自有页面的访问数)
  • 3、ErrorCount 单位时间内累计错误数
  • 2017-09-25 13:00

Version 1.0.1

  • 新增logger.SetEnabledConsole,当设置SetDevelopmentMode时自动开启
  • SetEnabledConsole:自动向console输出dotweb基础日志,便于开发人员调试阶段实时查看
  • 完善日志、注释
  • 2017-08-31 08:30

Version 1.0.0

  • dotweb正式进入1.0时代,感谢大家!
  • HttpServer新增IndexPage(),返回当前Server默认首页名称,支持配置文件配置,如果未配置,自动读取默认值:DefaultIndexPage = "index.html"
  • Context增加File、Attachment、Inline接口 感谢@esap issue #39
  • Context.File(file string),将指定文件响应到客户端,如果指定为目录,则根据HttpServer.IndexPage,默认寻找该目录下同名文件,不存在则返回404
  • Context.Attachment(file, name string),将指定文件响应到客户端下载,具体参考MIME协议扩展"Content-disposition"说明
  • Context.Inline(file, name string),将指定文件响应到客户端输出,具体参考MIME协议扩展"Content-disposition"说明
  • 新增example\file目录,提供对Context.File、Attachment、Inline三个接口的demo
  • 2017-07-29 17:00

Version 0.3.21

  • 新增DotWeb & HttpServer.ListenAndServer(addr string) 支持原生host监听
  • 新增DotWeb Close() & Shutdown() 支持优雅关闭服务
  • Context增加Context() & SetTimeoutContext() & WithContext()
  • Request增加自动生成unique RequestID,通过RequestID()获取,默认置入dotweb.Context.context中,以RequestID为key
  • 新增test目录,提供test公共方法,完善bind_test,感谢@zouyx
  • 2017-06-14 23:10

Version 0.3.20

Version 0.3.19

  • 新增AccessLog中间件,参考https://github.com/devfeel/middleware/tree/master/accesslog
  • use dotweb.logger
  • use debug level
  • logtarget is "dotweb_accesslog", like "dotweb_accesslog_debug_2017_06_09.log"
  • logformat: method userip proto status reqbytelen resbytelen timetaken
  • log-example: [debug] 2017-06-09 08:38:10.416369 [middleware.go:49] / GET 127.0.0.1 HTTP/1.1 200 0 19 10
  • 统一:所有中间件的New方式统一为package.Middleware()
  • 2017-06-09 08:00

Version 0.3.18

  • 新增cros中间件,参考 https://github.com/devfeel/middleware/tree/master/cros
  • 支持较为丰富的option选项,可以根据实际业务场景自定义
  • 支持设置Header:
  • 1)Access-Control-Allow-Origin
  • 2)Access-Control-Allow-Methods
  • 3)Access-Control-Allow-Headers
  • 4)Access-Control-Allow-Credentials
  • 5)Access-Control-Expose-Headers
  • 6)Access-Control-Max-Age
  • 7)P3P
  • HttpServer增加路由快捷方法:GET\POST\HEAD\OPTIONS\PUT\PATCH\DELETE\HiJack\WebSocket\ANY
  • Rsponse增加QueryHeader方法
  • 完善一些注释
  • Demo: https://github.com/devfeel/middleware/tree/master/example/cros
  • 2017-06-08 20:00

Version 0.3.17

  • 新增jwt中间件,参考demo:example/jwt
  • 支持较为丰富的option选项,可以根据实际业务场景自定义
  • 可配置通过Cookie、Header、QueryString三类token存储方式
  • 支持自定义非法token处理函数
  • 支持token通过jwt基础验证后的扩展处理接口
  • 新增依赖 引入 github.com/dgrijalva/jwt-go
  • 新增 example/jwt 目录
  • 2017-06-06 13:00

Version 0.3.16

  • 配置文件加载优化,加载解析配置文件失败的情况下返回error对象 × 配置文件匹配完善,依次按三个目录匹配:1按绝对路径检查,2进程根目录下寻找,3进程根目录/config/下寻找
  • 配置文件增加AppSet,用于应用自定义简单配置节点,配置文件增加appset节点,通过Context.AppSetConfig()访问
  • 更新 example/config 目录
<appset>
    <set key="email-host" value="mail.xx.com" />
    <set key="email-account" value="username" />
    <set key="email-password" value="password" />
    <set key="limit-per-ip" value="10" />
</appset>
//查询方式
ctx.AppSetConfig().GetString("email-host"))
ctx.AppSetConfig().GetInt("limit-per-ip"))
  • 2017-05-22 17:30

Version 0.3.15

  • 重要更新:HttpHandle增加error返回值,有error再也不用panic啦!
  • 重要更新:新增Context接口
  • ExceptionHandle func(*HttpContext, error) 调整为 ExceptionHandle func(Context, error)
  • HttpHandle func(*HttpContext) 调整为 HttpHandle func(Context) error
  • Middleware.Handle(ctx *HttpContext) error调整为Handle(ctx Context) error
  • Middleware.Next(ctx *HttpContext)调整为Next(ctx Context)
  • 为使Context设计与理解更清晰,做以下重要变更:
  • 迁移Context.QueryStrings()至Context.Request().QueryStrings()
  • 迁移Context.RawQuery()至Context.Request().RawQuery()
  • 迁移Context.FormFile()至Context.Request().FormFile()
  • 迁移Context.FormValues()至Context.Request().FormValues()
  • 迁移Context.PostBody()至Context.Request().PostBody()
  • 迁移Context.QueryHeader()至Context.Request().QueryHeader()
  • 迁移Context.Url()至Context.Request().Url()
  • 迁移Context.ContentType()至Context.Request().ContentType()
  • 迁移Context.DelHeader()至Context.Response().DelHeader()
  • 迁移Context.SetHeader()至Context.Response().SetHeader()
  • 迁移Context.SetContentType()至Context.Response().SetContentType()
  • 迁移Context.SetStatusCode()至Context.Response().SetStatusCode()
  • 废弃Context.PostString(key string) string
  • 通过在handler内返回相应的error,框架自动命中并通过设置的ExceptionHandle处理
  • 更新 example/下所有代码,以支持error返回值,支持Context接口
  • 2017-05-20 15:00

Version 0.3.14

  • 配置文件支持Middleware,支持App\Group\Router三个级别
  • DotWeb增加RegisterMiddlewareFunc\GetMiddlewareFunc方法,用于创建中间件的方法注册
  • 默认日志增加文件名与行号输出 - logger/xlog.go - [贡献者: @淡定]
  • 更新 example/config 目录
  • 2017-05-17 15:00

Version 0.3.12

  • ExceptionHandle定义由ExceptionHandle func(*HttpContext, interface{})调整为ExceptionHandle func(*HttpContext, error)
  • HttpContext.SetCookie定义由SetCookie(cookie http.Cookie)调整为SetCookie(cookie *http.Cookie)
  • HttpModule去除*Server属性
  • Group新增RegisterRoute(method, path string, h HttpHandle) 方法
  • 配置文件增加Group支持,可参考 example/config目录下xml与json示例配置文件
  • 更新 example/main 文件、example/config 目录
  • 2017-05-15 22:10

Version 0.3.11

  • 新增Group支持,可通过HttpServer.Group()或者NewGroup()创建,目前Group支持HEAD\GET\POST\PUT\OPTIONS\PATCH\DELETE路由方法
  • Middleware支持三个级别Use:DotWeb.Use\Group.Use\RouterNode.Use
  • 优化Router实现,移除router目录,整合xRouter和router.Router
  • 废弃:移除RouterNode级别的Feature支持,原RouterNode.Features.SetEnabledCROS 可通过自实现Middleware实现
  • 更新 example/middleware 目录
func InitRoute(server *dotweb.HttpServer) {
	server.Router().GET("/", Index)
	server.Router().GET("/use", Index).Use(NewAccessFmtLog("Router-use"))

	g := server.Group("/group").Use(NewAccessFmtLog("group"))
	g.GET("/", Index)
	g.GET("/use", Index).Use(NewAccessFmtLog("group-use"))
}
  • 2017-05-6 00:30

Version 0.3.10

  • 新增Middleware支持,通过DotWeb.Use引入中间件,处理请求顺序在HttpModule之后,响应请求顺序在HttpModule之前
  • 用户实现Middleware interface开发自定义middleware,为简化代码,可基于BaseMiddlware开发
  • 内建支持RequestLogMiddleware,通过DotWeb.UseRequestLog()引入
  • 优化路由注册日志,添加Handler名称,例如:main.Index
  • 更新 example/middleware 目录
  • 2017-04-23 09:00

Version 0.3.9.7

  • 新增Json格式配置文件支持
  • 更新 example/config 目录
  • 2017-04-19 09:00

Version 0.3.9.6

  • 优化精简HttpContext,移除部分非常用冗余方法,迁移至新增Request类型
  • Request增加PostBody缓存,可通过Request.PostBody()重复获取
  • 迁移:HttpContext.Proto()\Method()\FullRemoteIP()\Referer()\UserAgent()\Path()\Host()\IsAJAX 迁移至HttpContext.Request
  • BUG修复:修复HttpContext释放时,Response释放不彻底问题
  • 2017-04-12 09:00

Version 0.3.9.5

  • 新增Feature模块,目前支持CROS特性,可通过HttpServer全局设置、RouterNode路由级别设置
  • 新增CROS设置,设置是否允许跨域访问,并可设置AllowedOrigins、、AllowedMethods、AllowedHeaders、AllowCredentials、AllowedP3P属性
  • PProfServer调整为属性设置,通过SetPProfConfig设置,移除StartPProf方法
  • HttpContext新增RouterNode属性,可通过该属性获取路由信息
  • 迁移:原DotWeb中SetSessionConfig函数迁移至HttpServer
  • 废弃:DotWeb.SetSessionConfig、DotWeb.StartPProfServer
  • 配置App节点新增EnabledPProf\PProfPort设置,用于设置PProfServer
  • 完善配置文件与代码,完善代码,完善example
  • 2017-04-09 20:00

Version 0.3.9.4

  • 新增Logger接口,增加内置文件日志xlog实现
  • 配置新增app节点,支持LogPath、EnabledLog、RunMode,DotWeb增加SetEnabledLog方法;
  • 新增RunMode,目前支持development、production,相关特性后续完善,默认为development
  • 迁移:原DotWeb中SetEnabledListDir、SetEnabledSession、SetEnabledGzip函数迁移至HttpServer
  • 完善配置文件与代码,完善代码,完善example
  • 2017-04-04 18:00

Version 0.3.9.3

  • 调整Cache接口,Exists\Get\GetString\GetInt\GetInt64增加error返回值,影响Cache模块、Session模块
  • Redis连接异常信息将从接口error返回,取消原来的panic设计
  • 2017-04-04 16:00

Version 0.3.9.2

  • Render增加SetTemplatePath接口,用于设置模板默认目录, 默认添加base、base/templates、base/views
  • 模板查找顺序从最后一个插入的元素开始往前找
  • SetTemplatePath(path ...string)
  • 2017-04-01 10:30

Version 0.3.9.1

  • Router增加MatchPath接口,用于检查指定请求与指定路由是否匹配,一般用于HttpModule中
  • ctx.HttpServer.Router().MatchPath(ctx, "/user")
  • 2017-03-31 22:30

Version 0.3.9

  • 增强静态文件处理,增加设置目录浏览开关,通过Router.ServerFile使用
  • Router增加Any路由方式,如果设置为Any,则自动匹配:GET\HEAD\POST\PUT\PATCH\OPTIONS\DELETE
  • ServerConfig增加EnabledListDir选项,仅对Router.ServerFile有效,若设置该项,则可以浏览目录文件,默认不开启
  • ServerConfig增加EnabledAutoHEAD选项,如果设置该选项,则会为除Websocket\HEAD外所有路由方式默认添加HEAD路由,默认不开启
  • 优化部分代码,增加example\static、example\router
  • 2017-03-26 19:30

Version 0.3.8

  • 新增模板渲染支持,新增Renderer接口,需实现Render(io.Writer, string, interface{}, *HttpContext) error
  • 支持接入第三方模板引擎,默认使用http/template内建引擎
  • HttpContext增加ViewData,用于向模板传递值
  • HttpContext增加View()方法,传入模板文件名,用于简化模板使用:View(name string) error
  • 增加example\render
  • 2017-03-26 11:10

Version 0.3.7

  • 新增Cache模块,支持runtime、redis,常规支持Get\Set\GetString\GetInt\GetInt64\Incr\Decr\Exists\Clear操作
  • Cache通过app.SetCache启用,通过HttpContext.Cache()使用
  • ItemContext增加Remove、Once接口,影响HttpContext.AppContext、HttpContext.Items
  • 增加example\cache,优化部分代码
  • 2017-03-25 22:30

Version 0.3.6.5

  • App、Server、Session配置代码梳理优化
  • 新增Server接口,新增OfflineServer实现
  • 新增Router接口,将原HttpServer路由操作转移至HttpServer.Router()
  • 2017-03-24 14:00

Version 0.3.6

  • 新增Config支持, 支持Server、Session、Router三类配置
  • 新增HttpServer.RegisterHandler、HttpServer.GetHandler用于注册HttpHandle
  • 新增Offline配置,可设置Offline欢迎语或者默认跳转维护页
  • 新增example\config
  • 2017-03-23 22:00

Version 0.3.5.1

  • 新增ItemContext支持 - 单次请求完整通道内共享容器,通过HttpContext.Items().Get\Set操作
  • 可在OnBeginRequest、UserHandler、OnEndRequest三个环节使用
  • 新增example\httpmodule
  • 2017-03-21 15:00

Version 0.3.5

  • 新增AppContext支持 - 进程内共享容器,通过HttpContext.AppContext.Get\Set操作
  • 新增文件上传支持, 新增HttpContext.FormFile("key"),返回*UploadFile
  • 新增example\appcontext & example\uploadfile
  • 2017-03-21 15:00

Version 0.3.4

  • 新增Bind支持 - HttpContext.Bind(interface{}) 支持json、xml、Form数据
  • 2017-03-16 11:00

Version 0.3.3

  • 新增Gzip支持,通过app.SetEnabledGzip(true)开启,默认关闭
  • 2017-03-14 13:00

Version 0.3.2

  • 新增Session模块实现 - runtime\redis 两种模式
  • 2017-03-13 14:00

Version 0.3.1

  • 新增HttpServer.RegisterRoute函数,新增example目录
  • 2017-03-09 10:00

Version 0.3

  • 新增Hijack支持
  • 2017-01-10 16:00

Version 0.2

  • 新增WebSocket协议支持
  • 2016-11-29 16:00

Version 0.1.4

  • 新增HttpContext对Cookie的操作函数:WriteCookie\WriteCookieObj\RemoveCookie\ReadCookie\ReadCookieObj
  • 启用pool优化对象管理,节约GC压力
  • 2016-11-23 15:00

Version 0.1.3

  • 将fasthttp引擎变更为原生nethttp引擎
  • 升级go版本从1.6->1.7.3
  • 2016-11-15 16:00

Version 0.1.2

  • 增加HttpModule、ExceptionHandle、NotFound、Error特性支持
  • 2016-11-14 15:00

Version 0.1.1

  • 扩展HttpContext支持方法
  • 2016-11-10 11:00

Version 0.1

  • 初始版本,基于fasthttp引擎
  • 2016-11-09 11:00