结班后证书发放

This commit is contained in:
wuchunlei
2024-09-25 14:59:19 +08:00
parent 486def5389
commit 872718e01a
7 changed files with 180 additions and 102 deletions

View File

@@ -25,6 +25,7 @@ import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.imageio.ImageIO;
import java.math.BigDecimal;
import java.net.URL;
import java.util.HashSet;
import java.util.List;
@@ -400,113 +401,107 @@ public class ClassController {
return R.ok().put("userCertificate",userCertificate);
}
//生成证书
@RequestMapping("/generateCertificateClass")
//结班后发放证书
@RequestMapping("/generateCertificateByClassEnd")
@Transactional
public R generateCertificateClass(@RequestBody Map<String,Object> params) {
//抢锁
Boolean lock = redisTemplate.opsForValue().setIfAbsent("lock", "123");
if(lock) {
try {
//证书类型A a证 B b证 ZK自考
String type = params.get("type").toString();
MyUserEntity user = ShiroUtils.getUser();
String photoUrl = user.getPhoto();//证书人照片
String realName = user.getName();//真是姓名
public R generateCertificateByClassEnd(@RequestBody Map<String,Object> params){
ClassEntity classEntity = classEntityService.getById(params.get("classId").toString());
//给合格学员发放证书
List<Map<String,Object>> userScoreList = classEntityService.userScoreList(params);
for (Map<String, Object> userScoreMap : userScoreList) {
if (new BigDecimal(userScoreMap.get("userScore").toString()).compareTo(new BigDecimal(60))>=0){
UserCertificate userCertificate = new UserCertificate();
userCertificate.setTitle(classEntity.getTitle());
String type = "B";
if (new BigDecimal(userScoreMap.get("userScore").toString()).compareTo(new BigDecimal(70))>=0){
type = "A";
}
userCertificate.setType(type);
userCertificate.setUserId(ShiroUtils.getUId());
if ("ZK".equals(type)){
CourseEntity courseEntity = courseService.getById(params.get("relationId").toString());
String courseTitle = courseEntity.getTitle();
if (courseTitle.contains("")){
courseTitle = courseEntity.getTitle().substring(0,courseEntity.getTitle().indexOf(""));
}
userCertificate.setTitle(courseTitle);
ClassExamUser classExamUser = classExamUserService.getOne(new LambdaQueryWrapper<ClassExamUser>()
.eq(ClassExamUser::getUserId,ShiroUtils.getUId())
.eq(ClassExamUser::getRelationId,params.get("relationId").toString()));
String endYear = DateUtil.year(classExamUser.getEndTime())+"";
String endMonth = DateUtil.month(classExamUser.getEndTime())+1+"";
String endDay = DateUtil.dayOfMonth(classExamUser.getEndTime())+"";
String[] description= {endYear,endMonth,endDay,courseTitle};
String[] edes = {courseEntity.getEtitle()};
String certificateNo = getNextCertificateNo(type,courseEntity.getTitleAbbr());//证书编号
String url = userCertificateService.generateCertificate(type,certificateNo,photoUrl,realName, description, edes, endYear,endMonth,endDay);
MyUserEntity user = (MyUserEntity)userScoreMap.get("user");
userCertificate.setUserId(user.getId());
userCertificate.setClassId(classEntity.getId());
//查询小班下得课程信息
List<Map<String,Object>> classCourseInfoLlist = classEntityService.classCourseInfoClassId(classEntity.getId(),0);
for (Map<String,Object> classCourseInfo:classCourseInfoLlist){
String certificateNo = classEntityService.getNextCertificateNo(type,classCourseInfo.get("titleAbbr").toString());
userCertificate.setCertificateNo(certificateNo);
userCertificate.setCertificateUrl(url);
userCertificate.setCourseId(courseEntity.getId());
userCertificateService.save(userCertificate);
}else {
ClassEntity classEntity = classEntityService.getById(params.get("relationId").toString());
String startYear = DateUtil.year(classEntity.getStartTime())+"";
String startMonth = DateUtil.month(classEntity.getStartTime())+1+"";
String startDay = DateUtil.dayOfMonth(classEntity.getStartTime())+"";
String endYear = DateUtil.year(classEntity.getEndTime())+"";
String endMonth = DateUtil.month(classEntity.getEndTime())+1+"";
String endDay = DateUtil.dayOfMonth(classEntity.getEndTime())+"";
List<Map<String,Object>> list = classEntityService.classCourseInfoClassId(classEntity.getId());
for (Map<String,Object> map:list){
userCertificate.setCourseId((Integer) map.get("courseId"));
double keshiTotal = (double)map.get("keshi");
userCertificate.setCourseId((Integer) classCourseInfo.get("courseId"));
if (StringUtils.isNotEmpty(user.getPhoto())&&StringUtils.isNotEmpty(user.getName())){
String startYear = DateUtil.year(classEntity.getStartTime())+"";
String startMonth = DateUtil.month(classEntity.getStartTime())+1+"";
String startDay = DateUtil.dayOfMonth(classEntity.getStartTime())+"";
String endYear = DateUtil.year(classEntity.getEndTime())+"";
String endMonth = DateUtil.month(classEntity.getEndTime())+1+"";
String endDay = DateUtil.dayOfMonth(classEntity.getEndTime())+"";
double keshiTotal = (double)classCourseInfo.get("keshi");
String keshi = (keshiTotal+"").replace(".0","");
String courseTitle = map.get("courseTitle").toString();
String courseTitle = classCourseInfo.get("courseTitle").toString();
if (courseTitle.contains("")){
courseTitle = courseTitle.substring(0,courseTitle.indexOf(""));
}
String[] des = {startYear,startMonth,startDay,endYear,endMonth,endDay,
classEntity.getTitle(),courseTitle,keshi};
String[] edes = {map.get("courseETitle").toString(),keshi};
String certificateNo = getNextCertificateNo(type,map.get("titleAbbr").toString());
String url = userCertificateService.generateCertificate(type,certificateNo,photoUrl,realName,des, edes, endYear,endMonth,endDay);
String[] edes = {classCourseInfo.get("courseETitle").toString(),keshi};
String url = userCertificateService.generateCertificate(type,certificateNo,user.getPhoto(),user.getName(),
des, edes, endYear,endMonth,endDay);
userCertificate.setCertificateUrl(url);
userCertificate.setCertificateNo(certificateNo);
userCertificate.setTitle(classEntity.getTitle());
userCertificate.setClassId(classEntity.getId());
userCertificateService.save(userCertificate);
}
userCertificateService.save(userCertificate);
}
}finally {
//解锁
redisTemplate.delete("lock");
}
}else {
generateCertificateClass(params);
}
return R.ok();
}
//获取下一个编号
public String getNextCertificateNo(String type,String courseNamePinyin){
List<UserCertificate> userCertificateList = userCertificateService.list(new LambdaQueryWrapper<UserCertificate>()
.orderByDesc(UserCertificate::getId));
String res = "";
if (userCertificateList.size() > 0){
UserCertificate u0 = userCertificateList.get(0);
String certificateNo = u0.getCertificateNo();
int no = 0;
if (certificateNo.contains("ZK")){
no = Integer.parseInt(certificateNo.substring(5,11))+1;
}else {
no = Integer.parseInt(certificateNo.substring(3,9))+1;
}
if ("A".equals(type)){
res = "NO."+String.format("%06d", no);
}else if ("B".equals(type)){
res = "NO."+String.format("%06d", no);
}else if ("ZK".equals(type)){
res = "NO.ZK"+String.format("%06d", no);
}
//生成证书图片
@RequestMapping("/generateCertificateClass")
public R generateCertificateClass(@RequestBody Map<String,Object> params) {
MyUserEntity user = ShiroUtils.getUser();
String photoUrl = user.getPhoto();//证书人照片
String realName = user.getName();//真实姓名
UserCertificate userCertificate = userCertificateService.getById(params.get("id").toString());
String type = userCertificate.getType();//证书类型A a证 B b证 ZK自考
if ("ZK".equals(type)){
CourseEntity courseEntity = courseService.getById(userCertificate.getCourseId());
String courseTitle = userCertificate.getTitle();
ClassExamUser classExamUser = classExamUserService.getOne(new LambdaQueryWrapper<ClassExamUser>()
.eq(ClassExamUser::getUserId,ShiroUtils.getUId())
.eq(ClassExamUser::getRelationId,userCertificate.getCourseId()));
String endYear = DateUtil.year(classExamUser.getEndTime())+"";
String endMonth = DateUtil.month(classExamUser.getEndTime())+1+"";
String endDay = DateUtil.dayOfMonth(classExamUser.getEndTime())+"";
String[] description= {endYear,endMonth,endDay,courseTitle};
String[] edes = {courseEntity.getEtitle()};
String certificateNo = userCertificate.getCertificateNo();//证书编号
String url = userCertificateService.generateCertificate(type,certificateNo,photoUrl,realName, description, edes, endYear,endMonth,endDay);
userCertificate.setCertificateUrl(url);
userCertificateService.updateById(userCertificate);
}else {
if ("A".equals(type)){
res = "NO.000001";
}else if ("B".equals(type)){
res = "NO.000001";
}else if ("ZK".equals(type)){
res = "NO.ZK000001";
ClassEntity classEntity = classEntityService.getById(userCertificate.getClassId());
String startYear = DateUtil.year(classEntity.getStartTime())+"";
String startMonth = DateUtil.month(classEntity.getStartTime())+1+"";
String startDay = DateUtil.dayOfMonth(classEntity.getStartTime())+"";
String endYear = DateUtil.year(classEntity.getEndTime())+"";
String endMonth = DateUtil.month(classEntity.getEndTime())+1+"";
String endDay = DateUtil.dayOfMonth(classEntity.getEndTime())+"";
List<Map<String,Object>> list = classEntityService.classCourseInfoClassId(classEntity.getId(),userCertificate.getCourseId());
for (Map<String,Object> map:list){
double keshiTotal = (double)map.get("keshi");
String keshi = (keshiTotal+"").replace(".0","");
String courseTitle = map.get("courseTitle").toString();
if (courseTitle.contains("")){
courseTitle = courseTitle.substring(0,courseTitle.indexOf(""));
}
String[] des = {startYear,startMonth,startDay,endYear,endMonth,endDay,
classEntity.getTitle(),courseTitle,keshi};
String[] edes = {map.get("courseETitle").toString(),keshi};
String certificateNo = userCertificate.getCertificateNo();
String url = userCertificateService.generateCertificate(type,certificateNo,photoUrl,realName,des, edes, endYear,endMonth,endDay);
userCertificate.setCertificateUrl(url);
userCertificateService.updateById(userCertificate);
}
}
return res+courseNamePinyin;
return R.ok();
}