日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

spring boot實現(xiàn)自動輸出word文檔功能的實例代碼

瀏覽:199日期:2022-06-24 14:20:25

spring boot實現(xiàn)自動輸出word文檔功能

本文用到Apache POI組件組件依賴在pom.xml文件中添加

<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.0</version></dependency><dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>4.1.0</version></dependency>

首先創(chuàng)建相關(guān)的實體類、編寫需要用到的sql查詢。

import lombok.Data;// 選擇題實體@Datapublic class MultiQuestion { private Integer questionId; private String subject; private String section; private String answerA; private String answerB; private String answerC; private String answerD; private String question; private String level; private String rightAnswer; private String analysis; //題目解析 private Integer score; }

import lombok.Data;//填空題實體類@Datapublic class FillQuestion { private Integer questionId; private String subject; private String question; private String answer; private Integer score; private String level; private String section; private String analysis; //題目解析 }

import lombok.Data;//判斷題實體類@Datapublic class JudgeQuestion { private Integer questionId; private String subject; private String question; private String answer; private String level; private String section; private Integer score; private String analysis; //題目解析}

創(chuàng)建好要用到的實體類之后,利用mybatis寫sql查詢,可以分為兩種:1、配置mapper.xml文件路徑,在xml文件中編寫sql語句。2、直接使用注解。本文使用方法為第二種。

@Mapperpublic interface MultiQuestionMapper { /** * select * from multiquestions where questionId in ( * select questionId from papermanage where questionType = 1 and paperId = 1001 * ) */ @Select('select * from multi_question where questionId in (select questionId from paper_manage where questionType = 1 and paperId = #{paperId})') List<MultiQuestion> findByIdAndType(Integer PaperId); @Select('select * from multi_question') IPage<MultiQuestion> findAll(Page page); /** * 查詢最后一條記錄的questionId * @return MultiQuestion */ @Select('select questionId from multi_question order by questionId desc limit 1') MultiQuestion findOnlyQuestionId(); @Options(useGeneratedKeys = true,keyProperty = 'questionId') @Insert('insert into multi_question(subject,question,answerA,answerB,answerC,answerD,rightAnswer,analysis,section,level) ' + 'values(#{subject},#{question},#{answerA},#{answerB},#{answerC},#{answerD},#{rightAnswer},#{analysis},#{section},#{level})') int add(MultiQuestion multiQuestion); @Select('select questionId from multi_question where subject =#{subject} order by rand() desc limit #{pageNo}') List<Integer> findBySubject(String subject,Integer pageNo);}

//填空題@Mapperpublic interface FillQuestionMapper { @Select('select * from fill_question where questionId in (select questionId from paper_manage where questionType = 2 and paperId = #{paperId})') List<FillQuestion> findByIdAndType(Integer paperId); @Select('select * from fill_question') IPage<FillQuestion> findAll(Page page); /** * 查詢最后一條questionId * @return FillQuestion */ @Select('select questionId from fill_question order by questionId desc limit 1') FillQuestion findOnlyQuestionId(); @Options(useGeneratedKeys = true,keyProperty ='questionId' ) @Insert('insert into fill_question(subject,question,answer,analysis,level,section) values ' + '(#{subject,},#{question},#{answer},#{analysis},#{level},#{section})') int add(FillQuestion fillQuestion); @Select('select questionId from fill_question where subject = #{subject} order by rand() desc limit #{pageNo}') List<Integer> findBySubject(String subject,Integer pageNo);}

//判斷題@Mapperpublic interface JudgeQuestionMapper { @Select('select * from judge_question where questionId in (select questionId from paper_manage where questionType = 3 and paperId = #{paperId})') List<JudgeQuestion> findByIdAndType(Integer paperId); @Select('select * from judge_question') IPage<JudgeQuestion> findAll(Page page); /** * 查詢最后一條記錄的questionId * @return JudgeQuestion */ @Select('select questionId from judge_question order by questionId desc limit 1') JudgeQuestion findOnlyQuestionId(); @Insert('insert into judge_question(subject,question,answer,analysis,level,section) values ' + '(#{subject},#{question},#{answer},#{analysis},#{level},#{section})') int add(JudgeQuestion judgeQuestion); @Select('select questionId from judge_question where subject=#{subject} order by rand() desc limit #{pageNo}') List<Integer> findBySubject(String subject,Integer pageNo);}

寫好mapper底層查詢后,需要創(chuàng)建service及其實現(xiàn)類來調(diào)用mapper底層。例如:

public interface JudgeQuestionService { List<JudgeQuestion> findByIdAndType(Integer paperId); IPage<JudgeQuestion> findAll(Page<JudgeQuestion> page); JudgeQuestion findOnlyQuestionId(); int add(JudgeQuestion judgeQuestion); List<Integer> findBySubject(String subject,Integer pageNo);}

