编写纳新网站后端的相关知识总结
使用HSSFWorkbook导出数据库中的数据
导入Apache POI Maven jar包
<!-- Apache POI -->
<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.6</version>
</dependency>
在控制层编写表单导出函数
/*** 将数据库里面的报名成员的数据以excel表格的形式打印出来* @param response* @throws IOException*/@RequestMapping(value = "/ExcelDownloads")public void downloadAllMember(HttpServletResponse response) throws IOException {HSSFWorkbook workbook = new HSSFWorkbook();HSSFSheet sheet = workbook.createSheet("信息表");List<Member> memberList = memberService.findAll();//设置要导出的文件的名字String fileName = "member" + ".xls";//新增数据行,并且设置单元格数据int rowNum = 1;//headers表示excel表中第一行的表头String[] headers = { "序号", "姓名", "性别", "学号","电话号码","专业班级","分组意向"};//在excel表中添加表头HSSFRow row = sheet.createRow(0);for(int i=0;i<headers.length;i++){HSSFCell cell = row.createCell(i);HSSFRichTextString text = new HSSFRichTextString(headers[i]);cell.setCellValue(text);}//在表中存放查询到的数据放入对应的列for (Member member : memberList) {HSSFRow row1 = sheet.createRow(rowNum);row1.createCell(0).setCellValue(member.getId());row1.createCell(1).setCellValue(member.getName());row1.createCell(2).setCellValue(member.getSex());row1.createCell(3).setCellValue(member.getNumber());row1.createCell(4).setCellValue(member.getPhone());row1.createCell(5).setCellValue(member.getMajor());row1.createCell(6).setCellValue(member.getIntention());rowNum++;}response.setContentType("application/octet-stream");response.setHeader("Content-disposition", "attachment;filename=" + fileName);response.flushBuffer();workbook.write(response.getOutputStream());}
注意:导出表单的名字不能为中文,否则会出现导出的表单文件无名字的情况
springboot自定义http反馈状态码
这个是前端朋友要求设置的…一开始设置还设置错了,导致并没有起作用…
ResponseEntity :标识整个http相应:状态码、头部信息、响应体内容(spring)
/*** 配置类,判断注册结果的准确与否*/
public class ConfigResult {public static ResponseEntity<Map<String,Object>> success(){Map<String,Object> map = new HashMap<>();map.put("data", "success");map.put("code","200");return new ResponseEntity<>(map, HttpStatus.OK);}public static ResponseEntity<Map<String,Object>> error(){Map<String,Object> map = new HashMap<>();map.put("data", "error");map.put("code","404");return new ResponseEntity<>(map, HttpStatus.NOT_FOUND);}
}
常用HttpStatus状态:
- HttpStatus.OK = 200;
- HttpStatus.BAD_REQUEST = 400;
- HttpStatus.FORBIDDEN = 403;
- HttpStatus.NOT_FOUND = 404;
- HttpStatus.REQUEST_TIMEOUT = 408;
- HttpStatus.SERVICE_UNAVAILABLE =500;
跨域问题
出于安全原因,浏览器禁止Ajax调用驻留在当前原点之外的资源。跨域,指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器对JavaScript施加的安全限制。
所谓同源是指,域名,协议,端口均相同,不明白没关系,举个栗子:
http://www.123.com/index.html 调用 http://www.123.com/service.PHP (非跨域)
http://www.123.com/index.html 调用 http://www.456.com/service.php (主域名不同:123/456,跨域)
http://abc.123.com/index.html 调用 http://def.123.com/service.php(子域名不同:abc/def,跨域)
http://www.123.com:8080/index.html调用 http://www.123.com:8081/sevice.php(端口不同:8080/8088,跨域)
http://www.123.com/index.html 调用 https://www.123.com/service.php(协议不同:http/https,跨域)
请注意:localhost和127.0.0.1虽然都指向本机,但也属于跨域。
浏览器执行javascript脚本时,会检查这个脚本属于哪个页面,如果不是同源页面,就不会被执行。
@CrossOrigin注解最简单的使用方法,直接加在@RestController前面,如下图:
注意:springMVC的版本要在4.2或以上版本才支持@CrossOrigin
关于主键自增(@GeneratedValue注解)
使用了@GeneratedValue 注解使得主键由数据库自己增长,如果不设置这个的话,即使数据库已经设置了主键递增,但还是会报错(实际上数据库并没有执行主键递增操作)。
springboot中@GeneratedValue作用:
(1)@GeneratedValue注解存在的意义主要就是为一个实体生成一个唯一标识的主键,@GeneratedValue提供了主键的生成策略;
(2)@GeneratedValue注解有两个属性,分别是strategy和generator。
strategy属性:提供四种值:
-AUTO主键由程序控制, 是默认选项 ,不设置就是这个-IDENTITY 主键由数据库生成, 采用数据库自增长, Oracle不支持这种方式-SEQUENCE 通过数据库的序列产生主键, MYSQL 不支持-Table 提供特定的数据库产生主键, 该方式更有利于数据库的移植
使用方法如下图:
相关文章:

IOSUIcontrol事件
UIKit提供了一组控件:UISwitch开关、UIButton按钮、UISegmentedControl分段控件、UISlider滑块、UITextField文本字段控件、UIPageControl分页控件。 控件是对UIView派生类的实用增强及补充,并可以直接附着于导航栏、表格单元,甚至更大的对象…

Xcode Debugging
程序员日常开发中有大量时间都会花费在 debug 上,从事 iOS 开发不可避免地需要使用 Xcode。这篇博客就主要介绍了 Xcode 中几种能够大幅提升代码调试效率的方式。“If debugging is the process of removing bugs, then programming must be the process of putting…

css小技巧 -- 单标签实现单行文字居中,多行文字居左
可能出现的尺寸场景: 代码如下: <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv&q…

Unity游戏开发大师班
大小解压后:8.63G 持续时间19h 包含项目文件 1280X720 MP4 语言:英语中英文字幕(根据原英文字幕机译更准确) Unity游戏开发大师班 信息: 要求 –没有课程要求,展示了开发过程的每一步(包括解释的每一行代码) 这门课…

GC处理的分析
GC处理的深入分析 在Java中针对垃圾收集也提供了多种不同的处理分类 1.引用计数: 一个实例化对象,如果有程序使用了这个引用对象,引用计数加一,当一个对象使用完毕,引用计数减一,当引用计数为0时&#x…

2016.1.20 dubbo启动之后机器ip有问题
环境 100.0.4.222 zookerper 2182 100.0.4.221 dubbo 20871 1.问题 dubbo 对应的机器ip 是202.106.199.37 不是100.0.4.221 2.解决 说明 主机名有问题 修改主机名 使之生效 重启zookeeper服务 和dubbo服务 搞定 转载于:https://www.cnblogs.com/huawei306/p…

在Eclipse或MyEclipse中安装findbugs插件
2019独角兽企业重金招聘Python工程师标准>>> 我们都知道,在Eclipse或MyEclipse中安装插件有两种方式,一种是在线安装,第二种是先下载插件然后在本地安装。 在这里我们先介绍第一种在线安装。 Eclipse上在线安装findbugs(具体步骤如…

Jboss解决只能通过localhost访问而不能使用IP访问项目的问题
jboss的配置文件,如 E:\downloadChrome\wildfly-10.1.0.Final\standalone\configuration\shandalone.xml <interfaces> <interface name"management"> <inet-address value"${jboss.bind.address.management:127.0.0.1}"/>…

一.JDBC概述
第1章:JDBC概述 1.1 数据的持久化 持久化(persistence):把数据保存到可掉电式存储设备中以供之后使用。大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以”固化”,而持久化的实现过程大…

在Blender中创建惊人的低多边形动画
大小解压后:13.5G 持续时间10小时 包括项目文件 1920X1080 MP4 语言:英语中英文字幕(根据原英文字幕机译更准确) 标题:CGBoost学院–立方体世界在Blender中创建惊人的低多边形动画 信息: 创建漂亮的3D动画,就像玩乐高…

开发Eclipse自定义控件
摘自:http://www.ibm.com/developerworks/cn/opensource/os-eclipcntl/ 我们在开发自定义控件时主要考虑以下问题: 1、 自定义控件的绘制:通常我们需要自己对控件的形状或图案进行绘制; 2、 控件对键盘事件的响应:当焦…

小米手机无法连接eclipse调试案例
按照参考博客2的方法 小米2S手机在Eclipse真机调试时,设备选择列表无法显示手机,DDMS也连接不上设备,解决步骤: 1.打开手机设置中开发者选项 - USB调试开启; 2.保证小米2S手机Windows下设备驱动已安装,可…

手机号码格式验证和 FASTDFS 工具类
常见大陆和香港号码格式验证 import java.util.regex.Matcher; import java.util.regex.Pattern; import java.util.regex.PatternSyntaxException;public class PhoneFormatCheckUtils {// 大陆号码或香港号码均可public static boolean isPhoneLegal(String str) throws Patt…

Maya摄像机动画技能学习教程
MP4 |视频:h264,1280720 |音频:AAC,44.1 KHz,2 Ch 语言:英语中英文字幕(根据原英文字幕机译更准确) |时长:4h 38m |大小解压后:1.65 GB 含课程文件 Maya的相机工具是所有3D包中最好的。在本课程中&#x…

前端解决跨域问题的8种方案(最新最全)
.同源策略如下: URL说明是否允许通信http://www.a.com/a.jshttp://www.a.com/b.js同一域名下允许http://www.a.com/lab/a.jshttp://www.a.com/script/b.js同一域名下不同文件夹允许http://www.a.com:8000/a.jshttp://www.a.com/b.js同一域名,不同端口不允…

IDEA中修改文件的默认创建方式
今天很手欠地在创建application-dev.yml文件的时候将application-dev这个名字的文件成功变成了一个我不认识的文件打开方式了,如下图: 可以看到,这个application-dev.yml文件从原来的SpringBoot的配置文件变成一个我们不认识的文件格式… 补…

ArcEngine 直连连接SDE
关键代码IPropertySet pPropertySet new PropertySetClass();pPropertySet.SetProperty("SERVER", sde.IpAdress);pPropertySet.SetProperty("INSTANCE", "sde:oracle11g$//" sde.IpAdress "/" sde.Instance); pPrope…

Dubbo和Spring Cloud微服务架构对比
一、为什么要使用微服务? 微服务提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合。 今天我们来了解下业内主要的微服务框架:Dubbo 和 Spring Cloud 微服务主要的优势 降低复杂度将原来耦合在一起的复杂业务拆分为单个服务,…

Unity 3D为策略游戏创建地图学习教程
MP4 |视频:h264,1280720 |音频:AAC,44.1 KHz,2 Ch 语言:英语中英文字幕(根据原英文字幕机译更准确) |时长:30节课(7h 42m) |大小:5 GB 含项目文件 沿着曲线、高程图和数据结构移动对象 你会学到: Unity&…

Lambda表达式(简单解析)
Lambda表达式 Lambda表达式其实是JDK8的一个新特性。所谓Lambda表达式指的是应用在单一抽象方法接口环境下的一种简化定义形式,可以用于解决匿名内部类中定义复杂的问题。 我们先来看一段代码,如下: interface Customer{public void print(…

YTU 2899: D-险恶逃生 I
2899: D-险恶逃生 I 时间限制: 1 Sec 内存限制: 128 MB提交: 130 解决: 55题目描述 Koha被邪恶的巫师困在一个m*n的矩阵当中,他被放在了矩阵的最左上角坐标(0,0)处,而唯一的出口在矩阵最右下角坐标(m-1,n-1)处,他每次只能向右或者向下移动一…

2021-2027年中国托育服务行业市场研究及前瞻分析报告
【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新(交付时间约3个工作日) 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国托育服务行业市场行业相关概述、中国托育服务行业市场行业运行环境、分析了中国托育服务行…
2021全国高校计算机能力挑战赛(初赛)Java试题一
从大于等于N 的正整数里找到一个最小的数M,使之满足:M和M的逆序数(如1230的逆序数为321)的和为一个[100000,200000]区间内的值。 import java.util.Scanner; public class Main {public static void main(String[] args){Scanner scanner new Scanner(System.in);int N scann…

Blender写实产品创作学习教程
Blender中的现实产品创作 Realistic Product Creation in Blender MP4 |视频:h264,1280720 |音频:AAC,44.1 KHz,2 Ch 语言:英语中英文字幕(根据原英文字幕机译更准确)|时长:71节课(6小时30分钟)|大小解压…

试题 入门训练 Fibonacci数列(Java)
题目: 一开始我看到这题目其实觉得挺简单的,第一次简单写了一个循环就提交上去了,结果… 我意识到这是因为超过long类型的最大范围导致的,所以第二次换成BigInteger大整数类型,但最后一个测试点超时了… 通过百度…

翻译BonoboService官网的安装教程
This page covers simple Bonobo Git Server installation. Be sure to check prerequisites page before installation and for other sections visit the documentation page. 此页包括简单的Bonobo Git 服务安装。在安装和查看文档页之前要先查看系统要求页。 The following…

2021-2027年中国涂装行业市场需求预测与投资战略规划分析报告
【报告类型】产业研究 【报告价格】4500起 【出版时间】即时更新(交付时间约3个工作日) 【发布机构】智研瞻产业研究院 【报告格式】PDF版 本报告介绍了中国涂装行业市场行业相关概述、中国涂装行业市场行业运行环境、分析了中国涂装行业市场行业的…

【SICP练习】84 练习2.56
这道题的代码略长啊。不过我也是因此而知道Edwin上的代码居然可以复制到word上,以前还想当然的以为不能复制的,毕竟在Edwin上粘贴用的CtrlY,而不是CtrlV。在这里我就只将书上没有的代码贴出来了。 (define (deriv exp var)(cond ((number? e…
2021全国高校计算机能力挑战赛(初赛)Java试题二
某地大数据防疫平台记录了往来的所有防疫相关信息,包括本地或外地人员、健康码颜色、接种疫苗情况、最近一次核酸结果等 import java.util.ArrayList; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner new …

Zbrush2021写实人物肖像雕刻学习教程
Zbrush 2021写实人物肖像雕刻学习教程 Zbrush 2021 Character Likeness Sculpting Tutorial 大小解压后:24G 持续时间32h 1280X720 MP4 语言:英语中英文字幕(根据原英文字幕机译更准确) 标题:Udemy–Zbrush 2021人物肖像雕刻教程…