From f4e156185d24a4dbfee55819e4124819cb2f9e75 Mon Sep 17 00:00:00 2001 From: Saturneric Date: Wed, 19 Feb 2020 02:22:25 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E5=9F=BA=E6=9C=AC=E8=A1=A8?= =?UTF-8?q?=E7=BB=93=E6=9E=84=E6=95=B0=E6=8D=AE=E5=AF=BC=E5=85=A5=E6=94=AF?= =?UTF-8?q?=E6=8C=81;=E7=BC=96=E5=86=99=E5=B9=B6=E6=B5=8B=E8=AF=95Excel?= =?UTF-8?q?=E8=A1=A8=E6=A0=BC=E5=AF=BC=E5=85=A5=E5=AF=BC=E5=87=BA=E5=99=A8?= =?UTF-8?q?;=E6=B7=BB=E5=8A=A0WEB-INF=E6=96=87=E4=BB=B6=E5=A4=B9;?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../datamanager/DataExcelGenerator.java | 84 +++++++++++++ .../datamanager/DataExcelReader.java | 119 ++++++++++++++++++ .../component/datamanager/DataGenerator.java | 17 +++ .../DataModelRepositorySearcher.java | 3 +- .../datamanager/DataModelSearcher.java | 2 +- .../ase/component/datamanager/DataReader.java | 27 ++++ .../ase/component/datamanager/DataTable.java | 61 +++++++++ .../component/datamanager/DataTableRow.java | 21 ++++ .../exception/DataFileNotFoundException.java | 15 +++ .../ase/exception/DataIOException.java | 9 ++ .../DataIllegalTableFormatException.java | 9 ++ .../exception/DataInvalidFormatException.java | 15 +++ ...DataReaderRowIndexOutOfRangeException.java | 9 ++ .../codesdream/ase/service/IUserService.java | 3 + .../codesdream/ase/service/UserService.java | 6 + .../codesdream/ase/test/DataManagerTest.java | 47 ------- src/main/resources/base_political_status.sql | 14 +++ src/main/resources/data_base_college.sql | 25 ++++ src/main/webapp/WEB-INF/web.xml | 6 + .../com/codesdream/ase/DataManagerTest.java | 108 ++++++++++++++++ .../java/com/codesdream/ase}/UserTest.java | 2 +- 21 files changed, 551 insertions(+), 51 deletions(-) create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataExcelGenerator.java create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataExcelReader.java create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataGenerator.java create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataReader.java create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataTable.java create mode 100644 src/main/java/com/codesdream/ase/component/datamanager/DataTableRow.java create mode 100644 src/main/java/com/codesdream/ase/exception/DataFileNotFoundException.java create mode 100644 src/main/java/com/codesdream/ase/exception/DataIOException.java create mode 100644 src/main/java/com/codesdream/ase/exception/DataIllegalTableFormatException.java create mode 100644 src/main/java/com/codesdream/ase/exception/DataInvalidFormatException.java create mode 100644 src/main/java/com/codesdream/ase/exception/DataReaderRowIndexOutOfRangeException.java delete mode 100644 src/main/java/com/codesdream/ase/test/DataManagerTest.java create mode 100644 src/main/resources/base_political_status.sql create mode 100644 src/main/webapp/WEB-INF/web.xml create mode 100644 src/test/java/com/codesdream/ase/DataManagerTest.java rename src/{main/java/com/codesdream/ase/test => test/java/com/codesdream/ase}/UserTest.java (98%) diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataExcelGenerator.java b/src/main/java/com/codesdream/ase/component/datamanager/DataExcelGenerator.java new file mode 100644 index 0000000..1ca17b2 --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataExcelGenerator.java @@ -0,0 +1,84 @@ +package com.codesdream.ase.component.datamanager; + +import com.codesdream.ase.exception.DataFileNotFoundException; +import com.codesdream.ase.exception.DataIOException; +import org.apache.poi.ss.usermodel.Row; +import org.apache.poi.ss.usermodel.Sheet; +import org.apache.poi.ss.usermodel.Workbook; +import org.apache.poi.xssf.usermodel.XSSFWorkbook; + +import java.io.FileNotFoundException; +import java.io.FileOutputStream; +import java.io.IOException; +import java.util.ArrayList; +import java.util.Collection; + +/** + * 利用数据生成Excel文件 + */ +public class DataExcelGenerator implements DataGenerator { + Workbook workbook = new XSSFWorkbook(); + + Sheet sheet; + Integer colNumber; + String path; + + public DataExcelGenerator(String path) { + sheet = workbook.createSheet("Data"); + this.path = path; + } + + public void setTableTitle(Collection titles){ + Row sheetRow = sheet.createRow(0); + int idx = 0; + for(String title : titles){ + sheetRow.createCell(idx).setCellValue(title); + idx++; + } + colNumber = titles.size(); + } + + public void insertRow(int rowIndex, Collection dataCollection){ + Row row = sheet.createRow(rowIndex); + int idx = 0; + for(String data : dataCollection){ + // 限制表头与表体的数据数目 + if(idx >= colNumber) break; + row.createCell(idx).setCellValue(data); + idx++; + } + } + + public void insertRow(Collection dataCollection){ + insertRow(sheet.getLastRowNum() + 1, dataCollection); + + } + + public void insertRowDataALL(Collection dataCollections){ + int cellIdx = 0; + Collection dataCollection = new ArrayList<>(); + for(String dataCollectionItem :dataCollections){ + dataCollection.add(dataCollectionItem); + cellIdx++; + if(cellIdx % colNumber == 0) { + insertRow(dataCollection); + dataCollection.clear(); + cellIdx = 0; + } + + } + } + + + public void save() { + try { + FileOutputStream stream = new FileOutputStream(path, false); + workbook.write(stream); + stream.close(); + } catch (FileNotFoundException e) { + throw new DataFileNotFoundException(path); + } catch (IOException e) { + throw new DataIOException(); + } + } +} diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataExcelReader.java b/src/main/java/com/codesdream/ase/component/datamanager/DataExcelReader.java new file mode 100644 index 0000000..ae2e2e6 --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataExcelReader.java @@ -0,0 +1,119 @@ +package com.codesdream.ase.component.datamanager; + + +import com.codesdream.ase.exception.*; +import org.apache.poi.openxml4j.exceptions.InvalidFormatException; +import org.apache.poi.ss.usermodel.*; + +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.IOException; +import java.util.ArrayList; +import java.util.Collection; + +/** + * 读取简单表格式的Excel文件 + */ +public class DataExcelReader implements DataReader { + Workbook workbook = null; + Sheet sheet = null; + short colNumber = 0; + int rowNumberNow = 0; + String path; + boolean hasReadFile = false; + + public DataExcelReader(String path){ + this.path = path; + readFile(); + } + + public void readFile(){ + if(hasReadFile) return; + try{ + FileInputStream fileInputStream = new FileInputStream(path); + workbook = WorkbookFactory.create(fileInputStream); + sheet = workbook.getSheetAt(0); + fileInputStream.close(); + } catch (FileNotFoundException e) { + throw new DataFileNotFoundException(path); + } catch (InvalidFormatException e) { + throw new DataInvalidFormatException(e); + } catch (IOException e) { + throw new DataIOException(); + } + } + + public Collection readColsTitle(){ + Row titleRow = sheet.getRow(0); + colNumber = titleRow.getLastCellNum(); + // 表头项目个数不可为0 + if(colNumber == 0) throw new DataIllegalTableFormatException(); + Collection title = new ArrayList<>(); + for(int cellIdx = 0; cellIdx < colNumber; cellIdx++){ + title.add(readCell(titleRow.getCell(cellIdx))); + } + return title; + } + + public Collection readRow(int idx){ + // 检查是否获取表头数据 + if(this.colNumber == 0) readColsTitle(); + if(idx > getRowsSize()) throw new DataReaderRowIndexOutOfRangeException(); + this.rowNumberNow = idx; + Collection data = new ArrayList<>(); + Row dataRow = sheet.getRow(rowNumberNow); + // 检查列数是否合适 + if(dataRow.getLastCellNum() > colNumber) throw new DataIllegalTableFormatException(); + for(int cellIdx = 0; cellIdx < colNumber; cellIdx++){ + data.add(readCell(dataRow.getCell(cellIdx))); + } + return data; + } + + @Override + public int getRowsSize() { + return lastDataRowIndex() - firstDataRowIndex(); + } + + @Override + public int firstDataRowIndex() { + return 1; + } + + @Override + public int lastDataRowIndex() { + return sheet.getLastRowNum(); + } + + public Collection readRow(){ + if(rowNumberNow >= getRowsSize()) return null; + return readRow(rowNumberNow + 1); + } + + private String readCell(Cell cell){ + String cellValue = ""; + switch (cell.getCellType()) { + case Cell.CELL_TYPE_STRING: + cellValue = cell.getRichStringCellValue().getString(); + break; + case Cell.CELL_TYPE_NUMERIC: + if (DateUtil.isCellDateFormatted(cell)) { + cellValue = cell.getDateCellValue().toString(); + } else { + cellValue = String.valueOf(cell.getNumericCellValue()); + } + break; + case Cell.CELL_TYPE_BOOLEAN: + cellValue = String.valueOf(cell.getBooleanCellValue()); + break; + case Cell.CELL_TYPE_FORMULA: + cellValue = String.valueOf(cell.getCellFormula()); + break; + case Cell.CELL_TYPE_BLANK: + break; + default: + } + return cellValue; + } + +} diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataGenerator.java b/src/main/java/com/codesdream/ase/component/datamanager/DataGenerator.java new file mode 100644 index 0000000..4a9f061 --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataGenerator.java @@ -0,0 +1,17 @@ +package com.codesdream.ase.component.datamanager; + +import java.util.Collection; + +/** + * 表给狗数据文件生成器接口 + */ +public interface DataGenerator { + // 读取表头信息 + void setTableTitle(Collection titles); + + // 向表中写入一行数据 + void insertRow(int rowIndex, Collection dataCollection); + + // 将修改保存表到文件中 + void save(); +} diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataModelRepositorySearcher.java b/src/main/java/com/codesdream/ase/component/datamanager/DataModelRepositorySearcher.java index c3b9c63..3844039 100644 --- a/src/main/java/com/codesdream/ase/component/datamanager/DataModelRepositorySearcher.java +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataModelRepositorySearcher.java @@ -8,7 +8,7 @@ import org.springframework.stereotype.Component; import javax.annotation.Resource; /** - * DataModel对应Repository层查询器 + * Model对应的Repository层查询器 */ @Data @Component @@ -43,7 +43,6 @@ public class DataModelRepositorySearcher { return null; } - public static String doCheckName(String string) { char[] charArray = string.toCharArray(); if(Character.isLowerCase(charArray[0])) charArray[0] -= 32; diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataModelSearcher.java b/src/main/java/com/codesdream/ase/component/datamanager/DataModelSearcher.java index d4c7925..0493d1c 100644 --- a/src/main/java/com/codesdream/ase/component/datamanager/DataModelSearcher.java +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataModelSearcher.java @@ -10,7 +10,7 @@ import java.util.ArrayList; import java.util.Collection; /** - * 根据子系统及名称查找特定的Data Model + * 根据子系统及名称查找特定的MModel */ @Data @Component diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataReader.java b/src/main/java/com/codesdream/ase/component/datamanager/DataReader.java new file mode 100644 index 0000000..4b9dd21 --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataReader.java @@ -0,0 +1,27 @@ +package com.codesdream.ase.component.datamanager; + +import java.util.Collection; + +/** + * 表结构信息读取器接口 + */ +public interface DataReader { + // 从文件中读取数据(在使用上要求这个调用可有可无) + void readFile(); + + // 获得表头列的数目 + Collection readColsTitle(); + + // 读取特定序号的行的数据 + Collection readRow(int row); + + // 得到数据的总行数 + int getRowsSize(); + + // 得到第一数据行的序号 + int firstDataRowIndex(); + + // 得到最后一行数据行的序号 + int lastDataRowIndex(); + +} diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataTable.java b/src/main/java/com/codesdream/ase/component/datamanager/DataTable.java new file mode 100644 index 0000000..8e6eb1b --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataTable.java @@ -0,0 +1,61 @@ +package com.codesdream.ase.component.datamanager; + +import com.codesdream.ase.exception.DataIllegalTableFormatException; +import org.springframework.context.annotation.Scope; +import org.springframework.stereotype.Component; + +import java.util.*; + +// 描述一张数据表 +@Component +@Scope("prototype") +public class DataTable { + Collection titleCollection = new ArrayList<>(); + Vector dataRows = new Vector<>(); + + // 为表添加列及列名 + public DataTable addColTitle(String title){ + titleCollection.add(title); + return this; + } + + // 获得特定行的数据 + public Collection getRow(int index){ + return dataRows.elementAt(index).getRow(); + } + + // 从DataReader导入特定表 + public void ImportTable(DataReader reader){ + // 从文件中读取数据 + reader.readFile(); + // 读取列信息 + titleCollection = reader.readColsTitle(); + + int rowsSize = reader.getRowsSize(); + int index = 0; + for(int i = reader.firstDataRowIndex(); i < reader.lastDataRowIndex(); i++){ + dataRows.add(new DataTableRow(index++, reader.readRow(i))); + // 检查是否列数一致 + if(dataRows.lastElement().getColsSize() != this.getColsSize()) { + // 清空表数据 + this.dataRows.clear(); + throw new DataIllegalTableFormatException(); + } + } + } + + // 为表添加行 + public void addRow(Collection row){ + dataRows.add(new DataTableRow(dataRows.size() + 1, row)); + } + + // 获得表的列数 + public int getColsSize(){ + return titleCollection.size(); + } + + // 获得表的行数 + public int getRowsSize(){ + return dataRows.size(); + } +} diff --git a/src/main/java/com/codesdream/ase/component/datamanager/DataTableRow.java b/src/main/java/com/codesdream/ase/component/datamanager/DataTableRow.java new file mode 100644 index 0000000..9e68b1a --- /dev/null +++ b/src/main/java/com/codesdream/ase/component/datamanager/DataTableRow.java @@ -0,0 +1,21 @@ +package com.codesdream.ase.component.datamanager; + +import lombok.Data; + +import java.util.Collection; + +// 描述数据表的行 +@Data +public class DataTableRow { + int index; + Collection row; + + public DataTableRow(int index, Collection row){ + this.index = index; + this.row = row; + } + + public int getColsSize(){ + return row.size(); + } +} diff --git a/src/main/java/com/codesdream/ase/exception/DataFileNotFoundException.java b/src/main/java/com/codesdream/ase/exception/DataFileNotFoundException.java new file mode 100644 index 0000000..c85958a --- /dev/null +++ b/src/main/java/com/codesdream/ase/exception/DataFileNotFoundException.java @@ -0,0 +1,15 @@ +package com.codesdream.ase.exception; + +import lombok.Data; +import lombok.EqualsAndHashCode; + +@EqualsAndHashCode(callSuper = true) +@Data +public class DataFileNotFoundException extends RuntimeException { + private String path; + + public DataFileNotFoundException(String filePath){ + super(); + this.path = filePath; + } +} diff --git a/src/main/java/com/codesdream/ase/exception/DataIOException.java b/src/main/java/com/codesdream/ase/exception/DataIOException.java new file mode 100644 index 0000000..f220cac --- /dev/null +++ b/src/main/java/com/codesdream/ase/exception/DataIOException.java @@ -0,0 +1,9 @@ +package com.codesdream.ase.exception; + +import lombok.Data; +import lombok.EqualsAndHashCode; + +@EqualsAndHashCode(callSuper = true) +@Data +public class DataIOException extends RuntimeException { +} diff --git a/src/main/java/com/codesdream/ase/exception/DataIllegalTableFormatException.java b/src/main/java/com/codesdream/ase/exception/DataIllegalTableFormatException.java new file mode 100644 index 0000000..5c01b8c --- /dev/null +++ b/src/main/java/com/codesdream/ase/exception/DataIllegalTableFormatException.java @@ -0,0 +1,9 @@ +package com.codesdream.ase.exception; + +import lombok.Data; +import lombok.EqualsAndHashCode; + +@EqualsAndHashCode(callSuper = true) +@Data +public class DataIllegalTableFormatException extends RuntimeException { +} diff --git a/src/main/java/com/codesdream/ase/exception/DataInvalidFormatException.java b/src/main/java/com/codesdream/ase/exception/DataInvalidFormatException.java new file mode 100644 index 0000000..e06394f --- /dev/null +++ b/src/main/java/com/codesdream/ase/exception/DataInvalidFormatException.java @@ -0,0 +1,15 @@ +package com.codesdream.ase.exception; + +import lombok.Data; +import lombok.EqualsAndHashCode; + +@EqualsAndHashCode(callSuper = true) +@Data +public class DataInvalidFormatException extends RuntimeException { + String information; + + public DataInvalidFormatException(Exception e){ + super(); + information = e.getMessage(); + } +} diff --git a/src/main/java/com/codesdream/ase/exception/DataReaderRowIndexOutOfRangeException.java b/src/main/java/com/codesdream/ase/exception/DataReaderRowIndexOutOfRangeException.java new file mode 100644 index 0000000..fb004a4 --- /dev/null +++ b/src/main/java/com/codesdream/ase/exception/DataReaderRowIndexOutOfRangeException.java @@ -0,0 +1,9 @@ +package com.codesdream.ase.exception; + +import lombok.Data; +import lombok.EqualsAndHashCode; + +@EqualsAndHashCode(callSuper = true) +@Data +public class DataReaderRowIndexOutOfRangeException extends RuntimeException { +} diff --git a/src/main/java/com/codesdream/ase/service/IUserService.java b/src/main/java/com/codesdream/ase/service/IUserService.java index 277d413..1759447 100644 --- a/src/main/java/com/codesdream/ase/service/IUserService.java +++ b/src/main/java/com/codesdream/ase/service/IUserService.java @@ -31,6 +31,9 @@ public interface IUserService { // 根据学号生成随机用户名 void generateRandomUsernameByStudentID(User user, String id); + // 随机生成一个用户名 + void generateRandomUsername(User user); + // 注册用户 User save(User user); diff --git a/src/main/java/com/codesdream/ase/service/UserService.java b/src/main/java/com/codesdream/ase/service/UserService.java index 3d09ea8..390b383 100644 --- a/src/main/java/com/codesdream/ase/service/UserService.java +++ b/src/main/java/com/codesdream/ase/service/UserService.java @@ -17,6 +17,7 @@ import javax.annotation.Resource; import java.util.Collection; import java.util.List; import java.util.Optional; +import java.util.UUID; @Service public class UserService implements IUserService { @@ -72,6 +73,11 @@ public class UserService implements IUserService { user.setUsername(usernameEncoder.encode(id)); } + @Override + public void generateRandomUsername(User user) { + user.setUsername(usernameEncoder.encode(UUID.randomUUID().toString())); + } + @Override public User save(User user) { // 查找用户名是否已经被注册 diff --git a/src/main/java/com/codesdream/ase/test/DataManagerTest.java b/src/main/java/com/codesdream/ase/test/DataManagerTest.java deleted file mode 100644 index 09c9353..0000000 --- a/src/main/java/com/codesdream/ase/test/DataManagerTest.java +++ /dev/null @@ -1,47 +0,0 @@ -package com.codesdream.ase.test; - -import com.codesdream.ase.component.ASESpringUtil; -import com.codesdream.ase.component.datamanager.DataModelRepositorySearcher; -import com.codesdream.ase.component.datamanager.DataModelSearcher; -import com.codesdream.ase.repository.permission.UserRepository; -import org.junit.Assert; -import org.junit.Test; -import org.junit.runner.RunWith; -import org.springframework.boot.test.context.SpringBootTest; -import org.springframework.test.context.junit4.SpringRunner; - -import javax.annotation.Resource; - -/** - * 测试DataModel相关查找器 - */ -@RunWith(SpringRunner.class) -@SpringBootTest -public class DataManagerTest { - @Resource - ASESpringUtil springUtil; - - @Test - public void dataModelSearcherTest() { - DataModelSearcher dataModelSearcher = springUtil.getBean(DataModelSearcher.class); - dataModelSearcher.getDataModelClass("permission", "Tag"); - Assert.assertTrue(dataModelSearcher.isPresent()); - - for(String param : dataModelSearcher.getDataModelParamArgs()){ - System.out.println(param); - } - - } - - @Test - public void dataModelRepositorySearcherTest(){ - DataModelRepositorySearcher dataModelRepositorySearcher = - springUtil.getBean(DataModelRepositorySearcher.class); - - dataModelRepositorySearcher.getDataModelRepositoryClass("permission", "User"); - Assert.assertTrue(dataModelRepositorySearcher.isPresent()); - UserRepository userRepository = dataModelRepositorySearcher.getDataModelRepositoryInstance(); - - } - -} diff --git a/src/main/resources/base_political_status.sql b/src/main/resources/base_political_status.sql new file mode 100644 index 0000000..bba8879 --- /dev/null +++ b/src/main/resources/base_political_status.sql @@ -0,0 +1,14 @@ +INSERT INTO `base_political_status`(`id`, `name`) VALUES (0, '----'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (1, '中共党员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (2, '中共预备党员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (3, '共青团员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (4, '民革会员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (5, '民盟盟员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (6, '民建会员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (7, '民进会员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (8, '农工党党员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (9, '致公党党员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (10, '九三学社社员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (11, '台盟盟员'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (12, '无党派民主人士'); +INSERT INTO `base_political_status`(`id`, `name`) VALUES (13, '群众'); diff --git a/src/main/resources/data_base_college.sql b/src/main/resources/data_base_college.sql index e69de29..482ea2f 100644 --- a/src/main/resources/data_base_college.sql +++ b/src/main/resources/data_base_college.sql @@ -0,0 +1,25 @@ +-- ---------------------------- +-- Records of base_college +-- ---------------------------- +INSERT INTO `base_college` VALUES ('01', '航空学院', '1'); +INSERT INTO `base_college` VALUES ('02', '航天学院', '2'); +INSERT INTO `base_college` VALUES ('03', '航海学院', '3'); +INSERT INTO `base_college` VALUES ('04', '材料学院', '4'); +INSERT INTO `base_college` VALUES ('05', '机电学院', '5'); +INSERT INTO `base_college` VALUES ('06', '力学与土木建筑学院', '6'); +INSERT INTO `base_college` VALUES ('07', '动力与能源学院', '7'); +INSERT INTO `base_college` VALUES ('08', '电子信息学院', '8'); +INSERT INTO `base_college` VALUES ('09', '自动化学院', '9'); +INSERT INTO `base_college` VALUES ('10', '计算机学院', '10'); +INSERT INTO `base_college` VALUES ('11', '理学院', '11'); +INSERT INTO `base_college` VALUES ('12', '管理学院', '12'); +INSERT INTO `base_college` VALUES ('13', '人文与经法学院', '13'); +INSERT INTO `base_college` VALUES ('14', '软件学院学院', '14'); +INSERT INTO `base_college` VALUES ('15', '生命学院', '15'); +INSERT INTO `base_college` VALUES ('16', '外国语学院', '16'); +INSERT INTO `base_college` VALUES ('17', '教育实验学院', '17'); +INSERT INTO `base_college` VALUES ('18', '西北工业大学伦敦玛丽女王大学工程学院', '18'); +INSERT INTO `base_college` VALUES ('19', '马克思主义学院', '19'); +INSERT INTO `base_college` VALUES ('20', '微电子学院', '20'); +INSERT INTO `base_college` VALUES ('21', '网络空间安全学院', '21'); +INSERT INTO `base_college` VALUES ('22', '民航学院', '22'); diff --git a/src/main/webapp/WEB-INF/web.xml b/src/main/webapp/WEB-INF/web.xml new file mode 100644 index 0000000..d80081d --- /dev/null +++ b/src/main/webapp/WEB-INF/web.xml @@ -0,0 +1,6 @@ + + + \ No newline at end of file diff --git a/src/test/java/com/codesdream/ase/DataManagerTest.java b/src/test/java/com/codesdream/ase/DataManagerTest.java new file mode 100644 index 0000000..ba87338 --- /dev/null +++ b/src/test/java/com/codesdream/ase/DataManagerTest.java @@ -0,0 +1,108 @@ +package com.codesdream.ase; + +import com.codesdream.ase.component.ASESpringUtil; +import com.codesdream.ase.component.datamanager.DataExcelGenerator; +import com.codesdream.ase.component.datamanager.DataExcelReader; +import com.codesdream.ase.component.datamanager.DataModelRepositorySearcher; +import com.codesdream.ase.component.datamanager.DataModelSearcher; +import com.codesdream.ase.repository.permission.UserRepository; +import org.junit.Assert; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.junit4.SpringRunner; + +import javax.annotation.Resource; +import java.util.ArrayList; +import java.util.Collection; +import java.util.Iterator; + +/** + * 测试DataModel相关查找器 + */ +@RunWith(SpringRunner.class) +@SpringBootTest +public class DataManagerTest { + @Resource + ASESpringUtil springUtil; + + // Model 查找器测试 + @Test + public void dataModelSearcherTest() { + DataModelSearcher dataModelSearcher = springUtil.getBean(DataModelSearcher.class); + dataModelSearcher.getDataModelClass("permission", "Tag"); + Assert.assertTrue(dataModelSearcher.isPresent()); + + for(String param : dataModelSearcher.getDataModelParamArgs()){ + System.out.println(param); + } + + } + + // Repository 查找器测试 + @Test + public void dataModelRepositorySearcherTest(){ + DataModelRepositorySearcher dataModelRepositorySearcher = + springUtil.getBean(DataModelRepositorySearcher.class); + + dataModelRepositorySearcher.getDataModelRepositoryClass("permission", "User"); + Assert.assertTrue(dataModelRepositorySearcher.isPresent()); + UserRepository userRepository = dataModelRepositorySearcher.getDataModelRepositoryInstance(); + + } + + // 测试Excel导出功能 + @Test + public void dataExcelGeneratorTest(){ + DataExcelGenerator dataExcelGenerator = new DataExcelGenerator("DataExcelGeneratorTest.xlsx"); + + // 设置表头信息 + Collection titles = new ArrayList<>(); + titles.add("Name"); + titles.add("Sex"); + titles.add("Age"); + dataExcelGenerator.setTableTitle(titles); + + Collection dataCollection = new ArrayList<>(); + dataCollection.add("Tom"); + dataCollection.add("M"); + dataCollection.add("18"); + + dataExcelGenerator.insertRow(1, dataCollection); + dataExcelGenerator.insertRow(dataCollection); + + dataCollection.add("Tom"); + dataCollection.add("M"); + dataCollection.add("18"); + dataExcelGenerator.insertRowDataALL(dataCollection); + + // 保存数据 + dataExcelGenerator.save(); + + } + + // 测试Excel导入功能 + @Test + public void dataExcelReaderTest(){ + DataExcelReader dataExcelReader = new DataExcelReader("DataExcelGeneratorTest.xlsx"); + + // 从文件中读取数据 + dataExcelReader.readFile(); + // 读取表头信息 + Collection title = dataExcelReader.readColsTitle(); + // 读一行取数据 + Collection data = dataExcelReader.readRow(); + + Iterator iterator = title.iterator(); + Assert.assertEquals(iterator.next(), "Name"); + Assert.assertEquals(iterator.next(), "Sex"); + Assert.assertEquals(iterator.next(), "Age"); + + iterator = data.iterator(); + Assert.assertEquals(iterator.next(), "Tom"); + Assert.assertEquals(iterator.next(), "M"); + Assert.assertEquals(iterator.next(), "18"); + } + + +} diff --git a/src/main/java/com/codesdream/ase/test/UserTest.java b/src/test/java/com/codesdream/ase/UserTest.java similarity index 98% rename from src/main/java/com/codesdream/ase/test/UserTest.java rename to src/test/java/com/codesdream/ase/UserTest.java index 1b0c25e..177a0db 100644 --- a/src/main/java/com/codesdream/ase/test/UserTest.java +++ b/src/test/java/com/codesdream/ase/UserTest.java @@ -1,4 +1,4 @@ -package com.codesdream.ase.test; +package com.codesdream.ase; import com.codesdream.ase.model.permission.User;