欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 使用Mongodb實現打卡簽到系統的實例代碼

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

熱門標簽:小裙科技電銷機器人怎樣 智能外呼系統官網 呼和浩特外呼系統原理是什么 長沙電銷外呼防封卡是什么 內蒙古營銷智能外呼系統哪個好 河南電話外呼系統招商 crm外呼系統聯系方式 外呼線路資源屬于電信業務嗎 青白江400企業電話申請

使用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中的數據
  ListAttend> attendList = new ArrayListAttend>(); //讀取文件對象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 ListAttend> 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 HashMapString,Object>(); /** * 已簽到 */ ListAttend> 
complete = attendService.findAllBySign(1);
result.put("complete",complete); /** * 未簽到 */ ListAttend> 
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實現打卡簽到系統內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MongoDB實現基于關鍵詞的文章檢索功能(C#版)
  • 深入了解MongoDB 分布式集群
  • 開源 5 款超好用的數據庫 GUI 帶你玩轉 MongoDB、Redis、SQL 數據庫(推薦)
  • JAVA代碼實現MongoDB動態條件之分頁查詢
  • MongoDB設計方法以及技巧示例詳解
  • MongoDB數據庫基礎操作總結
  • express+mongoose實現對mongodb增刪改查操作詳解
  • win7平臺快速安裝、啟動mongodb的方法
  • 淺析MongoDB 全文檢索

標簽:楚雄 白山 菏澤 呼倫貝爾 黃石 池州 安順 舟山

巨人網絡通訊聲明:本文標題《使用Mongodb實現打卡簽到系統的實例代碼》,本文關鍵詞  使用,Mongodb,實現,打卡,簽到,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用Mongodb實現打卡簽到系統的實例代碼》相關的同類信息!
  • 本頁收集關于使用Mongodb實現打卡簽到系統的實例代碼的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    天涯成人国产亚洲精品一区av| 日韩黄色一区二区| xxxx日本黄色| 精品日韩一区二区| 日本va欧美va瓶| 制服丝袜第二页| 日韩一区二区免费高清| 视频一区视频二区在线观看| 毛茸茸free性熟hd| 欧美一级片在线看| 日韩成人免费看| 大又大又粗又硬又爽少妇毛片 | 在线电影院国产精品| 亚洲一区欧美一区| 亚洲精品激情视频| 日韩免费看网站| 久久av资源网| 人妻无码一区二区三区免费| 国产精品免费免费| www.在线成人| 欧美色大人视频| 亚洲444eee在线观看| 黄色片视频免费观看| 精品第一国产综合精品aⅴ| 国产一区二区三区蝌蚪| 成人免费精品动漫网站| 亚洲色图都市小说| 2025中文字幕| 日韩免费性生活视频播放| 黄页视频在线91| 免费观看特级毛片| 亚洲欧美日韩一区| 日韩av无码一区二区三区不卡| 欧美哺乳videos| 国产精品一线二线三线| 在线视频一区二区免费| 偷窥国产亚洲免费视频| 国产午夜福利一区| 亚洲欧美自拍偷拍| xxxx黄色片| 国产日韩高清在线| 亚洲一区二区三区三州| 日韩午夜激情av| 国产成人三级在线观看| 国产成人精品亚洲777人妖| 国产盗摄一区二区三区在线| 亚洲午夜电影网| 国产黄色大片免费看| 亚洲特级片在线| 国产 中文 字幕 日韩 在线| 国产喂奶挤奶一区二区三区| 91丝袜美女网| 欧美精品一区二区三区一线天视频| 成人免费视频app| 91精品久久久久久久91蜜桃| 国产精品亚洲第一区在线暖暖韩国 | 成人97人人超碰人人99| 7777精品伊人久久久大香线蕉超级流畅| 久久黄色级2电影| 色婷婷激情综合| 蜜臀久久99精品久久久画质超高清| 朝桐光av在线| 日韩av不卡在线观看| 欧美特级一级片| 免费日韩伦理电影| 色一区在线观看| 看电影不卡的网站| 欧美婷婷六月丁香综合色| 国产一区二区不卡在线| 欧美剧在线免费观看网站 | 国产一区欧美日韩| 欧美日韩精品一区二区天天拍小说| 国内成+人亚洲+欧美+综合在线| 在线观看精品一区| 国产麻豆精品视频| 91精品国产手机| 99九九99九九九视频精品| 亚洲精品一区二区三区蜜桃下载 | 日本一区二区三区dvd视频在线| 三级网站免费看| 中文字幕av资源一区| 极品白嫩丰满美女无套| 一区二区欧美国产| 777777国产7777777| 免费看日韩精品| 欧美三级中文字幕在线观看| 国产成人精品三级麻豆| 精品国产乱码久久久久久图片| 国产探花一区二区三区| 黄色av免费播放| 午夜视频在线观看一区二区| 日本高清视频一区二区| 国产成人精品免费网站| www国产精品av| 中文字幕av观看| 亚洲成人黄色影院| 欧美性猛交xxxxxx富婆| 成人白浆超碰人人人人| 国产人伦精品一区二区| 亚洲精品成人无码| 日韩精品电影在线观看| 欧美日韩久久不卡| 成人三级做爰av| 亚洲欧美日韩中文字幕一区二区三区| 制服丨自拍丨欧美丨动漫丨| 精品一区二区三区免费视频| 欧美一区二区三区免费在线看| 香蕉视频免费网站| 亚洲一线二线三线视频| 91福利在线观看| 99re这里只有精品首页| 国产精品国产三级国产普通话99 | 国产日本欧洲亚洲| 1024手机在线观看你懂的| 看电影不卡的网站| 精品国产露脸精彩对白| 色欲av无码一区二区三区| 日本不卡的三区四区五区| 欧美一区二区三区四区五区 | 精东粉嫩av免费一区二区三区| 欧美大胆人体bbbb| 少妇光屁股影院| 久久精品国产在热久久| 精品国产精品一区二区夜夜嗨| 久久久久久亚洲中文字幕无码| 美女视频黄免费的久久| 精品福利在线导航| 欧美老熟妇乱大交xxxxx| 久久精品国产99久久6| 欧美videos中文字幕| 国产男男chinese网站| 青草av.久久免费一区| 精品美女一区二区| 少妇人妻好深好紧精品无码| 国产一区二区三区在线看麻豆 | 精品国产无码在线观看| 蜜臀久久99精品久久久久宅男| 亚洲精品一区二区三区蜜桃下载| 在线观看亚洲大片短视频| 国产一二精品视频| 国产精品每日更新| 欧美最新大片在线看| 国产又黄又嫩又滑又白| 亚洲va欧美va人人爽| 日韩午夜av电影| 色屁屁草草影院ccyy.com| 粉嫩在线一区二区三区视频| 亚洲色图欧洲色图| 欧美美女一区二区在线观看| 国产高清自拍视频| 国产呦萝稀缺另类资源| 国产精品久久毛片| 欧美日韩在线播| 色噜噜日韩精品欧美一区二区| 国产一区在线不卡| 亚洲日本在线a| 5566中文字幕一区二区电影| 久久精品视频18| 国产亚洲精品7777| 一本到三区不卡视频| 无码人妻精品一区二区三| 久久99久久99精品免视看婷婷| 亚洲国产精品激情在线观看| 日本韩国一区二区三区| 成人h动漫精品一区| 国产成人亚洲综合色影视| 亚洲精品五月天| 日韩三区在线观看| 波多野结衣亚洲一区二区| 91传媒理伦片在线观看| 国产在线视频一区二区| 亚洲三级在线免费| 精品日韩一区二区| 色老汉一区二区三区| 午夜理伦三级做爰电影| 波多野结衣在线一区| 日韩电影在线看| 18成人在线观看| 欧美大片顶级少妇| 色综合久久综合| av黄色免费网站| 91在线视频播放地址| 久久99精品国产麻豆婷婷| 亚洲美女在线国产| 久久综合九色综合欧美98| 在线看国产日韩| 欧美性受xxxx黑人| 少妇熟女视频一区二区三区| 激情都市一区二区| 亚洲午夜国产一区99re久久| 国产日产精品一区| 欧美一区二区三区四区高清| 黄色a级片在线观看| aa一级黄色片| 免费高清视频在线观看| 国产精品白丝av| 免费在线视频一区| 一区二区在线免费| 中文一区在线播放| 精品国产sm最大网站免费看|