管道基础大数据平台系统开发-【后端】-Server
1
13693261870
2024-12-18 2a7ba88ff2f2a0de623d2078e026acf4904ca8e3
˵Ã÷.txt
@@ -1,93 +1,95 @@
----------------------------------------------------------------------------------------------------
01.修改菜单、数据目录、单位的xls数据,编写递归查询SQL
02.登录时验证使用MD5+Salt密码
03.登录时的用户名和密码使用RSA加密、解密
04.WebSocket服务
05.资源实时监控(CPU信息+内存信息+在线用户+资源状态)
06.新建和修改用户密码时使用MD5加密
07.解决Swagger-UI无法传递Cookie信息
08.验证密码复杂度(8-20位包含字母、数字和特殊字符)
09.使用GDAL读取tif、shp、gdb文件
10.添加Mybatis Plus组件
11.解决表映射出错、根据ID查询失败、分页无效等问题
12.开发地名地址分页查询接口
13.开发上传shp文件读取第一条记录的WKT功能
14.解决上传文件时实体类映射异常
15.后台服务访问添加登录验证拦截器
16.开发切面日志功能
17.添加数据库监控功能(Druid Monitor)
18.设置下载文件的MIME类型
19.5分钟内密码错误5次拒绝登录
20.开发获取资源权限、菜单权限、操作权限接口
21.Redis服务配置强密码,并解决SpringBoot启动后无法访问
22.修改钻孔表的数据结构,添加新的字段
23.修改钻孔数据下载工具,更新新增字段的属性
24.身份认证拦截器添加黑白名单检查功能
25.开发自动生成Mybtis Plus代码小工具
26.批量生成基础数据表的实体类和Mapper类
27.修改所有的批量新增、删除、修改接口
28.开发大文件上传接口(commons-fileupload)
29.开发批量修改用户密码接口
30.开发上传Shp文件功能
31.使用Gdal读取Shp文件,读取后删除文件 <
-----------------------------------------------
.对用户、菜单、角色、资源进行授权
.添加查询角色、菜单、资源权限接口
.开发根据实体名称动态查询表的记录数
.开发根据实体名称进行动态分页查询
.开发根据实体名称查询空间表的WKT记录
.开发根据实体名称+字段+值模糊搜索前10条记录
.开发根据名称模糊搜索用户、单位的前10条记录
.开发根据标绘JSON数据生成shp文件并下载
.开发上传shp文件转换为JSON数据接口
----------------------------------------------------------------------------------------------------
------------------------------------------------------------------------------- Header参数值
Content-Security-Policy                      default-src 'self'
X-XSS-Protection                             1; mode=block
Strict-Transport-Security                    max-age=31536000
Referrer-Policy                              origin-when-crossorigin
X-Permitted-Cross-Domain-Policies            master-only
X-Download-Options                           noopen
X-Frame-Options                              SAMEORIGIN
X-Content-Type-Options                       nosniff
OPTIONS                                      False
------------------------------------------------------------------------------- ä¸“题图
case "A0": return 1200;
case "A1": return 850;
case "A2": return 600;
case "A3": return 424;
case "A4": return 300;
------------------------------------------------------------------------------- ä¼˜åŒ–网络
gpedit.msc
计算机\管理模板\网络\Qos数据包计划程序\限制可保留带宽 -> å¯ç”¨ï¼Œ0%
netsh interface tcp show global # æŸ¥çœ‹è‡ªåŠ¨ä¼˜åŒ–çº§åˆ«
【网络连接】→右键【属性】→【配置】→【高级】→【属性】→【TCP/UDP æ ¡éªŒå’Œå¸è½½ï¼ˆIPv6或者IPv4)】→右边的【值】选择禁用。
【 æ¼«æ¸¸ä¸»åŠ¨æ€§ ã€‘→【最低值】
【速度/双工】的【值】→【100MB å…¨åŒå·¥ã€‘。
【电源管理】关闭"允许计算机关闭该设备以节约用电".
ipconfig /flushdns # åˆ·æ–°DNS缓存
TCPOptimizer.exe,自动优化
regedit.msc
HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Microsoft\Windows
新建项目 Psched,右击新建 NonBestEfortLimit,DWORD(32-位)值为 0。
------------------------------------------------------------------------------- Postgres修改Data
https://www.landui.com/docs-1599
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\postgresql-x64-14
修改 ImagePath:"C:\Program Files\PostgreSQL\14cm\bin\pg_ctl.exe" runservice -N "postgresql-x64-14" -D "C:\Program Files\PostgreSQL\14cm\data" -w
net start postgresql-x64-14 # é‡å¯
-------------------------------------------------------------------------------
Access:https://blog.csdn.net/weixin_43407520/article/details/122165848
GDAL:https://www.cnblogs.com/unlockth/p/14062076.html
E:\terrait\TianJin\Zip\release-1928-x64-dev\release-1928-x64\bin
https://start.spring.io -> https://start.aliyun.com
-------------------------------------------------------------------------------
mklink /d "C:\Program Files\Apache Software Foundation\Tomcat 9.0\webapps\geoserver\data\data\tiles" E:\TaiRui\LFData\2d\tiles
@TableField(value = "class")
private String clazz;
java è°ƒç”¨gdal读取gdb数据,linux下java调用gdal:
https://blog.csdn.net/weixin_53853459/article/details/120954597
https://blog.csdn.net/qq_43444401/article/details/125649414
https://blog.csdn.net/qq_43961619/article/details/124627871
http://127.0.0.1:12316/dict/selectCount?tab=sys_user
http://127.0.0.1:12316/Dict/selectByPage?tab=sys_user&pageSize=10&pageIndex=0
http://127.0.0.1:12316/Style/selectCount?name=edp
http://127.0.0.1:12316/Style/selectByPage?name=edp&pageSize=10&pageIndex=0
http://127.0.0.1/lf/sg/login.html
Druid:http://127.0.0.1:12316/server/druid/index.html
http://127.0.0.1:12316/swagger-ui.html
http://192.168.20.106:12316/swagger-ui.html
http://localhost:12316/sign/toIndex
http://localhost:12316/sign/toLogin
http://127.0.0.1:12316/sign/toLogin?service=http://www.sina.com.cn
------------------------------------------------------------------------------- Java与Postgres类型对应
java8                    postgreSQL
LocalDate              date
LocalTime              time
LocalDateTime     timestamp without timezone
OffsetDateTime   timestamp with timezone
String                    varchar
String                    text
Integer                  int2
Integer                  int4
Long                    int8
Float                    float4
Double                  float8
BigDecimal           numeric
Boolean                bool
------------------------------------------------------------------------------- è·¨åŸŸ
chrome://flags/#block-insecure-private-network-requests
Block insecure private network requests. -> Disabled
.gdb > HFCP+LRRL + TFCA
.shp  > F5004_WT.shp + F5004_WL.shp + F5004.shp
------------------------------------------------------------------------------- æš‚时未对应的Controller
data/DownloadController
data/MetaFileController
sys/AttachController
sys/MsgController
进入bin目录,输入:ogrinfo --formats,中国石油天然气管道工程有限公司
----------------------------------------------------------------------------------------------------
java和js实现aes加密解密:
https://blog.csdn.net/weixin_30663839/article/details/114049667
http://192.168.20.39:12306/
http://192.168.20.39:12315/
http://192.168.20.39:12316/
----------------------------------------------------------------------------------------------------
http://192.168.20.39:12316/server/druid/sql.html
-------------------------------------------------------------------------------
String path = System.getProperty("user.dir");
String uid = RsaHelper.decrypt(user.getUid());
String pwd = RsaHelper.decrypt(user.getPwd());
String p1="Admin@123";
String p1 = "Admin@123";
boolean f = p1.equalsIgnoreCase("Some text here");
String p2= RsaHelper.encrypt(p1);
String p3= RsaHelper.decrypt(p2);
http://192.168.20.39:8088/cas/login,admin/Admin@123,postgres
String pwd = "Admin@123";
String md5 = "b37f70636f1164e86cc8796201737933f65af63918d8442b";
@@ -97,149 +99,55 @@
boolean f2 = Md5Helper.validatePassword(pwd, md5Pwd);
new String(Base64.getDecoder().decode(username));
下载:http://127.0.0.1:12316/style/download?guid=15deb4e6bf02db827e39521758520fd5
http://192.168.20.39:8088/cas/login,admin/Admin@123,postgres
使用Commons FileUpLoad æ–‡ä»¶ä¸Šä¼ åŠŸèƒ½ï¼š
https://www.itdaan.com/blog/2017/08/08/b2dbc1106fa7.html
----------------------------------------------------------------------------------------------------
一、开发运行环境
JDK版本:1.8
maven版本:3.5
文件编码:UTF-8
Postgresql按天、周、月、年统计信息:
https://blog.csdn.net/qq_44663150/article/details/119681400
-------------------------------------------------------------------------------
开发运行环境:JDK版本:1.8,maven版本:3.5,文件编码:UTF-8
服务端:核心框架:SpringBoot,持久层框架:Mybatis,安全框架:Shiro,缓存:redis
前端:JS框架:vue.js,主页框架:adminLTE(基于Bootstrap),表格插件:jqGrid,树形表格:tree-table,树形插件:ztree,弹窗组件:layer,表单校验:validator
private static final String SQLSERVER_URL = "jdbc:sqlserver://192.168.0.77\\ZKZS; databaseName=xian";
二、技术框架说明
    æ€»ä½“采用了前后端分离的技术方案,后台提供REST服务,前端使用MVVM框架做用户交互。
    å‰åŽç«¯å¯å¹¶è¡Œç‹¬ç«‹å¼€å‘。
