2025-02-22 07:10:20 +00:00
|
|
|
|
package utils
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"bytes"
|
|
|
|
|
"crypto/sha256"
|
|
|
|
|
"encoding/hex"
|
|
|
|
|
"errors"
|
2025-06-15 07:27:51 +00:00
|
|
|
|
"fmt"
|
2025-02-22 07:10:20 +00:00
|
|
|
|
"fonchain-fiee/pkg/e"
|
2025-06-15 07:27:51 +00:00
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
"github.com/tealeg/xlsx"
|
2025-02-22 07:10:20 +00:00
|
|
|
|
"io"
|
|
|
|
|
"io/ioutil"
|
|
|
|
|
"net/http"
|
|
|
|
|
"net/url"
|
|
|
|
|
"os"
|
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
const (
|
|
|
|
|
ExcelPrefix = "xlsx"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func SHA256V(str []byte) string {
|
|
|
|
|
h := sha256.New()
|
|
|
|
|
h.Write(str)
|
|
|
|
|
return hex.EncodeToString(h.Sum(nil))
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Get(url string) string {
|
|
|
|
|
client := &http.Client{Timeout: 5 * time.Second}
|
|
|
|
|
resp, err := client.Get(url)
|
|
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
var buffer [512]byte
|
|
|
|
|
result := bytes.NewBuffer(nil)
|
|
|
|
|
for {
|
|
|
|
|
n, err := resp.Body.Read(buffer[0:])
|
|
|
|
|
result.Write(buffer[0:n])
|
|
|
|
|
if err != nil && err == io.EOF {
|
|
|
|
|
break
|
|
|
|
|
} else if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result.String()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PostForm 发送post请求
|
|
|
|
|
func PostForm(urlStr string, data url.Values) (string, error) {
|
|
|
|
|
resp, err := http.PostForm(urlStr, data)
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
// handle error
|
|
|
|
|
}
|
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
body, err := ioutil.ReadAll(resp.Body)
|
|
|
|
|
if err != nil {
|
|
|
|
|
// handle error
|
|
|
|
|
}
|
|
|
|
|
return string(body), err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func CheckDirPath(path string, create bool) (exists bool, err error) {
|
|
|
|
|
exists = false
|
|
|
|
|
if path == "" {
|
|
|
|
|
err = errors.New(e.GetMsg(e.InvalidParams))
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if _, err = os.Stat(path); os.IsNotExist(err) {
|
|
|
|
|
if !create {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if err = os.MkdirAll(path, os.ModePerm); err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
exists = true
|
|
|
|
|
return
|
|
|
|
|
}
|
2025-06-15 07:27:51 +00:00
|
|
|
|
|
|
|
|
|
// ToExcelByType 转成Excel类型
|
|
|
|
|
func ToExcelByType(titleList []string, dataList []interface{}, dataType string, filePath string) (content io.ReadSeeker, err error) {
|
|
|
|
|
// 生成一个新的文件
|
|
|
|
|
file := xlsx.NewFile()
|
|
|
|
|
// 添加sheet页
|
|
|
|
|
sheet, _ := file.AddSheet("Sheet1")
|
|
|
|
|
// 插入表头
|
|
|
|
|
titleRow := sheet.AddRow()
|
|
|
|
|
for _, v := range titleList {
|
|
|
|
|
cell := titleRow.AddCell()
|
|
|
|
|
cell.Value = v
|
|
|
|
|
}
|
|
|
|
|
// 插入内容
|
|
|
|
|
for _, v := range dataList {
|
|
|
|
|
row := sheet.AddRow()
|
|
|
|
|
if dataType == "struct" {
|
|
|
|
|
row.WriteStruct(v, -1)
|
|
|
|
|
} else if dataType == "slice" {
|
|
|
|
|
row.WriteSlice(v, -1)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
var buffer bytes.Buffer
|
|
|
|
|
_ = file.Write(&buffer)
|
|
|
|
|
if filePath != "" {
|
|
|
|
|
if err = file.Save(filePath); err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
content = bytes.NewReader(buffer.Bytes())
|
|
|
|
|
}
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ResponseXls content 为上面生成的io.ReadSeeker, fileTag 为返回前端的文件名
|
|
|
|
|
func ResponseXls(c *gin.Context, content io.ReadSeeker, fileTag string) {
|
|
|
|
|
fileName := fmt.Sprintf("%s.%s", fileTag, ExcelPrefix)
|
|
|
|
|
c.Writer.Header().Add("Content-Disposition", fmt.Sprintf(`attachment; filename="%s"`, fileName))
|
|
|
|
|
c.Writer.Header().Add("Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet")
|
|
|
|
|
http.ServeContent(c.Writer, c.Request, fileName, time.Now(), content)
|
|
|
|
|
}
|