亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

使用Mongodb實現打卡簽到系統的實例代碼

2020-10-29 18:40:34
字體:
來源:轉載
供稿:網友

使用excel文件導入數據,整合mongodb實現打卡簽到系統

環境參數

  • 開發工具:IDEA
  • 基礎環境:Maven+JDK8
  • 主要技術:SpringBoot、Mongodb
  • SpringBoot版本:2.2.6

實現步驟如下:

1.添加依賴

 <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-web</artifactId>  </dependency>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-data-mongodb</artifactId>  </dependency>  <dependency>   <groupId>org.projectlombok</groupId>   <artifactId>lombok</artifactId>   <optional>true</optional>  </dependency>  <!-- excel工具 -->  <dependency>   <groupId>org.apache.poi</groupId>   <artifactId>poi-ooxml</artifactId>   <version>4.0.1</version>  </dependency>  <dependency>   <groupId>org.springframework.boot</groupId>   <artifactId>spring-boot-starter-test</artifactId>   <scope>test</scope>   <exclusions>    <exclusion>     <groupId>org.junit.vintage</groupId>     <artifactId>junit-vintage-engine</artifactId>    </exclusion>   </exclusions>  </dependency>  <dependency>   <groupId>junit</groupId>   <artifactId>junit</artifactId>   <scope>test</scope>  </dependency>

2.實體層

3.業務service層

4. service實現層