@Servicepublic class JudgeQuestionServiceImpl implements JudgeQuestionService { @Autowired private JudgeQuestionMapper judgeQuestionMapper; @Override public List<JudgeQuestion> findByIdAndType(Integer paperId) {return judgeQuestionMapper.findByIdAndType(paperId); } @Override public IPage<JudgeQuestion> findAll(Page<JudgeQuestion> page) {return judgeQuestionMapper.findAll(page); } @Override public JudgeQuestion findOnlyQuestionId() {return judgeQuestionMapper.findOnlyQuestionId(); } @Override public int add(JudgeQuestion judgeQuestion) {return judgeQuestionMapper.add(judgeQuestion); } @Override public List<Integer> findBySubject(String subject, Integer pageNo) {return judgeQuestionMapper.findBySubject(subject,pageNo); }}

最后將輸出文件方法寫在controller層:

@RequestMapping('/exam/exportWord') public void exportWord(int examCode, HttpServletResponse response) throws FileNotFoundException{ //由于題目應(yīng)于考試信息對應(yīng) 所以需要先查出考試信息后根據(jù)pageId來查找對應(yīng)的組卷信息ExamManage res = examManageService.findById(examCode);int paperId = res.getPaperId();List<MultiQuestion> multiQuestionRes = multiQuestionService.findByIdAndType(paperId); //選擇題題庫 1List<FillQuestion> fillQuestionsRes = fillQuestionService.findByIdAndType(paperId); //填空題題庫 2List<JudgeQuestion> judgeQuestionRes = judgeQuestionService.findByIdAndType(paperId);//響應(yīng)到客戶端XWPFDocument document= new XWPFDocument();//分頁XWPFParagraph firstParagraph = document.createParagraph();//格式化段落firstParagraph.getStyleID();XWPFRun run = firstParagraph.createRun();int i = 1;run.setText('一、選擇題' + 'rn'); //換行for (MultiQuestion multiQuestion : multiQuestionRes) { String str = multiQuestion.getQuestion(); String str1 = multiQuestion.getAnswerA(); String str2 = multiQuestion.getAnswerB(); String str3 = multiQuestion.getAnswerC(); String str4 = multiQuestion.getAnswerD(); run.setText(i + '. ' + str + 'rn'); run.setText('A. ' + str1 + 'rn'); run.setText('B. ' + str2 + 'rn'); run.setText('C. ' + str3 + 'rn'); run.setText('D. ' + str4 + 'rn'); i++;}run.setText('二、填空題' + 'rn');for (FillQuestion fillQuestion : fillQuestionsRes) { String str = fillQuestion.getQuestion(); run.setText(i + '. ' + str + 'rn'); i++;}run.setText('三、判斷題' + 'rn');for (JudgeQuestion judgeQuestion : judgeQuestionRes) { String str = judgeQuestion.getQuestion(); run.setText(i + '. ' + str + 'rn'); i++;}document.createTOC();try { //設(shè)置相應(yīng)頭 this.setResponseHeader(response, res.getSource() + '試卷.doc'); //輸出流 OutputStream os = response.getOutputStream(); document.write(os); os.flush(); os.close();} catch (Exception e) { e.printStackTrace();} } /** * 發(fā)送響應(yīng)流方法 */ private void setResponseHeader(HttpServletResponse response, String fileName) {try { try {fileName = URLEncoder.encode(fileName, 'UTF-8'); } catch (UnsupportedEncodingException e) {e.printStackTrace(); } response.setContentType('application/octet-stream;charset=UTF-8'); response.setHeader('Content-Disposition', 'attachment;filename='+ fileName); //遵守緩存規(guī)定 response.addHeader('Pargam', 'no-cache'); response.addHeader('Cache-Control', 'no-cache');} catch (Exception ex) { ex.printStackTrace();} }

效果:

spring boot實現(xiàn)自動輸出word文檔功能的實例代碼

到此這篇關(guān)于spring boot實現(xiàn)自動輸出word文檔功能的文章就介紹到這了,更多相關(guān)spring boot自動輸出word文檔內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: word
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
色综合视频一区二区三区日韩 | 国产欧美日韩在线一区二区| 亚洲精品福利| 久久精品99国产精品日本| 国产精品免费不| 九九久久国产| 久久久人人人| 免费在线观看视频一区| 日韩一区免费| 精品午夜视频| re久久精品视频| 热久久久久久久| 日韩av在线免费观看不卡| 国产精品白丝久久av网站| 色网在线免费观看| 欧美xxxx中国| 亚洲免费激情| 国产欧美日韩综合一区在线播放| 欧美国产偷国产精品三区| 日韩av免费| 免费人成精品欧美精品| 国产精品综合| 久久九九精品| 欧美日韩99| 私拍精品福利视频在线一区| 婷婷丁香综合| 青青青国产精品| 国产福利片在线观看| 一本一本久久| 精品中文在线| 成人自拍av| 视频一区中文字幕精品| 国产一区二区三区不卡av| 99日韩精品| 久久精品国产99国产精品| 亚洲高清久久| 91成人福利| 成人在线免费观看网站| 久久av一区| 精品久久97| 亚洲欧美日韩综合国产aⅴ| 国产精品久久久久av蜜臀| 亚洲国产日韩欧美在线| 美女av一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 日韩精品免费一区二区夜夜嗨 | 欧美日韩免费看片| 日韩三区四区| 亚洲电影在线| 狂野欧美性猛交xxxx| 亚洲免费影视| se01亚洲视频| 国产精品一区二区av日韩在线 | 亚洲精品网址| 亚洲综合专区| 久久天堂成人| 美女视频一区在线观看| 亚洲丝袜啪啪| 三上悠亚国产精品一区二区三区 | 日本久久精品| 国产亚洲一区二区三区啪| 亚洲大全视频| 日韩不卡免费高清视频| 国产日韩亚洲| 每日更新成人在线视频| 免费亚洲一区| 偷拍亚洲精品| 欧美a级一区| 欧美精品1区| 国产亚洲精aa在线看| 亚洲中午字幕| 欧美天堂视频| 精品国产乱码久久久久久1区2匹| 欧美一区在线观看视频| 国产婷婷精品| 亚洲欧美日本国产专区一区| 91看片一区| 亚洲天堂av影院| 粉嫩av一区二区三区四区五区 | 亚洲第一精品影视| 黑森林国产精品av| 欧美交a欧美精品喷水| 国产亚洲人成a在线v网站| 亚洲综合五月| 亚洲一二av| 久久国产精品亚洲77777| 欧美日韩尤物久久| 国产一区二区三区天码| 成人亚洲一区二区| 精品免费av| 福利一区视频| 电影91久久久| 日韩av专区| 国产精品66| 国产精品.xx视频.xxtv| 国产日韩一区二区三区在线播放| 91精品视频一区二区| 日韩有吗在线观看| 亚洲精品系列| 久久国产精品色av免费看| 日本电影久久久| 亚洲欧美日本国产| 日本在线不卡视频| 欧美久久一区二区三区| 国产精品免费大片| 精品亚洲精品| 日韩一区欧美| 狠狠久久婷婷| 亚洲国产不卡| 国产精品日本| 日韩在线卡一卡二| 亚洲青青久久| 日韩高清一区| 久久国内精品视频| 国产精品欧美在线观看| 精品中文字幕一区二区三区四区| 精品国产亚洲一区二区三区大结局| 久久精品九色| 亚洲精品国产嫩草在线观看| 在线视频日韩| 欧美日韩va| 精品91福利视频| 国产在线视频欧美一区| 久久精品国产福利| 日韩中文字幕高清在线观看| 在线国产一区| 亚洲精品成a人ⅴ香蕉片| 欧美日韩午夜电影网| 激情久久一区二区| 尹人成人综合网| 性欧美69xoxoxoxo| 日韩精品导航| 成人国产精品久久| 久久久久蜜桃| 综合在线一区| 色欧美自拍视频| 亚洲大全视频| 国产精品香蕉| 国产精品精品| 久久亚洲视频| 欧美亚洲三级| 激情婷婷久久| 午夜在线精品| 国产日韩欧美在线播放不卡| 日韩欧美另类一区二区| 中文字幕一区二区三区四区久久| 欧美日韩1区2区3区| 中文在线中文资源| 三级欧美在线一区| 精品色999| 一区二区三区四区精品视频| 高清久久一区| 日韩欧美中文字幕一区二区三区| 精品在线网站观看| 成人av二区| 国产成人免费视频网站视频社区| 亚洲激情社区| 国产福利91精品一区二区| 国产精品老牛| 日韩精品1区| 欧美一区91| 日韩亚洲国产欧美| 麻豆精品少妇| 日韩黄色免费网站| 亚洲福利国产| 精品免费在线| 色狠狠一区二区三区| 在线日韩中文| 久久国产欧美日韩精品| 久久视频国产| 里番精品3d一二三区| 蜜桃传媒麻豆第一区在线观看| 色爱综合网欧美| 国产日韩欧美一区在线| 91超碰国产精品| 神马午夜在线视频| 欧美日韩1区| 丝袜亚洲精品中文字幕一区| 少妇精品导航| 精品国产一区二区三区噜噜噜| 亚洲另类黄色| 欧美天堂视频| 欧美精品1区| 99国产一区| 91精品一区国产高清在线gif| 精品视频在线你懂得| 国产精品亚洲欧美日韩一区在线| 亚洲永久字幕| 91精品啪在线观看国产18| 日本不卡中文字幕| 综合欧美亚洲| 极品日韩av| 91精品蜜臀一区二区三区在线| 成人污污视频| 欧美交a欧美精品喷水| 三级欧美韩日大片在线看| 亚洲国产不卡| 99久久夜色精品国产亚洲1000部| 欧美天堂一区| 男女男精品网站|