成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > 使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼

使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼

熱門(mén)標(biāo)簽:小裙科技電銷機(jī)器人怎樣 智能外呼系統(tǒng)官網(wǎng) 呼和浩特外呼系統(tǒng)原理是什么 長(zhǎng)沙電銷外呼防封卡是什么 內(nèi)蒙古營(yíng)銷智能外呼系統(tǒng)哪個(gè)好 河南電話外呼系統(tǒng)招商 crm外呼系統(tǒng)聯(lián)系方式 外呼線路資源屬于電信業(yè)務(wù)嗎 青白江400企業(yè)電話申請(qǐng)

使用excel文件導(dǎo)入數(shù)據(jù),整合mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)

環(huán)境參數(shù)

  • 開(kāi)發(fā)工具:IDEA
  • 基礎(chǔ)環(huán)境:Maven+JDK8
  • 主要技術(shù):SpringBoot、Mongodb
  • SpringBoot版本:2.2.6

實(shí)現(xiàn)步驟如下:

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.實(shí)體層

3.業(yè)務(wù)service層

4. service實(shí)現(xiàn)層

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; } //實(shí)例化對(duì)象列表,用于存儲(chǔ)Excel中的數(shù)據(jù)
  ListAttend> attendList = new ArrayListAttend>(); //讀取文件對(duì)象nameListExcel 中的數(shù)據(jù)(讀取Excel中每一行數(shù)據(jù),存到對(duì)象,存到對(duì)象列表中)
  try { //根據(jù)路徑獲取這個(gè)操作excel的實(shí)例
   HSSFWorkbook wb = new HSSFWorkbook(nameListExcel.getInputStream()); //根據(jù)頁(yè)面index 獲取sheet頁(yè)
   HSSFSheet sheet = wb.getSheetAt(0); HSSFRow row = null; //循環(huán)sesheet頁(yè)中數(shù)據(jù)從第二行開(kāi)始,第一行是標(biāo)題
   for (int i = 1; i  sheet.getPhysicalNumberOfRows(); i++) { //獲取每一行數(shù)據(jù)
    row = sheet.getRow(i); Attend attend = new Attend(); //下面cellnum對(duì)應(yīng)著下標(biāo),id是第一位對(duì)應(yīng)著下標(biāo)為0,name是第二位對(duì)應(yīng)的下標(biāo)為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中的數(shù)據(jù):" + attendList); /** * 如果成功就,寫(xiě)入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)); //局部修改的內(nèi)容
  Update update = new Update(); update.set("sign", 1); //attend 集合名 對(duì)應(yīng)實(shí)體的集合名
  mongoTemplate.updateFirst(query, update, "attend"); return "ok"; } /** * 全查詢學(xué)生信息 * @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)
{ /** * 將名字傳給服務(wù)層,mongodb修改登錄狀態(tài) 
*/ attendService.sign(name); return "ok"; 
} 
/** * 上傳文件 * @param classes * @param nameListExcel * @return 
*/ @PostMapping("/upload") 
public String upload(String classes, MultipartFile nameListExcel)
{
/** * 接收到前臺(tái)傳過(guò)來(lái)的文件對(duì)象,交給service層或者Excel工具類來(lái)解析數(shù)據(jù)
* System.out.println("接收前臺(tái)表單提交數(shù)據(jù):"+classes+nameListExcel);
*/ String result = attendService.upload(classes,nameListExcel);
return result;
} 
/** * 查詢未簽到同學(xué) 和已簽到同學(xué)
* @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的安全認(rèn)證配置

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

默認(rèn)單例配置如下

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

這里使用的是異步實(shí)現(xiàn)的

7.list.html

代碼如下

!DOCTYPE html>
html lang="en">
head>
 meta charset="UTF-8">
 title>考勤管理頁(yè)面/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>導(dǎo)入名單/h3> 班級(jí)名稱: input type="text" name="classes" id="classes"/> 請(qǐng)選擇導(dǎo)入文件 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 () { //初始化頁(yè)面查詢結(jié)果
 $.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(){ //將數(shù)據(jù)打包到formData對(duì)象中
   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("上傳成功,即將刷新頁(yè)面") //刷新當(dāng)前頁(yè)面
 location.reload(); }else { alert("上傳失敗,請(qǐng)重新上傳") } } }); }) }) /script>
/html>

簽到打卡代碼如下:

8.sign-in.html

!DOCTYPE html>
html lang="en">
head>
 meta charset="UTF-8">
 title>簽到頁(yè)面/title>
 script src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js" type="text/javascript" charset="utf-8">/script>
/head>
body> 請(qǐng)輸入你的姓名: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("簽到成功,返回簽到頁(yè)面") //刷新當(dāng)前頁(yè)面
 location.reload(); }else { alert("簽到成功,請(qǐng)重新簽到") } } }); }) }) /script>
/html>

list.html頁(yè)面效果圖

工作表效果圖

遠(yuǎn)程工具查詢剛導(dǎo)入的數(shù)據(jù)如下 數(shù)據(jù)后面有包的路徑是因?yàn)閷?dǎo)入數(shù)據(jù)的時(shí)候沒(méi)有添加mongodb配置類,添加了就沒(méi)有了。

添加配置類之后的效果圖 

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

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

項(xiàng)目已托管碼云

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

總結(jié)

到此這篇關(guān)于使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的文章就介紹到這了,更多相關(guān)使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MongoDB實(shí)現(xiàn)基于關(guān)鍵詞的文章檢索功能(C#版)
  • 深入了解MongoDB 分布式集群
  • 開(kāi)源 5 款超好用的數(shù)據(jù)庫(kù) GUI 帶你玩轉(zhuǎn) MongoDB、Redis、SQL 數(shù)據(jù)庫(kù)(推薦)
  • JAVA代碼實(shí)現(xiàn)MongoDB動(dòng)態(tài)條件之分頁(yè)查詢
  • MongoDB設(shè)計(jì)方法以及技巧示例詳解
  • MongoDB數(shù)據(jù)庫(kù)基礎(chǔ)操作總結(jié)
  • express+mongoose實(shí)現(xiàn)對(duì)mongodb增刪改查操作詳解
  • win7平臺(tái)快速安裝、啟動(dòng)mongodb的方法
  • 淺析MongoDB 全文檢索

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼》,本文關(guān)鍵詞  使用,Mongodb,實(shí)現(xiàn),打卡,簽到,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用Mongodb實(shí)現(xiàn)打卡簽到系統(tǒng)的實(shí)例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    五月亚洲婷婷| 中文字幕日韩av| 午夜精品在线观看| 成视频年人免费看黄网站| 97久久超碰福利国产精品…| 我要看黄色一级片| 亚洲欧美国产制服动漫| 日韩xxxxxxxxx| 成人免费在线观看av| 亚洲一区二区三区视频播放| 加勒比色综合久久久久久久久| 最近中文字幕在线免费观看| 色综合久久久久| 黄色免费看网站| 精品一卡二卡三卡四卡日本乱码| 欧美日韩成人网| 国产天堂在线播放视频| 欧美激情导航| 性欧美video另类hd尤物| 亚洲一区二区蜜桃| 人人妻人人澡人人爽| 三级无遮挡在线观看| 高清欧美电影在线| 熟妇人妻系列aⅴ无码专区友真希| 青青草一区二区| 97人妻精品一区二区三区软件| 少妇丰满尤物大尺度写真| 欧美一区综合| 亚洲av片一区二区三区| 亚洲一级av无码毛片精品| 亚洲精品一区二区三区在线观看| 99re在线视频上| 免费av在线电影| 日韩成人午夜影院| 五月开心播播网| 亚洲国产第一页| 欧美福利一区二区| 天天操天天干天天干| 国产麻豆视频一区二区| 91av一区二区三区| 99热手机在线观看| 秋霞a级毛片在线看| 成年网站视频| 国产成人精品午夜| 国产无套精品一区二区三区| 日本福利专区在线观看| 亚洲图片在线视频| 天天综合永久入口| 日韩精品专区在线影院观看| 国产亚洲美州欧州综合国| 国产高清一区在线观看| 一区二区三区四区五区精品| 国产高清免费在线播放| 欧美黑人性受xxxx精品| 国产传媒一区| 巨乳女教师的诱惑| 亚洲国产欧美一区二区三区久久| 中国毛片在线观看| 天堂av免费看| 91免费看视频| 激情乱色小说视频| 中文字幕亚洲色图| 色狠狠久久av五月综合| 极品白嫩少妇无套内谢| 91高潮大合集爽到抽搐| 欧美激情中文网| 免费在线超碰| 成人影院天天5g天天爽无毒影院| 日韩理伦片在线| 天堂资源在线中文精品| 中文字幕在线中文字幕日亚韩一区| 日韩av电影国产| 欧美日本啪啪无遮挡网站| 天堂网免费视频| 亚洲一区亚洲二区| 国产精品网站在线| 视频国产在线观看| 欧美日韩国产影院| 一区二区三区精品牛牛| 天天操天天干天天操| 久久久成人精品| 天堂8中文在线最新版在线| 亚洲午夜久久久久久久久久久| aaa在线播放视频| av在线天天| 老头吃奶性行交视频| 国产女主播视频一区二区| 18深夜在线观看免费视频| xfplay爱情电影网love| 美女一区二区三区视频| 亚洲成人高清| 中文字幕超碰在线| 免费永久网站黄欧美| 国产中文一区二区三区| 欧美国产日韩在线播放| 奇米4444一区二区三区| 日韩视频免费在线| 精品国精品自拍自在线| 中文字幕精品一区日韩| 欧美亚洲愉拍一区二区| 国产精品乱子乱xxxx| 中文字幕第10页| 久久国产剧场电影| 国产精品资源在线观看| 中文字幕在线看高清电影| 日韩中文字幕网站| 亚洲aⅴ男人的天堂在线观看| 日本中文字幕高清视频| 四虎影院在线域名免费观看| 亚洲高清精品视频| 久久久免费高清视频| 国产无套精品一区二区三区| 亚洲av无码一区东京热久久| 午夜精品久久久久久久99樱桃| 国产精品永久在线| 中文字幕第四页| 黄色成人在线| 国产熟女一区二区三区四区| 日韩av影视大全| 国产一区二区三区在线播放免费观看| 国产精品19p| 免费日韩在线观看| 欧美三级免费看| 久久综合网hezyo| 免费成人美女在线观看| 一区二区三区四区高清精品免费观看| 一区二区三区日韩在线| 精品福利视频一区二区三区| 日韩精品中文字幕一区二区| 欧美乱大交xxxxx潮喷l头像| 91国拍精品国产粉嫩亚洲一区| 成人精品一区二区不卡视频| 中文字幕欧美日本乱码一线二线| 亚洲人在线播放| 久操手机在线视频| 亚洲一区中文在线| a在线欧美一区| 国产亚洲精品bt天堂精选| 91青青国产在线观看精品| 欧美高清视频不卡网| 欧美成欧美va| 精品视频久久久久| 一级黄色大片免费看| 俺去了亚洲欧美日韩| 欧美日韩视频免费在线观看| 日韩欧美激情四射| 亚洲欧美一二三| 国产黄色录像视频| 日韩av中文字幕第一页| 法国空姐电影在线观看| 最近的中文字幕在线看视频| 久草在线视频资源| 老司机午夜精品视频在线观看| 天天操天天摸天天干| 精品三级国产| 少妇高潮久久久| xfplay每日更新av资源| 久久久久久久久丰满| 亚洲午夜一区二区| 欧美午夜精品久久久久久孕妇| 男男成人高潮片免费网站| 精品人伦一区二区色婷婷| 久久久91麻豆精品国产一区| 国产成人va亚洲电影| 一本久道久久综合婷婷鲸鱼| 亚洲美女视频网站| 欧美国产专区| 全球成人中文在线| 欧美激情一区在线| 亚洲综合大片69999| 热re99久久精品国99热蜜月| 香蕉av一区二区三区| 国产精品一二一区| 国产免费黄色大片| 无码精品视频一区二区三区| 亚洲毛片欧洲毛片国产一品色| 日韩欧美高清在线观看| www.1024| 99re成人精品视频| 午夜国产精品视频| 天堂va蜜桃一区二区三区| jizzjizz视频| 日本中文在线播放| 久久久久久久久久久久久久久久久久| 91看片淫黄大片一级| 麻豆精品视频在线观看| 国产美女高潮在线观看| 国产精品99爱免费视频| 最近中文字幕免费| 亚洲free嫩bbb| 中文字幕免费视频| 欧美剧情片在线观看| 美女一区二区视频| 亚洲欧洲无码一区二区三区| 亚洲一卡二卡三卡四卡无卡久久| 亚洲国产精品影院| 国产成人丝袜美腿| 97精品在线视频| 91福利视频免费观看| 国产精品视频无码| 在线天堂www在线国语对白| 国产视频不卡| 欧美亚韩一区二区三区| 亚洲欧美春色| 日韩欧美精品免费在线| 亚洲欧美日韩偷拍| 久久男人中文字幕资源站| 韩国一区二区电影| 亚洲欧洲av另类| 成年人在线观看网站| 久久久久亚洲av无码网站| 欧美成人精品免费| 亚洲伦理久久| 亚洲在线一区二区三区| 日韩av片免费在线观看| 国产激情片在线观看| 久久久影院官网| 亚洲区国产区| 国产一区二区不卡| 成人一区视频| a级大片免费看| 自拍偷拍亚洲在线| 九义人在线观看完整免费版电视剧| 欧美日韩国产高清一区| 青青草av专区| 免费在线成人| 一级片avav网址| 亚洲伦理一区二区| 色婷婷一区二区三区在线观看| 国产成年人在线观看| 中文字幕欧美人妻精品| 欧美日本不卡高清| 男人精品网站一区二区三区| 在线一级成人| 97自拍视频| 国产探花在线免费观看| 欧美激情一区二区| 国产亚洲精品精品精品| 99re6在线观看| 色大师av一区二区三区| 亚洲精品一区二区妖精| 极品魔鬼身材女神啪啪精品| 久久国产精品毛片| 男男视频在线观看网站| 欧美日韩国产精品一区二区不卡中文| 欧美日韩综合一区二区| 色男人天堂av| 黄色三级网站在线观看| 一本久道中文字幕精品亚洲嫩| 久久亚洲午夜电影| 在线观看美女网站大全免费| 国产真实有声精品录音| 日韩av网址在线观看| 国产另类ts人妖一区二区| 翔田千里88av中文字幕| x99av成人免费| 虎白女粉嫩尤物福利视频| 日韩精品最新网址| 性爽视频在线| 日本护士做爰视频| 国产chinesehd精品露脸| 亚欧视频在线观看| 成人动漫在线观看视频| 日韩一区二区免费视频| 亚洲 欧美综合在线网络| 国产精品久久久午夜夜伦鲁鲁| 在线一区二区三区做爰视频网站| 嗯~啊~轻一点视频日本在线观看| www.国产在线观看| 欧美18—19sex性hd| 久久久国产精品午夜一区ai换脸| 欧美大片欧美激情性色a∨久久| 久久亚洲精精品中文字幕| 国产日韩在线免费| 妺妺窝人体色www在线下载| 精品91一区二区三区| 成人免费视频网站在线看| 99久久精品国产亚洲精品| 精品国产不卡| 久久99精品国产一区二区三区| 亚洲国产精品成人综合色在线婷婷| 农村妇女精品一区二区| 欧美激情 亚洲| 国产色综合天天综合网| 成年人免费观看视频网站| 一本在线免费视频| 国产真实乱人偷精品视频| jiujiure精品视频播放| 欧美激情精品久久久六区热门| 天堂网www在线中文天堂| 亚洲欧美另类日本| 国产在线拍揄自揄拍无码视频| 亚洲线精品一区二区三区| 日韩欧美在线播放视频| 午夜影院在线视频| 亚洲桃花岛网站| av资源网在线观看| 一区二区三区四区在线免费观看| 在线黄色免费看| 欧美精品入口蜜桃| 久久久久网站| 偷拍女澡堂一区二区三区| 亚洲综合中文网| 欧美激情成人| 久久久久久久高潮| 亚洲视频999| 欧美精品18videosex性欧美| 中文字幕一区日韩电影| 国产最新精品视频| 一卡二卡三卡视频| 国产精品老熟女视频一区二区| 日韩精品亚洲人成在线观看| 免费黄网站在线播放| 国产一区二区三区在线免费观看| 免费看毛片网站| 久久久久久欧美精品色一二三四| 欧美午夜精品一区二区三区电影| 欧美日韩精品一区二区天天拍小说| 在线观看一区二区精品视频| 91久久偷偷做嫩草影院电| 91中文字幕一区| 亚洲午夜未满十八勿入免费观看全集| 青青九九免费视频在线| aaa在线免费观看| www.久久爱.cn| 插插插亚洲综合网| 性欧美video另类hd3| 日韩中文字幕三区|