|
@@ -0,0 +1,471 @@
|
|
|
+package org.jeecg.modules.demo.test.controller;
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSON;
|
|
|
+import com.alibaba.fastjson.JSONArray;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
+import io.swagger.annotations.Api;
|
|
|
+import io.swagger.annotations.ApiOperation;
|
|
|
+import io.swagger.annotations.ApiParam;
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.jeecg.common.api.vo.Result;
|
|
|
+import org.jeecg.common.aspect.annotation.AutoLog;
|
|
|
+import org.jeecg.common.aspect.annotation.PermissionData;
|
|
|
+import org.jeecg.common.constant.CommonConstant;
|
|
|
+import org.jeecg.common.system.base.controller.JeecgController;
|
|
|
+import org.jeecg.common.system.query.QueryGenerator;
|
|
|
+import org.jeecg.common.util.DateUtils;
|
|
|
+import org.jeecg.common.util.RedisUtil;
|
|
|
+import org.jeecg.common.util.UUIDGenerator;
|
|
|
+import org.jeecg.modules.demo.test.entity.JeecgDemo;
|
|
|
+import org.jeecg.modules.demo.test.service.IJeecgDemoService;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+import org.springframework.web.servlet.ModelAndView;
|
|
|
+
|
|
|
+import javax.servlet.http.HttpServletRequest;
|
|
|
+import javax.servlet.http.HttpServletResponse;
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.Arrays;
|
|
|
+import java.util.Date;
|
|
|
+import java.util.List;
|
|
|
+
|
|
|
+/**
|
|
|
+ * @Description: 单表示例
|
|
|
+ * @Author: jeecg-boot
|
|
|
+ * @Date:2018-12-29
|
|
|
+ * @Version:V2.0
|
|
|
+ */
|
|
|
+@Slf4j
|
|
|
+@Api(tags = "单表DEMO")
|
|
|
+@RestController
|
|
|
+@RequestMapping("/test/jeecgDemo")
|
|
|
+public class JeecgDemoController extends JeecgController<JeecgDemo, IJeecgDemoService> {
|
|
|
+ @Autowired
|
|
|
+ private IJeecgDemoService jeecgDemoService;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private RedisUtil redisUtil;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 分页列表查询
|
|
|
+ *
|
|
|
+ * @param jeecgDemo
|
|
|
+ * @param pageNo
|
|
|
+ * @param pageSize
|
|
|
+ * @param req
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @ApiOperation(value = "获取Demo数据列表", notes = "获取所有Demo数据列表")
|
|
|
+ @GetMapping(value = "/list")
|
|
|
+ @PermissionData(pageComponent = "jeecg/JeecgDemoList")
|
|
|
+ public Result<?> list(JeecgDemo jeecgDemo, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize,
|
|
|
+ HttpServletRequest req) {
|
|
|
+ QueryWrapper<JeecgDemo> queryWrapper = QueryGenerator.initQueryWrapper(jeecgDemo, req.getParameterMap());
|
|
|
+ queryWrapper.orderByDesc("create_time");
|
|
|
+ Page<JeecgDemo> page = new Page<JeecgDemo>(pageNo, pageSize);
|
|
|
+
|
|
|
+ IPage<JeecgDemo> pageList = jeecgDemoService.page(page, queryWrapper);
|
|
|
+ log.info("查询当前页:" + pageList.getCurrent());
|
|
|
+ log.info("查询当前页数量:" + pageList.getSize());
|
|
|
+ log.info("查询结果数量:" + pageList.getRecords().size());
|
|
|
+ log.info("数据总数:" + pageList.getTotal());
|
|
|
+ return Result.OK(pageList);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 添加
|
|
|
+ *
|
|
|
+ * @param jeecgDemo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @PostMapping(value = "/add")
|
|
|
+ @AutoLog(value = "添加测试DEMO")
|
|
|
+ @ApiOperation(value = "添加DEMO", notes = "添加DEMO")
|
|
|
+ public Result<?> add(@RequestBody JeecgDemo jeecgDemo) {
|
|
|
+ jeecgDemoService.save(jeecgDemo);
|
|
|
+ return Result.OK("添加成功!");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 编辑
|
|
|
+ *
|
|
|
+ * @param jeecgDemo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @AutoLog(value = "编辑DEMO", operateType = CommonConstant.OPERATE_TYPE_3)
|
|
|
+ @ApiOperation(value = "编辑DEMO", notes = "编辑DEMO")
|
|
|
+ @RequestMapping(value = "/edit", method = {RequestMethod.PUT,RequestMethod.POST})
|
|
|
+ public Result<?> edit(@RequestBody JeecgDemo jeecgDemo) {
|
|
|
+ jeecgDemoService.updateById(jeecgDemo);
|
|
|
+ return Result.OK("更新成功!");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 通过id删除
|
|
|
+ *
|
|
|
+ * @param id
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @AutoLog(value = "删除测试DEMO")
|
|
|
+ @DeleteMapping(value = "/delete")
|
|
|
+ @ApiOperation(value = "通过ID删除DEMO", notes = "通过ID删除DEMO")
|
|
|
+ public Result<?> delete(@RequestParam(name = "id", required = true) String id) {
|
|
|
+ jeecgDemoService.removeById(id);
|
|
|
+ return Result.OK("删除成功!");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 批量删除
|
|
|
+ *
|
|
|
+ * @param ids
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @DeleteMapping(value = "/deleteBatch")
|
|
|
+ @ApiOperation(value = "批量删除DEMO", notes = "批量删除DEMO")
|
|
|
+ public Result<?> deleteBatch(@RequestParam(name = "ids", required = true) String ids) {
|
|
|
+ this.jeecgDemoService.removeByIds(Arrays.asList(ids.split(",")));
|
|
|
+ return Result.OK("批量删除成功!");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 通过id查询
|
|
|
+ *
|
|
|
+ * @param id
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/queryById")
|
|
|
+ @ApiOperation(value = "通过ID查询DEMO", notes = "通过ID查询DEMO")
|
|
|
+ public Result<?> queryById(@ApiParam(name = "id", value = "示例id", required = true) @RequestParam(name = "id", required = true) String id) {
|
|
|
+ JeecgDemo jeecgDemo = jeecgDemoService.getById(id);
|
|
|
+ return Result.OK(jeecgDemo);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 导出excel
|
|
|
+ *
|
|
|
+ * @param request
|
|
|
+ */
|
|
|
+ @RequestMapping(value = "/exportXls")
|
|
|
+ @PermissionData(pageComponent = "jeecg/JeecgDemoList")
|
|
|
+ public ModelAndView exportXls(HttpServletRequest request, JeecgDemo jeecgDemo) {
|
|
|
+ //获取导出表格字段
|
|
|
+ String exportFields = jeecgDemoService.getExportFields();
|
|
|
+ //分sheet导出表格字段
|
|
|
+ return super.exportXlsSheet(request, jeecgDemo, JeecgDemo.class, "单表模型",exportFields,500);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 通过excel导入数据
|
|
|
+ *
|
|
|
+ * @param request
|
|
|
+ * @param response
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
|
|
|
+ public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
|
|
|
+ return super.importExcel(request, response, JeecgDemo.class);
|
|
|
+ }
|
|
|
+
|
|
|
+ // =====Redis 示例===============================================================================================
|
|
|
+
|
|
|
+ /**
|
|
|
+ * redis操作 -- set
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/redisSet")
|
|
|
+ public void redisSet() {
|
|
|
+ redisUtil.set("name", "张三" + DateUtils.now());
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * redis操作 -- get
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/redisGet")
|
|
|
+ public String redisGet() {
|
|
|
+ return (String) redisUtil.get("name");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * redis操作 -- setObj
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/redisSetObj")
|
|
|
+ public void redisSetObj() {
|
|
|
+ JeecgDemo p = new JeecgDemo();
|
|
|
+ p.setAge(10);
|
|
|
+ p.setBirthday(new Date());
|
|
|
+ p.setContent("hello");
|
|
|
+ p.setName("张三");
|
|
|
+ p.setSex("男");
|
|
|
+ redisUtil.set("user-zdh", p);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * redis操作 -- setObj
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/redisGetObj")
|
|
|
+ public Object redisGetObj() {
|
|
|
+ return redisUtil.get("user-zdh");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * redis操作 -- get
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/redis/{id}")
|
|
|
+ public JeecgDemo redisGetJeecgDemo(@PathVariable("id") String id) {
|
|
|
+ JeecgDemo t = jeecgDemoService.getByIdCacheable(id);
|
|
|
+ log.info(t.toString());
|
|
|
+ return t;
|
|
|
+ }
|
|
|
+
|
|
|
+ // ===Freemaker示例================================================================================
|
|
|
+
|
|
|
+ /**
|
|
|
+ * freemaker方式 【页面路径: src/main/resources/templates】
|
|
|
+ *
|
|
|
+ * @param modelAndView
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @RequestMapping("/html")
|
|
|
+ public ModelAndView ftl(ModelAndView modelAndView) {
|
|
|
+ modelAndView.setViewName("demo3");
|
|
|
+ List<String> userList = new ArrayList<String>();
|
|
|
+ userList.add("admin");
|
|
|
+ userList.add("user1");
|
|
|
+ userList.add("user2");
|
|
|
+ log.info("--------------test--------------");
|
|
|
+ modelAndView.addObject("userList", userList);
|
|
|
+ return modelAndView;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ // ==========================================动态表单 JSON接收测试===========================================
|
|
|
+ /**
|
|
|
+ * online新增数据
|
|
|
+ */
|
|
|
+ @PostMapping(value = "/testOnlineAdd")
|
|
|
+ public Result<?> testOnlineAdd(@RequestBody JSONObject json) {
|
|
|
+ log.info(json.toJSONString());
|
|
|
+ return Result.OK("添加成功!");
|
|
|
+ }
|
|
|
+
|
|
|
+ /*----------------------------------------外部获取权限示例------------------------------------*/
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 【数据权限示例 - 编程】mybatisPlus java类方式加载权限
|
|
|
+ *
|
|
|
+ * @param pageNo
|
|
|
+ * @param pageSize
|
|
|
+ * @param req
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/mpList")
|
|
|
+ @PermissionData(pageComponent = "jeecg/JeecgDemoList")
|
|
|
+ public Result<?> loadMpPermissonList(@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize,
|
|
|
+ HttpServletRequest req) {
|
|
|
+ QueryWrapper<JeecgDemo> queryWrapper = new QueryWrapper<JeecgDemo>();
|
|
|
+ //编程方式,给queryWrapper装载数据权限规则
|
|
|
+ QueryGenerator.installAuthMplus(queryWrapper, JeecgDemo.class);
|
|
|
+ Page<JeecgDemo> page = new Page<JeecgDemo>(pageNo, pageSize);
|
|
|
+ IPage<JeecgDemo> pageList = jeecgDemoService.page(page, queryWrapper);
|
|
|
+ return Result.OK(pageList);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 【数据权限示例 - 编程】mybatis xml方式加载权限
|
|
|
+ *
|
|
|
+ * @param jeecgDemo
|
|
|
+ * @param pageNo
|
|
|
+ * @param pageSize
|
|
|
+ * @param req
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/sqlList")
|
|
|
+ @PermissionData(pageComponent = "jeecg/JeecgDemoList")
|
|
|
+ public Result<?> loadSqlPermissonList(JeecgDemo jeecgDemo, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize,
|
|
|
+ HttpServletRequest req) {
|
|
|
+ IPage<JeecgDemo> pageList = jeecgDemoService.queryListWithPermission(pageSize, pageNo);
|
|
|
+ return Result.OK(pageList);
|
|
|
+ }
|
|
|
+ /*----------------------------------------外部获取权限示例------------------------------------*/
|
|
|
+
|
|
|
+ /**
|
|
|
+ * online api增强 列表
|
|
|
+ * @param params
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @PostMapping("/enhanceJavaListHttp")
|
|
|
+ public Result enhanceJavaListHttp(@RequestBody JSONObject params) {
|
|
|
+ log.info(" =========================================================== ");
|
|
|
+ log.info("params: " + params.toJSONString());
|
|
|
+ log.info("params.tableName: " + params.getString("tableName"));
|
|
|
+ log.info("params.json: " + params.getJSONObject("json").toJSONString());
|
|
|
+ JSONArray dataList = params.getJSONArray("dataList");
|
|
|
+ log.info("params.dataList: " + dataList.toJSONString());
|
|
|
+ log.info(" =========================================================== ");
|
|
|
+ return Result.OK(dataList);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * online api增强 表单
|
|
|
+ * @param params
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @PostMapping("/enhanceJavaFormHttp")
|
|
|
+ public Result enhanceJavaFormHttp(@RequestBody JSONObject params) {
|
|
|
+ log.info(" =========================================================== ");
|
|
|
+ log.info("params: " + params.toJSONString());
|
|
|
+ log.info("params.tableName: " + params.getString("tableName"));
|
|
|
+ log.info("params.json: " + params.getJSONObject("json").toJSONString());
|
|
|
+ log.info(" =========================================================== ");
|
|
|
+ return Result.OK("1");
|
|
|
+ }
|
|
|
+
|
|
|
+ @GetMapping(value = "/hello")
|
|
|
+ public String hello(HttpServletRequest req) {
|
|
|
+ return "hello world!";
|
|
|
+ }
|
|
|
+
|
|
|
+ // =====Vue3 Native 原生页面示例===============================================================================================
|
|
|
+ @GetMapping(value = "/oneNative/list")
|
|
|
+ public Result oneNativeList(@RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize){
|
|
|
+ Object oneNative = redisUtil.get("one-native");
|
|
|
+ JSONArray data = new JSONArray();
|
|
|
+ if(null != oneNative){
|
|
|
+ JSONObject nativeObject = (JSONObject) oneNative;
|
|
|
+ data = nativeObject.getJSONArray("data");
|
|
|
+ }
|
|
|
+ IPage<JSONObject> objectPage = queryDataPage(data, pageNo, pageSize);
|
|
|
+ return Result.OK(objectPage);
|
|
|
+ }
|
|
|
+
|
|
|
+ @PostMapping("/oneNative/add")
|
|
|
+ public Result<String> oneNativeAdd(@RequestBody JSONObject jsonObject){
|
|
|
+ Object oneNative = redisUtil.get("one-native");
|
|
|
+ JSONObject nativeObject = new JSONObject();
|
|
|
+ JSONArray data = new JSONArray();
|
|
|
+ if(null != oneNative){
|
|
|
+ nativeObject = (JSONObject) oneNative;
|
|
|
+ data = nativeObject.getJSONArray("data");
|
|
|
+ }
|
|
|
+ jsonObject.put("id", UUIDGenerator.generate());
|
|
|
+ data.add(jsonObject);
|
|
|
+ nativeObject.put("data",data);
|
|
|
+ redisUtil.set("one-native",nativeObject);
|
|
|
+ return Result.OK("添加成功");
|
|
|
+ }
|
|
|
+
|
|
|
+ @PutMapping("/oneNative/edit")
|
|
|
+ public Result<String> oneNativeEdit(@RequestBody JSONObject jsonObject){
|
|
|
+ JSONObject oneNative = (JSONObject)redisUtil.get("one-native");
|
|
|
+ JSONArray data = oneNative.getJSONArray("data");
|
|
|
+ data = getNativeById(data,jsonObject);
|
|
|
+ oneNative.put("data", data);
|
|
|
+ redisUtil.set("one-native", oneNative);
|
|
|
+ return Result.OK("修改成功");
|
|
|
+ }
|
|
|
+
|
|
|
+ @DeleteMapping("/oneNative/delete")
|
|
|
+ public Result<String> oneNativeDelete(@RequestParam(name = "ids") String ids){
|
|
|
+ Object oneNative = redisUtil.get("one-native");
|
|
|
+ if(null != oneNative){
|
|
|
+ JSONObject nativeObject = (JSONObject) oneNative;
|
|
|
+ JSONArray data = nativeObject.getJSONArray("data");
|
|
|
+ data = deleteNativeById(data,ids);
|
|
|
+ nativeObject.put("data",data);
|
|
|
+ redisUtil.set("one-native",nativeObject);
|
|
|
+ }
|
|
|
+ return Result.OK("删除成功");
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取redis对应id的数据
|
|
|
+ * @param data
|
|
|
+ * @param jsonObject
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public JSONArray getNativeById(JSONArray data,JSONObject jsonObject){
|
|
|
+ String dbId = "id";
|
|
|
+ String id = jsonObject.getString(dbId);
|
|
|
+ for (int i = 0; i < data.size(); i++) {
|
|
|
+ if(id.equals(data.getJSONObject(i).getString(dbId))){
|
|
|
+ data.set(i,jsonObject);
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return data;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 删除redis中包含的id数据
|
|
|
+ * @param data
|
|
|
+ * @param ids
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public JSONArray deleteNativeById(JSONArray data,String ids){
|
|
|
+ String dbId = "id";
|
|
|
+ for (int i = 0; i < data.size(); i++) {
|
|
|
+ //如果id包含直接清除data中的数据
|
|
|
+ if(ids.contains(data.getJSONObject(i).getString(dbId))){
|
|
|
+ data.fluentRemove(i);
|
|
|
+ }
|
|
|
+ //判断data的长度是否还剩1位
|
|
|
+ if(data.size() == 1 && ids.contains(data.getJSONObject(0).getString(dbId))){
|
|
|
+ data.fluentRemove(0);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return data;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 模拟查询数据,可以根据父ID查询,可以分页
|
|
|
+ *
|
|
|
+ * @param dataList 数据列表
|
|
|
+ * @param pageNo 页码
|
|
|
+ * @param pageSize 页大小
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ private IPage<JSONObject> queryDataPage(JSONArray dataList, Integer pageNo, Integer pageSize) {
|
|
|
+ // 根据父级id查询子级
|
|
|
+ JSONArray dataDb = dataList;
|
|
|
+ // 模拟分页(实际中应用SQL自带的分页)
|
|
|
+ List<JSONObject> records = new ArrayList<>();
|
|
|
+ IPage<JSONObject> page;
|
|
|
+ long beginIndex, endIndex;
|
|
|
+ // 如果任意一个参数为null,则不分页
|
|
|
+ if (pageNo == null || pageSize == null) {
|
|
|
+ page = new Page<>(0, dataDb.size());
|
|
|
+ beginIndex = 0;
|
|
|
+ endIndex = dataDb.size();
|
|
|
+ } else {
|
|
|
+ page = new Page<>(pageNo, pageSize);
|
|
|
+ beginIndex = page.offset();
|
|
|
+ endIndex = page.offset() + page.getSize();
|
|
|
+ }
|
|
|
+ for (long i = beginIndex; (i < endIndex && i < dataDb.size()); i++) {
|
|
|
+ JSONObject data = dataDb.getJSONObject((int) i);
|
|
|
+ data = JSON.parseObject(data.toJSONString());
|
|
|
+ // 不返回 children
|
|
|
+ data.remove("children");
|
|
|
+ records.add(data);
|
|
|
+ }
|
|
|
+ page.setRecords(records);
|
|
|
+ page.setTotal(dataDb.size());
|
|
|
+ return page;
|
|
|
+ }
|
|
|
+ // =====Vue3 Native 原生页面示例===============================================================================================
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 获取创建人
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @GetMapping(value = "/groupList")
|
|
|
+ public Result<?> groupList() {
|
|
|
+ return Result.ok(jeecgDemoService.getCreateByList());
|
|
|
+ }
|
|
|
+
|
|
|
+}
|