upload_file.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/config"
  6. "kpt-pasture/model"
  7. "kpt-pasture/util"
  8. "mime/multipart"
  9. "os"
  10. "path/filepath"
  11. "time"
  12. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  13. "go.uber.org/zap"
  14. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  15. "gitee.com/xuyiping_admin/pkg/xerr"
  16. )
  17. func (s *StoreEntry) Photos(ctx context.Context, files []*multipart.FileHeader) ([]string, error) {
  18. userModel, err := s.GetUserModel(ctx)
  19. if err != nil {
  20. return nil, err
  21. }
  22. workDir := fmt.Sprintf("%s", config.WorkDir)
  23. pathDir := fmt.Sprintf("/files/photos/%d/%s", userModel.AppPasture.Id, time.Now().Local().Format("20060102"))
  24. saveDir := filepath.Join(workDir, pathDir)
  25. if _, err = os.Stat(saveDir); os.IsNotExist(err) {
  26. if err = os.MkdirAll(saveDir, 0755); err != nil {
  27. return nil, xerr.Customf("创建目录失败: %s", err.Error())
  28. }
  29. }
  30. // 处理每个文件
  31. filePaths := make([]string, len(files))
  32. for i, file := range files {
  33. contentType := file.Header.Get("Content-Type")
  34. if contentType != "image/jpeg" && contentType != "image/png" && contentType != "image/gif" {
  35. return nil, xerr.Customf("图片格式错误: %s", file.Filename)
  36. }
  37. if file.Size > 1024*1024*5 {
  38. return nil, xerr.Customf("单个图片文件不能超过5MB")
  39. }
  40. ext := filepath.Ext(file.Filename)
  41. if ext == "" {
  42. switch contentType {
  43. case "image/jpeg":
  44. ext = ".jpg"
  45. case "image/png":
  46. ext = ".png"
  47. case "image/gif":
  48. ext = ".gif"
  49. default:
  50. ext = ".jpg" // 默认
  51. }
  52. }
  53. randomName := util.GenerateRandomNumberString(32)
  54. finalFilename := randomName + ext
  55. fPath := filepath.Join(saveDir, finalFilename)
  56. urlPath := filepath.Join(pathDir, finalFilename)
  57. if err = util.SaveUploadedFile(file, fPath); err != nil {
  58. return nil, xerr.Customf("保存文件失败: %s", err.Error())
  59. }
  60. filePaths[i] = urlPath
  61. }
  62. return filePaths, nil
  63. }
  64. func (s *StoreEntry) ImportExcel(ctx context.Context, data []map[string]string) error {
  65. // 获取当前用户信息
  66. userModel, err := s.GetUserModel(ctx)
  67. if err != nil {
  68. return err
  69. }
  70. // 验证牧场ID
  71. if userModel.AppPasture.Id <= 0 {
  72. return xerr.Custom("无效的牧场ID")
  73. }
  74. cowList := make([]*model.Cow, 0)
  75. // 批量处理数据
  76. for _, row := range data {
  77. // 验证必要字段
  78. if _, ok := row["耳号"]; !ok {
  79. return xerr.Custom("缺少必要字段: 耳号")
  80. }
  81. sex := pasturePb.Genders_Female
  82. if _, ok := row["性别"]; !ok {
  83. return xerr.Custom("缺少必要字段: 性别")
  84. } else {
  85. if row["性别"] == "公" {
  86. sex = pasturePb.Genders_Male
  87. }
  88. }
  89. // 创建或更新牛只信息
  90. cow := &model.Cow{
  91. PastureId: userModel.AppPasture.Id,
  92. EarNumber: row["耳号"],
  93. Sex: sex,
  94. }
  95. // 检查牛只是否已存在
  96. var existingCow model.Cow
  97. if err = s.DB.Model(new(model.Cow)).
  98. Where("pasture_id = ? AND ear_number = ?", userModel.AppPasture.Id, cow.EarNumber).
  99. First(&existingCow).Error; err == nil {
  100. } else {
  101. cowList = append(cowList, cow)
  102. }
  103. }
  104. zaplog.Info("ImportExcel", zap.Any("cowList", cowList))
  105. return nil
  106. }