----------------------------------------------------------------------------------------------------
服务端:
  æ ¸å¿ƒæ¡†æž¶ï¼šSpringBoot
  æŒä¹…层框架:Mybatis
  å®‰å…¨æ¡†æž¶ï¼šShiro
  ç¼“存:redis
前端:
  JS框架:vue.js
  ä¸»é¡µæ¡†æž¶ï¼šadminLTE(基于Bootstrap)
  è¡¨æ ¼æ’件:jqGrid
  æ ‘形表格:tree-table
  æ ‘形插件:ztree
  å¼¹çª—组件:layer
  è¡¨å•校验:validator
private static final String SQLSERVER_URL = "jdbc:sqlserver://192.168.0.77\\ZKZS;databaseName=xian";
------------------------------------------------------------------------------------------------ æƒé™
管道基础大数据平台:           åˆ é™¤
综合展示\综合展示\查询:       ä¸‹è½½ã€ä¸Šä¼ 
综合展示\综合展示\标绘:       æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
综合展示\专题图:             ç»Ÿè®¡
综合展示\资料馆:             ä¸‹è½½
-------------------------------------------
数据管理\数据上传:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤ã€ä¸Šä¼ ã€ä¸‹è½½
数据管理\目录管理:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
数据管理\数据检索:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤ã€ä¸Šä¼ ã€ä¸‹è½½
数据管理\版本管理:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
数据管理\字典管理:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
数据管理\元数据管理:          æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤ã€ä¸Šä¼ ã€ä¸‹è½½
数据管理\样式管理:           æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤ã€ä¸Šä¼ ã€ä¸‹è½½
-------------------------------------------
运维管理\系统管理\菜单管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\系统管理\用户管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\系统管理\单位管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\系统管理\资源管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤ã€ä¸Šä¼ 
运维管理\系统管理\角色管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\系统管理\权限管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\授权管理\用户角色授权:新增、修改、删除
运维管理\授权管理\菜单权限授权:新增、修改、删除
运维管理\授权管理\角色菜单授权:新增、修改、删除
运维管理\授权管理\角色资源授权:新增、修改、删除
运维管理\运维监控\令牌管理:   æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\运维监控\黑白/名单:  æ–°å¢žã€ä¿®æ”¹ã€åˆ é™¤
运维管理\系统配置:           ä¿®æ”¹
----------------------------------------------------------------------------------------------------
// èŽ·å–è¯·æ±‚æ–¹å¼: GET
String getMethod()
http://localhost:12316/floatserver/checkout/license
String str = EntityUtils.toString(entity, "UTF-8");
java -jar C:\360\luyten054\luyten-0.5.4.jar
------------------------------------------------------------------------------- Java Web操作
String getMethod() // èŽ·å–è¯·æ±‚æ–¹å¼: GET
// èŽ·å–è™šæ‹Ÿç›®å½•(上下文目录):虚拟路径通过在application配置当中可以配置
// é…ç½®ï¼šserver.servlet.context-path=/aaa
String getContextPath()
// èŽ·å–Servlet路径:就是获取的controller当中配置的路径
String getServletPath()
/// èŽ·å–è¯·æ±‚å‚æ•°ï¼š id=3
// http://localhost:8080/aaa/test?id=3
String getQueryString()
String getContextPath() // é…ç½®ï¼šserver.servlet.context-path=/aaa
String getServletPath() // èŽ·å–Servlet路径:就是获取的controller当中配置的路径
String getQueryString() // http://localhost:8080/aaa/test?id=3,获取请求参数: id=3
// èŽ·å–è¯·æ±‚URI:/servletDemo/demo1
// ä¸Šä¸‹æ–‡è·¯å¾„+controller当中配置的路径
String getRequestURI()
String getRequestURI() // ä¸Šä¸‹æ–‡è·¯å¾„+controller当中配置的路径
String getRequestURL() // èŽ·å–å®Œæ•´è¯·æ±‚è·¯å¾„ï¼šhttp://localhost:8080/aaa/test
String getProtocol() // èŽ·å–åè®®åŠç‰ˆæœ¬ï¼šHTTP/1.1
String getRemoteAddr() // èŽ·å–å®¢æˆ·æœºçš„IP地址:192.168.0.0
String getHeader(String name) // èŽ·å–è¯·æ±‚å¤´æ•°æ®,通过请求头名称获取值
Enumeration<String> getHeaderNames() // èŽ·å–æ‰€æœ‰è¯·æ±‚å¤´ä¿¡æ¯
BufferedReader getReader() // èŽ·å–æµå¯¹è±¡-获取字符输入流,只能操作字符数据
ServletInputStream getInputStream() // èŽ·å–æµå¯¹è±¡-获取字节输入流,既能操作字节也能操作字符
// èŽ·å–å®Œæ•´è¯·æ±‚è·¯å¾„ï¼šhttp://localhost:8080/aaa/test
String getRequestURL()
// èŽ·å–åè®®åŠç‰ˆæœ¬ï¼šHTTP/1.1
String getProtocol()
// èŽ·å–å®¢æˆ·æœºçš„IP地址:192.168.0.0
String getRemoteAddr()
// èŽ·å–è¯·æ±‚å¤´æ•°æ®,通过请求头名称获取值
String getHeader(String name)
// èŽ·å–æ‰€æœ‰è¯·æ±‚å¤´ä¿¡æ¯
Enumeration<String> getHeaderNames()
// èŽ·å–æµå¯¹è±¡-获取字符输入流,只能操作字符数据
BufferedReader getReader()
// èŽ·å–æµå¯¹è±¡-获取字节输入流,既能操作字节也能操作字符
ServletInputStream getInputStream()
// èŽ·å–è¯·æ±‚å‚æ•°é€šç”¨æ–¹å¼(根据参数名称获取参数值) username=zhangsan
String getParameter(String name)
// èŽ·å–è¯·æ±‚å‚æ•°åç§°èŽ·å–å‚æ•°å€¼çš„æ•°ç»„ hobby=xx&hobby=game
String[] getParameters(String name)
// èŽ·å–è¯·æ±‚å‚æ•°åç§°(与获取请求头方法类似)
Enumeration<String> getParameterNames()
// èŽ·å–æ‰€æœ‰å‚æ•°çš„Map集合
Map<String,String> getParameterMap()
String getParameter(String name) // èŽ·å–è¯·æ±‚å‚æ•°é€šç”¨æ–¹å¼(根据参数名称获取参数值) username=zhangsan
String[] getParameters(String name) // èŽ·å–è¯·æ±‚å‚æ•°åç§°èŽ·å–å‚æ•°å€¼çš„æ•°ç»„ hobby=xx&hobby=game
Enumeration<String> getParameterNames() // èŽ·å–è¯·æ±‚å‚æ•°åç§°(与获取请求头方法类似)
Map<String,String> getParameterMap() // èŽ·å–æ‰€æœ‰å‚æ•°çš„Map集合
request.setCharacterEncoding("UTF-8");
RequestDispatcher getRequestDispatcher(String path); // é€šè¿‡request对象获取请求转发服务器:
// é€šè¿‡request对象获取请求转发服务器:
RequestDispatcher getRequestDispatcher(String path);
// ä½¿ç”¨==RequestDispatcher对象来进行转发
forward(ServlertRequest request,ServletResponse response);
//设置状态码
response.setStatus(304);
forward(ServlertRequest request,ServletResponse response); // ä½¿ç”¨==RequestDispatcher对象来进行转发
response.setStatus(304); //设置状态码
// è®¾ç½®æŒ‡å®šåç§°å“åº”头的值,下面是导出的时候我们经常要设置的响应头,响应头当中还有文件的名称,也就是通过流下载文件的时候那个文件名称
response.setHeader("Content-Disposition", "attachment;filename=" + zipName);
// 1.字符输出流
PrintWriter getWriter()
// 2.字节输出流(一般导出就是将文件写到字节流,然后响应response)
ServletOutputStream getOutputStream()
PrintWriter getWriter() // 1.字符输出流
ServletOutputStream getOutputStream() // 2.字节输出流(一般导出就是将文件写到字节流,然后响应response)
// æ³¨æ„ï¼šåœ¨åŒä¸€ä¸ªServlet,二种输出流不能同时使用,产生互斥
// response提供了专门负责重定向的方法
response.sendRedirect("/项目地址/资源地址");
// æŒ‡å®šæœåŠ¡å™¨å“åº”ä¸­æ–‡çš„ç¼–ç æ–¹å¼
response.setCharacterEncoding("GBK");
// ç»Ÿä¸€æœåŠ¡å™¨å’Œå®¢æˆ·ç«¯çš„ç¼–ç æ–¹å¼
response.setContentType("text/html;charset=utf-8");
response.sendRedirect("/项目地址/资源地址"); // response提供了专门负责重定向的方法
response.setCharacterEncoding("GBK"); // æŒ‡å®šæœåŠ¡å™¨å“åº”ä¸­æ–‡çš„ç¼–ç æ–¹å¼
response.setContentType("text/html;charset=utf-8"); // ç»Ÿä¸€æœåŠ¡å™¨å’Œå®¢æˆ·ç«¯çš„ç¼–ç æ–¹å¼
// å¯¼å‡ºçš„æ—¶å€™å¦‚果需要直接通过response流导出Excel,需要和前端设置上下文类型,如下:
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
----------------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------