package com.ckf.mongodb_punch.service.impl; import com.ckf.mongodb_punch.mapper.AttendRepository; import com.ckf.mongodb_punch.entity.Attend; import com.ckf.mongodb_punch.service.AttendService; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import org.springframework.data.mongodb.core.query.Update; import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; import java.io.IOException; import java.util.ArrayList; import java.util.List; @Service public class AttendServiceImpl implements AttendService { @Autowired private AttendRepository attendRepository; @Autowired private MongoTemplate mongoTemplate; /** * 上傳文件 * @param classes * @param nameListExcel * @return */ @Override public String upload(String classes, MultipartFile nameListExcel) { String result = "no"; if (nameListExcel == null) { return result; } //實例化對象列表,用于存儲Excel中的數據  List<Attend> attendList = new ArrayList<Attend>(); //讀取文件對象nameListExcel 中的數據(讀取Excel中每一行數據,存到對象,存到對象列表中)  try { //根據路徑獲取這個操作excel的實例   HSSFWorkbook wb = new HSSFWorkbook(nameListExcel.getInputStream()); //根據頁面index 獲取sheet頁   HSSFSheet sheet = wb.getSheetAt(0); HSSFRow row = null; //循環sesheet頁中數據從第二行開始,第一行是標題   for (int i = 1; i < sheet.getPhysicalNumberOfRows(); i++) { //獲取每一行數據    row = sheet.getRow(i); Attend attend = new Attend(); //下面cellnum對應著下標,id是第一位對應著下標為0,name是第二位對應的下標為1,等等..    attend.setId(Integer.valueOf((int) row.getCell(0).getNumericCellValue())); attend.setName(row.getCell(1).getStringCellValue()); attend.setSign(Integer.valueOf((int) row.getCell(2).getNumericCellValue())); attendList.add(attend); } } catch (IOException e) { e.printStackTrace(); } System.out.println("解析Excel中的數據:" + attendList); /** * 如果成功就,寫入mongodb中 */ attendRepository.saveAll(attendList); result = "ok"; return result; } /** * 簽到 * @param name * @return */ @Override public String sign(String name) { Query query = Query.query(Criteria.where("name").is(name)); //局部修改的內容  Update update = new Update(); update.set("sign", 1); //attend 集合名 對應實體的集合名  mongoTemplate.updateFirst(query, update, "attend"); return "ok"; } /** * 全查詢學生信息 * @param sign * @return */ @Override public List<Attend> findAllBySign(Integer sign) { return attendRepository.findAllBySign(sign); } }

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>

簽到打卡代碼如下:

8.sign-in.html

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>簽到頁面</title> <script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js" type="text/javascript" charset="utf-8"></script></head><body> 請輸入你的姓名:<input type="text" id="name"/> <input type="button" id="sign" value="簽到"/></body><script type="text/javascript"> $(function () { $("body").on("click","#sign",function(){ $.ajax({ type:"get", url:"/sign", data:{"name":$("#name").val()}, success:function(data){ console.log(data); if(data=="ok"){ alert("簽到成功,返回簽到頁面") //刷新當前頁面 location.reload(); }else { alert("簽到成功,請重新簽到") } } }); }) }) </script></html>

list.html頁面效果圖

工作表效果圖

遠程工具查詢剛導入的數據如下 數據后面有包的路徑是因為導入數據的時候沒有添加mongodb配置類,添加了就沒有了。

添加配置類之后的效果圖 

注意:導入excel文件(xsl工作表)的時候使用2003之前版本的,后綴帶XLS。

有哪里不明白的地方記得下方留言哦。

項目已托管碼云

地址:https://gitee.com/ckfeng/mongodb_punch.git 

總結

到此這篇關于使用Mongodb實現打卡簽到系統的文章就介紹到這了,更多相關使用Mongodb實現打卡簽到系統內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成一区二区| 欧美黑人极品猛少妇色xxxxx| 欧美日韩一区二区免费视频| 久久国内精品一国内精品| 国产一区二区激情| 欧美日韩第一视频| 亚洲网址你懂得| 日韩麻豆第一页| 国产精品色婷婷视频| 日韩av在线导航| 久久国产精品视频| 91国自产精品中文字幕亚洲| 国产日韩av在线播放| 黄色一区二区在线| 中日韩午夜理伦电影免费| 怡红院精品视频| 97在线观看视频| 国内精品小视频在线观看| 欧美激情一二三| 日韩欧美中文字幕在线播放| 在线一区二区日韩| 97久久久久久| 国产亚洲精品va在线观看| 国产一区二区三区三区在线观看| 国产欧美一区二区| 黑人巨大精品欧美一区二区免费| 亚洲va男人天堂| 日韩视频亚洲视频| 九九热这里只有精品6| 国产精品美腿一区在线看| 日本成熟性欧美| 国模叶桐国产精品一区| 亚洲美女精品成人在线视频| 97视频在线观看免费| 中文字幕在线成人| 综合136福利视频在线| 成人免费自拍视频| 色婷婷亚洲mv天堂mv在影片| 欧美猛男性生活免费| 日韩精品视频在线播放| 日本精品视频在线| 国内伊人久久久久久网站视频| 久久天堂av综合合色| 欧美日韩国产丝袜另类| 国产免费一区视频观看免费| 国产午夜精品全部视频播放| 美日韩精品免费视频| 亚洲欧美www| 欧美性猛交xxxx免费看| 国产精品久久久久久久久久久久久| 国产精品激情av在线播放| 久久99国产精品自在自在app| 国产亚洲精品美女久久久久| 91成人国产在线观看| 黑人巨大精品欧美一区二区三区| 国产精品视频精品视频| 亚洲国产天堂久久国产91| 色多多国产成人永久免费网站| 久久免费视频观看| 91精品国产自产在线观看永久| 欧美日产国产成人免费图片| 午夜精品三级视频福利| 亚洲精品理论电影| 亚洲在线www| 欧洲成人在线观看| 亚洲色图av在线| 奇米一区二区三区四区久久| 97视频免费在线观看| 亚洲第一精品夜夜躁人人爽| 日韩av免费在线观看| 亚洲美女精品久久| 精品一区二区三区三区| 91av在线国产| 欧洲成人免费aa| 97色在线视频观看| 日韩一级裸体免费视频| 国产精品自产拍在线观看中文| 欧美成人免费在线视频| 欧美日韩一区二区三区| 国内精品久久久久久久| 欧美亚洲一级片| 亚洲综合在线小说| 亚洲男人天堂久| 综合av色偷偷网| 亚洲综合在线播放| 日韩国产精品一区| 中国日韩欧美久久久久久久久| 97精品国产97久久久久久| 在线一区二区日韩| 日韩精品中文字幕在线播放| 日韩在线视频免费观看高清中文| 欧美超级乱淫片喷水| 久99九色视频在线观看| 欧美极度另类性三渗透| 午夜精品一区二区三区视频免费看| 国产精品白丝jk喷水视频一区| 2021久久精品国产99国产精品| 麻豆国产va免费精品高清在线| 欧美亚洲视频一区二区| 日韩免费中文字幕| 最好看的2019年中文视频| 国产成人免费91av在线| 日本人成精品视频在线| 亚洲夜晚福利在线观看| 久久这里有精品| 亚洲女人天堂网| 美女国内精品自产拍在线播放| 欧美疯狂做受xxxx高潮| 8090理伦午夜在线电影| 奇米四色中文综合久久| 欧美激情免费在线| 国产精品视频在线播放| 奇米一区二区三区四区久久| 自拍偷拍亚洲精品| 欧美午夜视频在线观看| 姬川优奈aav一区二区| 亚洲精品久久久久中文字幕二区| 亚洲综合一区二区不卡| 在线观看欧美视频| 亚洲国产一区二区三区四区| 日本视频久久久| 精品欧美一区二区三区| 国内精品久久久久久中文字幕| 国产91精品视频在线观看| 欧美精品videossex性护士| 久久久久久久久久国产精品| 91免费人成网站在线观看18| 欧美成人免费视频| 神马国产精品影院av| 国产精品视频久久久久| 久久免费视频这里只有精品| 91久久久久久久| 国产亚洲美女久久| 韩国19禁主播vip福利视频| 亚洲一区二区三区久久| 欧美精品videosex牲欧美| 久久久国产视频91| 国产精品激情自拍| 亚洲精品日韩在线| 亚洲精品国产电影| 国产精品美女久久| 欧美富婆性猛交| 永久555www成人免费| 亚洲精品xxx| 九九热精品视频| 亚洲一区二区日本| 狠狠爱在线视频一区| 亚洲日韩中文字幕在线播放| 国产精品va在线播放我和闺蜜| 日韩电影免费在线观看中文字幕| 成人免费看黄网站| 亚洲欧美日韩国产中文| xxav国产精品美女主播| 久久福利视频导航| 欧美中文字幕视频在线观看| 亚洲成人性视频| 亚洲乱码av中文一区二区| 91理论片午午论夜理片久久| 欧美电影免费观看电视剧大全| 精品久久久久国产| 91国语精品自产拍在线观看性色| 韩国v欧美v日本v亚洲| 久久精品国产96久久久香蕉| 久久久久久亚洲精品|