exhibition-main/pkg/service/register_record.go

415 lines
11 KiB
Go
Raw Normal View History

2024-01-31 09:04:43 +00:00
package service
2024-02-01 05:44:54 +00:00
import (
"context"
2024-02-19 05:54:38 +00:00
"encoding/base64"
2024-02-01 10:55:43 +00:00
"fmt"
2025-03-04 05:31:25 +00:00
"io/ioutil"
"net/http"
2025-03-11 06:24:12 +00:00
"os"
"strconv"
2025-03-04 05:31:25 +00:00
"time"
2024-02-01 05:44:54 +00:00
"github.com/dubbogo/gost/log/logger"
"github.com/exhibition-main/api/exhibition"
2024-02-01 10:55:43 +00:00
"github.com/exhibition-main/internal/config"
"github.com/exhibition-main/internal/model"
2024-02-01 05:44:54 +00:00
"github.com/exhibition-main/internal/msg"
"github.com/exhibition-main/internal/response"
2025-03-11 06:24:12 +00:00
"github.com/exhibition-main/pkg/service/common"
2024-02-02 09:06:06 +00:00
"github.com/exhibition-main/pkg/utils"
2024-02-01 05:44:54 +00:00
"github.com/gin-gonic/gin"
2024-02-19 05:54:38 +00:00
"github.com/gin-gonic/gin/binding"
2025-03-11 06:24:12 +00:00
"github.com/xuri/excelize/v2"
2024-02-01 05:44:54 +00:00
)
2024-02-01 10:55:43 +00:00
func RegisterList(c *gin.Context) {
2024-02-01 05:44:54 +00:00
var recordListReq exhibition.RecordListReq
if err := c.ShouldBind(&recordListReq); err != nil {
logger.Errorf("RegisterRecordList ShouldBind err", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
return
}
resp, err := GrpcExhibitionClientImpl.RegisterRecordList(context.Background(), &recordListReq)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
response.ResponseQuickMsg(c, msg.Ok, resp.Msg, resp)
return
}
2024-02-01 10:55:43 +00:00
func CheckByPhone(c *gin.Context) {
2024-02-01 05:44:54 +00:00
var registerInfo exhibition.RegisterInfo
if err := c.ShouldBind(&registerInfo); err != nil {
logger.Errorf("CheckPhone ShouldBind err", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
return
}
resp, err := GrpcExhibitionClientImpl.CheckPhone(context.Background(), &registerInfo)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
2024-02-20 06:26:34 +00:00
if resp.IsExist {
img := resp.Data.IdCardBackPhoto
2024-02-20 03:35:43 +00:00
2024-02-20 06:26:34 +00:00
response1, err := http.Get(img)
if err != nil {
fmt.Println("网络请求错误:", err)
return
}
2024-02-20 03:35:43 +00:00
2024-02-20 06:26:34 +00:00
defer response1.Body.Close()
2024-02-20 03:35:43 +00:00
2024-02-20 06:26:34 +00:00
// 读取图片数据
imageData, err := ioutil.ReadAll(response1.Body)
if err != nil {
fmt.Println("读取图片数据错误:", err)
return
}
2024-02-20 03:35:43 +00:00
2024-02-20 06:26:34 +00:00
// 将图片数据转换为base64编码
base64Data := base64.StdEncoding.EncodeToString(imageData)
result, err := model.OcrGetIdCard(base64Data, "back")
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
2024-02-20 03:35:43 +00:00
2024-02-20 06:26:34 +00:00
resp.Data.IdCardStartDate = result.IssueDate
resp.Data.IdCardEndDate = result.ExpirationDate
}
2024-02-20 03:35:43 +00:00
2024-02-01 05:44:54 +00:00
response.ResponseQuickMsg(c, msg.Ok, resp.Msg, resp)
return
}
2024-02-23 03:25:13 +00:00
func CheckIdCard(c *gin.Context) {
var registerInfo exhibition.RegisterInfo
if err := c.ShouldBind(&registerInfo); err != nil {
logger.Errorf("CheckIdCard ShouldBind err", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
return
}
resp, err := GrpcExhibitionClientImpl.CheckIdCard(context.Background(), &registerInfo)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
response.ResponseQuickMsg(c, msg.Ok, resp.Msg, nil)
return
}
2024-02-01 10:55:43 +00:00
func SaveRegister(c *gin.Context) {
2024-02-01 05:44:54 +00:00
var registerInfo exhibition.RegisterInfo
if err := c.ShouldBind(&registerInfo); err != nil {
logger.Errorf("SaveRegisterRecord ShouldBind err", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
return
}
resp, err := GrpcExhibitionClientImpl.SaveRegisterRecord(context.Background(), &registerInfo)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
2024-02-21 03:56:38 +00:00
img := resp.Data.IdCardBackPhoto
response1, err := http.Get(img)
if err != nil {
fmt.Println("网络请求错误:", err)
return
}
defer response1.Body.Close()
// 读取图片数据
imageData, err := ioutil.ReadAll(response1.Body)
if err != nil {
fmt.Println("读取图片数据错误:", err)
return
}
// 将图片数据转换为base64编码
base64Data := base64.StdEncoding.EncodeToString(imageData)
result, err := model.OcrGetIdCard(base64Data, "back")
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
resp.Data.IdCardStartDate = result.IssueDate
resp.Data.IdCardEndDate = result.ExpirationDate
2024-02-01 05:44:54 +00:00
response.ResponseQuickMsg(c, msg.Ok, resp.Msg, resp)
return
}
2024-02-01 10:55:43 +00:00
// ExportRegister 导出报名信息列表
func ExportRegister(c *gin.Context) {
var exportRecordReq exhibition.ExportRecordReq
resp, err := GrpcExhibitionClientImpl.ExportRegisterRecord(context.Background(), &exportRecordReq)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
if len(resp.Data) == 0 {
resp.Data = []*exhibition.ExportInfo{}
}
2025-03-10 07:19:02 +00:00
columns := []string{"初评评选号", "复评评选号", "画家姓名", "性别", "手机号", "身份证号", "通讯地址", "身份证照片", "本人近照", "省份", "作品名称", "作品类型", "画作尺寸", "报名时间", "更新时间"}
2025-03-10 08:23:58 +00:00
exportFileName := fmt.Sprintf("国展报名%s.xlsx", time.Now().Format("20060102"))
2025-03-05 07:47:19 +00:00
filePath := fmt.Sprintf("./runtime/%s", exportFileName)
2024-02-02 09:06:06 +00:00
data := make([]interface{}, 0)
for _, v := range resp.Data {
var temp []string
2025-03-10 07:19:02 +00:00
temp = append(temp, v.PreliminaryRatingNo)
temp = append(temp, v.ReRatingNo)
2024-02-02 09:06:06 +00:00
temp = append(temp, v.ArtistName)
var gender string
if v.Gender == 1 {
gender = "男"
2025-03-10 07:19:02 +00:00
} else if v.Gender == 2 {
2024-02-02 09:06:06 +00:00
gender = "女"
2025-03-10 07:19:02 +00:00
} else {
gender = " "
2024-02-02 09:06:06 +00:00
}
temp = append(temp, gender)
temp = append(temp, v.PhoneNum)
temp = append(temp, v.IdCard)
temp = append(temp, v.Address)
temp = append(temp, v.IdCardPhoto)
temp = append(temp, v.ArtistPhoto)
2025-03-10 07:19:02 +00:00
temp = append(temp, v.Province)
2025-03-04 05:31:25 +00:00
temp = append(temp, v.ArtworkName)
2025-03-10 07:19:02 +00:00
var artworkType string
if v.ArtworkType == 1 {
artworkType = "中国画"
} else {
artworkType = " "
}
temp = append(temp, artworkType)
temp = append(temp, v.ArtworkSize)
2024-02-02 09:06:06 +00:00
temp = append(temp, v.CreatedAt)
temp = append(temp, v.UpdatedAt)
data = append(data, &temp)
}
2025-03-05 09:18:50 +00:00
_, err = utils.ToExcelByType(columns, data, "slice", filePath)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
2025-03-06 01:24:51 +00:00
return
2025-03-05 09:18:50 +00:00
}
2024-02-02 09:06:06 +00:00
//处理图片
2025-03-05 08:49:39 +00:00
// err = logic.DealExcelImg(filePath)
// if err != nil {
// response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
// return
// }
2024-02-01 10:55:43 +00:00
var httpType string
2025-03-07 01:26:38 +00:00
if config.Data.System.Mode == "prod" {
2024-02-01 10:55:43 +00:00
httpType = model.HttpsType
} else {
httpType = model.HttpType
}
2024-02-22 04:14:35 +00:00
var exportUrl string
2025-03-06 01:45:20 +00:00
exportUrl = fmt.Sprintf("%s%s/api/static/%s", httpType, c.Request.Host, exportFileName)
2024-02-01 10:55:43 +00:00
response.ResponseQuickMsg(c, msg.Ok, resp.Msg, map[string]string{
2024-02-02 09:06:06 +00:00
"exportUrl": exportUrl,
2024-02-01 10:55:43 +00:00
})
return
}
2024-02-06 06:01:50 +00:00
2024-02-19 05:54:38 +00:00
func OcrBase64(c *gin.Context) {
var req model.OcrQuery
if err := c.ShouldBindBodyWith(&req, binding.JSON); err != nil {
logger.Errorf("OcrBase64 ShouldBind err", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
2024-02-06 06:01:50 +00:00
return
}
2024-02-19 05:54:38 +00:00
img := req.IdCardUrl
response1, err := http.Get(img)
if err != nil {
fmt.Println("网络请求错误:", err)
return
}
defer response1.Body.Close()
// 读取图片数据
imageData, err := ioutil.ReadAll(response1.Body)
if err != nil {
fmt.Println("读取图片数据错误:", err)
2024-02-06 06:01:50 +00:00
return
}
2024-02-19 05:54:38 +00:00
// 将图片数据转换为base64编码
base64Data := base64.StdEncoding.EncodeToString(imageData)
fmt.Println(base64Data)
side := ""
if req.Side == 1 {
side = "front"
} else {
side = "back"
}
result, err := model.OcrGetIdCard(base64Data, side)
2024-02-06 06:01:50 +00:00
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
2024-02-19 05:54:38 +00:00
res := model.OcrRes{}
if side == "front" {
res.IDNum = result.IdCard
res.RealName = result.Name
res.Path = result.Path
res.Age = result.Age
res.Birthday = result.Birthday
res.Sex = result.Sex
fmt.Println("身份证和名字", res.IDNum, res.RealName)
res.CheckIdAndName()
fmt.Println("身份证和名字", res.IDNum, res.RealName)
} else {
2024-02-19 07:23:26 +00:00
res.IssueDate = result.IssueDate
2024-02-19 05:54:38 +00:00
res.ExpirationDate = result.ExpirationDate
}
response.ResponseQuickMsg(c, msg.Ok, "操作成功", res)
2024-02-06 06:01:50 +00:00
return
}
2025-03-05 05:02:09 +00:00
func ImportRecordByExcel(c *gin.Context) {
file, err := c.FormFile("file")
if err != nil {
logger.Errorf("获取文件失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, msg.INVALID_PARAMS, nil)
return
}
//打开Excel文件
f, err := file.Open()
if err != nil {
logger.Errorf("打开文件失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, "文件打开失败", nil)
return
}
defer f.Close()
excelFile, err := excelize.OpenReader(f)
if err != nil {
logger.Errorf("读取Excel失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, "Excel解析失败", nil)
return
}
2025-03-05 05:49:26 +00:00
sheetName := excelFile.GetSheetName(1)
2025-03-11 06:24:12 +00:00
rows, err := excelFile.GetRows(sheetName)
2025-03-05 05:02:09 +00:00
if err != nil {
logger.Errorf("读取工作表失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, "工作表读取失败", nil)
return
}
// 遍历行数据(跳过标题行)
var records []*exhibition.RegisterInfo
for i, row := range rows {
if i == 0 { // 跳过标题行
continue
}
2025-03-11 06:24:12 +00:00
if len(row) < 12 { // 确保列数足够
2025-03-05 05:02:09 +00:00
continue
}
2025-03-11 06:24:12 +00:00
artworkUrl := ""
if pics, err := excelFile.GetPictures(sheetName, fmt.Sprintf("K%d", i+1)); err == nil && len(pics) > 0 {
tmpFile, err := ioutil.TempFile("", fmt.Sprintf("oss_upload_%d*.jpg", i))
if err != nil {
logger.Errorf("创建临时文件失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, "创建临时文件失败", nil)
return
}
defer os.Remove(tmpFile.Name())
if _, err := tmpFile.Write(pics[0].File); err != nil {
logger.Errorf("写入临时文件失败: %v", err)
response.ResponseQuickMsg(c, msg.Fail, "写入临时文件失败", nil)
return
}
//objectKey := fmt.Sprintf("artwork/%s/%d.jpg", time.Now().Format("20060102"), time.Now().UnixNano())
if url, err := common.PutBos(tmpFile.Name(), "image", false); err == nil {
artworkUrl = url
} else {
logger.Errorf("上传图片失败: %v", err)
}
}
2025-03-05 05:02:09 +00:00
record := &exhibition.RegisterInfo{
2025-03-11 06:24:12 +00:00
PreliminaryRatingNo: row[0],
ReRatingNo: row[1],
ArtworkName: row[2],
ArtworkType: 1, //中国画
ArtworkSize: row[4],
Address1: row[5],
ArtistName: row[6],
PhoneNum: string(row[7]),
Province: string(row[8]),
IdCard: string(row[9]),
ArtworkFile: artworkUrl,
2025-03-05 05:02:09 +00:00
}
2025-03-11 06:24:12 +00:00
record.Gender = GetGenderByIdCard(record.IdCard)
2025-03-05 05:02:09 +00:00
records = append(records, record)
}
2025-03-11 06:24:12 +00:00
for i, r := range records {
recordListReq := exhibition.RecordListReq{
Keyword: r.ArtistName,
}
resp, err := GrpcExhibitionClientImpl.RegisterRecordList(context.Background(), &recordListReq)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
records[i].Uuid = resp.Data[i].Uuid
}
2025-03-05 05:02:09 +00:00
for _, r := range records {
_, err := GrpcExhibitionClientImpl.SaveRegisterRecord(context.Background(), r)
if err != nil {
response.ResponseQuickMsg(c, msg.Fail, err.Error(), nil)
return
}
}
response.ResponseQuickMsg(c, msg.Ok, "ok", "")
return
}
2025-03-11 06:24:12 +00:00
// GetGenderByIdCard 根据身份证号判断性别
// 参数idCard - 身份证号码字符串
// 返回值1-男2-女0-未知
func GetGenderByIdCard(idCard string) int32 {
if len(idCard) != 18 && len(idCard) != 15 {
return 0
}
// 18位身份证取第17位15位身份证取最后一位
genderChar := idCard[16:17]
if len(idCard) == 15 {
genderChar = idCard[14:15]
}
genderNum, err := strconv.Atoi(genderChar)
if err != nil {
return 0
}
if genderNum%2 == 0 {
return 2 // 女
}
return 1 // 男
}