首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JeeSite | 保存信息修改记录

判断被修改的数据 在页面中将数据修改并提交页面后,数据会从 JSP 传递到 Controller 中,这时数据还没有被更新到数据库中,从提交到 Controller 的对象中用数据的 id 从数据库中查出它现有的数据...属性解析 上面的函数会返回两个对象中属性值不同的 List,获得该列表后,再次遍历解析属性对应的字段含义,进而拼接成一个字符串就可以生成修改日志进行保存了。...通常情况下只要把类中的属性和属性对应的中文进行关联后就可以了,但是在 JeeSite 中存在字典类型,比如“男”和“女”,在页面上会显示“男”和“女”,而在数据库中可能是以 “0” 和 “1” 进行存储的...,所以一般在选择“男”或“女”后页面提交的也是 “0” 或 “1”,以这种方式进行日志记录显然不直观,因此在这种情况下就需要将字段的中文和字典名也进行关联,这样就可以将字段中文匹配到字典的值的描述。...strModifyInfo = catModifyInfo(modList); // 输出差异字符串 System.out.println(strModifyInfo); // 把修改记录保存到日志表中

1.1K20

JeeSite | 保存信息修改记录续

接上一篇 JeeSite | 保存信息修改记录 遗留问题 上篇文章中遗留了一个问题,就是为了要关联类属性与注释,注释与字典的地方使用了两个 map 来逐个添加了相关的信息,如下所示: Map...当表结构发生改变后,这些“硬编码”的表字段和字典的两个 map 也需要相应的修改,反复的增加和修改这部分内容费时费力还容易错,那么解决的办法就是使用 JeeSite 系统中提供的两个表 gen_table...),一个用于记录表,一个用于记录表中的列,然后它们的关联关系如下: gen_table.id = gen_table_column.gen_table_id 在 gen_table 中保存了表名对应的类名...,在 gen_table_column 表中保存了表字段对应的注释和对应的 Java 类属性,有了这几部分就可以通过 类名 来获取注释和类属性了。...分别修改这几个文件。

78330

vue页面控制权限,vuex刷新保存状态、登录状态保存

1、页面权限控制 这个常见做法是,在路由跳转的时候做判断,通过router钩子函数判断页面是否需要登录 首先在router配置 meta属性 ? image 然后在钩子函数里面判断 ?...image to.meta.requireAuth为true就跳去登录页面登录,否则就直接到要访问的页面 2、vuex页面F5刷新后维持刷新前的状态不变 首先在store的index.js中,state...,增加页面保存的变量,并且将它们的值和sessionStorage里面的绑定 ?...image 3、登录状态保存 我们在网页中,常常有一个功能,就是像下图那样,勾选后十天内免登录,也就是记住登录状态 这个较上面的功能有一个不一样的地方就是,上面的刷新,假如我是登录状态,我将浏览器关闭之后再打开...image 首先,一样需要在store的index.js中,state,增加页面保存的变量,并且将它们的值和localStorage里面的绑定 ?

2.6K10

JeeSite | 保存信息修改记录封装

前面写过两篇关于“保存信息修改记录”的内容,分别如下: JeeSite | 保存信息修改记录 JeeSite | 保存信息修改记录续 回顾 第一篇文章通过类字段的比较返回一个有字段值不同的...List,然后自己构造表字段和字典的 Map 来生成修改前和修改后的差异字符串。...从而实现“信息”修改“前”和修改“后”的对比记录。...对于保存信息修改记录这个功能会在很多表单中进行使用,那么按照前面的解决方法,需要在每个表单对应的 Controller 中增加相同的代码来完成同样的事情,这样代码就重复了。...封装后的调用 在 JeeSite 中,新建和修改的“保存”调用的都是 Controller 中的 "save" 方法,具体是修改还是新建,只要通过判断对象是否存在 id 即可,代码如下: /* *

95060

JS防止站点被恶意保存

啦, 例如 如下代码: //这里的放到最开头 一加载页面就运行这个....let siteprotect=1;//做一个flag 然后用于下面判断这段JS是否执行 if(self !...let whitelist=['huai.pub','127.0.0.1','localhost','']; //host白名单;空的话,为以file类型打开,是为了防止保存到本地调试,如果不担心此条...把上面部分放到一个不得不运行且打开页面就运行的JS里面(不建议放到公共资源部分,比如 jQuery之类的 )…当然 需要按照注释修改为自己的参数; 之后将这条JS 加密 然后将第二部分放到页面底部的JS...中,同时也加密后再引入(siteprotect变量可以改名 且改掉值,最好使用随机值) 重要的是 JS一定要加密 且放到对站点效果影响大的JS中… 这样就算被别人恶意保存,基本也不会有大的问题了

3.8K20
领券