使用Mongodb实现打卡签到系统的实例代码

2020-05-07 12:01:03王振洲

5.controller层

package com.ckf.mongodb_punch.controller; 
import com.ckf.mongodb_punch.entity.Attend; 
import com.ckf.mongodb_punch.service.AttendService; 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController; 
import org.springframework.web.multipart.MultipartFile; 
import java.util.HashMap; import java.util.List; 
import java.util.Map; 
@RestController public class AttendController
{ 
@Autowired private AttendService attendService;
@GetMapping("/sign") 
public String sign(String name)
{ /** * 将名字传给服务层,mongodb修改登录状态 
*/ attendService.sign(name); return "ok"; 
} 
/** * 上传文件 * @param classes * @param nameListExcel * @return 
*/ @PostMapping("/upload") 
public String upload(String classes, MultipartFile nameListExcel)
{
/** * 接收到前台传过来的文件对象,交给service层或者Excel工具类来解析数据
* System.out.println("接收前台表单提交数据:"+classes+nameListExcel);
*/ String result = attendService.upload(classes,nameListExcel);
return result;
} 
/** * 查询未签到同学 和已签到同学
* @return */ @GetMapping("/list")
public Map list(){ Map result = new HashMap<String,Object>(); /** * 已签到 */ List<Attend> 
complete = attendService.findAllBySign(1);
result.put("complete",complete); /** * 未签到 */ List<Attend> 
incomplete = attendService.findAllBySign(0);
result.put("incomplete",incomplete); 
return result;
} 
}

6.application.yml

这里使用的是mongodb的安全认证配置

spring: 
data: 
mongodb: 
uri: 
mongodb://ckf_user:123456@192.168.85.154:27017/attend_db

默认单例配置如下

spring: 
data: 
mongodb: 
uri:
mongodb://localhost:27017/attend_db

这里使用的是异步实现的

7.list.html

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>考勤管理页面</title>
 <style> #complete,#incomplete{ width: 50%; float: left; } </style>
 <script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>

 <h3>导入名单</h3> 班级名称: <input type="text" name="classes" id="classes"/> 请选择导入文件 <input type="file" name="nameList" id="nameList"/>
 <input type="button" id="upload" value="上传">
 <hr/>

 <div id="incomplete">
  <h3>未签到的</h3>
  <p></p>

 </div>

 <div id="complete">
  <h3>已签到</h3>
  <p></p>
 </div>

</body>
<script type="text/javascript"> $(function () { //初始化页面查询结果
 $.ajax({ type:"get", url:"/list", success:function(data){ console.log(data); var complete =""; var incomplete =""; $.each(data.complete,function (index,object) { complete += object.id +"&nbsp;" +object.name +"<br/>"; }) $("#complete p").html(complete); $.each(data.incomplete,function (index,object) { incomplete += object.id +"&nbsp;" +object.name +"<br/>"; }) $("#incomplete p").html(incomplete); } }); $("body").on("click","#upload",function(){ //将数据打包到formData对象中
   var formData = new FormData(); formData.append("classes",$("#classes").val()); formData.append("nameListExcel",$("#nameList")[0].files[0]); $.ajax({ type:"post", url:"/upload", //dataType:"json",
 data:formData, processData: false, contentType: false, success:function(data){ console.log(data); if(data=="ok"){ alert("上传成功,即将刷新页面") //刷新当前页面
 location.reload(); }else { alert("上传失败,请重新上传") } } }); }) }) </script>
</html>