Modify: preview should use login session to enable http-range

This commit is contained in:
HFO4 2019-12-14 15:06:30 +08:00
parent 8557ed8e2e
commit 2c75c73886
3 changed files with 34 additions and 10 deletions

View file

@ -137,20 +137,22 @@ func Thumb(c *gin.Context) {
} }
// RedirectToDownload 创建下载会话并重定向至下载地址 // Preview 预览文件
func RedirectToDownload(c *gin.Context) { func Preview(c *gin.Context) {
// 创建上下文 // 创建上下文
ctx, cancel := context.WithCancel(context.Background()) ctx, cancel := context.WithCancel(context.Background())
defer cancel() defer cancel()
var service explorer.FileDownloadCreateService var service explorer.FileDownloadCreateService
if err := c.ShouldBindUri(&service); err == nil { if err := c.ShouldBindUri(&service); err == nil {
res := service.CreateDownloadSession(ctx, c) res := service.PreviewContent(ctx, c)
if res.Code == 0 { // 是否需要重定向
if res.Code == -301 {
c.Redirect(301, res.Data.(string)) c.Redirect(301, res.Data.(string))
return
} }
if res.Code != 0 {
c.JSON(200, res) c.JSON(200, res)
}
} else { } else {
c.JSON(200, ErrorResponse(err)) c.JSON(200, ErrorResponse(err))
} }
@ -171,7 +173,7 @@ func CreateDownloadSession(c *gin.Context) {
} }
} }
// DownloadArchived 文件下载 // Download 文件下载
func Download(c *gin.Context) { func Download(c *gin.Context) {
// 创建上下文 // 创建上下文
ctx, cancel := context.WithCancel(context.Background()) ctx, cancel := context.WithCancel(context.Background())

View file

@ -106,8 +106,8 @@ func InitRouter() *gin.Engine {
file.POST("upload", controllers.FileUploadStream) file.POST("upload", controllers.FileUploadStream)
// 创建文件下载会话 // 创建文件下载会话
file.PUT("download/*path", controllers.CreateDownloadSession) file.PUT("download/*path", controllers.CreateDownloadSession)
// 创建文件下载并重定向到下载地址 // 预览文件
file.GET("redirect/*path", controllers.RedirectToDownload) file.GET("preview/*path", controllers.Preview)
// 获取缩略图 // 获取缩略图
file.GET("thumb/:id", controllers.Thumb) file.GET("thumb/:id", controllers.Thumb)
// 取得文件外链 // 取得文件外链

View file

@ -112,7 +112,7 @@ func (service *FileDownloadCreateService) CreateDownloadSession(ctx context.Cont
} }
} }
// Download 文件下载 // Download 通过签名URL的文件下载无需登录
func (service *DownloadService) Download(ctx context.Context, c *gin.Context) serializer.Response { func (service *DownloadService) Download(ctx context.Context, c *gin.Context) serializer.Response {
// 创建文件系统 // 创建文件系统
fs, err := filesystem.NewFileSystemFromContext(c) fs, err := filesystem.NewFileSystemFromContext(c)
@ -150,3 +150,25 @@ func (service *DownloadService) Download(ctx context.Context, c *gin.Context) se
Code: 0, Code: 0,
} }
} }
// PreviewContent 预览文件,需要登录会话
func (service *FileDownloadCreateService) PreviewContent(ctx context.Context, c *gin.Context) serializer.Response {
// 创建文件系统
fs, err := filesystem.NewFileSystemFromContext(c)
if err != nil {
return serializer.Err(serializer.CodePolicyNotAllowed, err.Error(), err)
}
// 获取文件流
rs, err := fs.GetDownloadContent(ctx, service.Path)
if err != nil {
return serializer.Err(serializer.CodeNotSet, err.Error(), err)
}
defer rs.Close()
http.ServeContent(c.Writer, c.Request, fs.FileTarget[0].Name, fs.FileTarget[0].UpdatedAt, rs)
return serializer.Response{
Code: 0,
}
}