一般开源系统演示站点禁止修改演示数据都是怎么实现的?

2023-03-26 16:10:46 +08:00
 tlerbao

一般开源系统的演示站点都禁止修改演示数据

这是怎么实现的,

比如 ThinkPHP 开发的。

全局中间件?建个只有读权限的角色?

3174 次点击
所在节点    程序员
16 条回复
Puteulanus
2023-03-26 16:13:59 +08:00
看到的一般是定时重置
jeesk
2023-03-26 16:21:58 +08:00
我自己看到的项目 java, golang 的项目都是做拦截器,拦截有删除和修改的方法。 不执行数据库操作即可。
lichao
2023-03-26 16:42:18 +08:00
定时重置吧。

如果禁止修改的话,用户无法完全体验产品的功能
beetlerx
2023-03-26 16:54:31 +08:00
建一个数据库只读帐号,只需要全局改一下报错信息就行了
Huelse
2023-03-26 17:09:07 +08:00
sqlite 定期覆盖即可
knightdf
2023-03-26 17:53:07 +08:00
定时清理定时重置
yolee599
2023-03-26 18:11:19 +08:00
定期重置数据库
JohnH
2023-03-26 18:35:33 +08:00
1.定期重置数据库和代码,或自动或手动。php 项目如果有漏洞的话,整站比较容易被端掉
2.有些会利用中间件,来阻止 post 操作,提示演示站不可改
3.有些会在数据层发生真实写入时,阻拦写入
4.有些开源项目会加入一个是否演示站的标记,并根据标记细化操作。类似环境变量、NODE_ENV
tlerbao
2023-03-26 21:00:13 +08:00
@Puteulanus @lichao @Huelse @knightdf @yolee599 定时清理数据这种方式,给的权限太大,怕演示站恶意被搞,而且乱增加演示数据进系统看着也乱。

看来中间件可能目前比较好。
systemcall
2023-03-26 22:01:19 +08:00
可以在你访问的时候给你专门开一个实例,通过反代让你访问到,隔一段时间就销毁
群晖和威联通的演示就是这么弄的
biubiuF
2023-03-26 22:19:06 +08:00
一般写 cache ,然后用 lru 就行了
chendy
2023-03-27 08:33:11 +08:00
一般能改,不能改就不能体验完整系统功能了
但是会每天凌晨覆盖数据
zoyao
2023-03-27 10:05:09 +08:00
完全不给改起不到演示效果吧,一个小时定时重置一次数据库就好了
flyingghost
2023-03-27 14:23:25 +08:00
多租户,每进一个体验者分配单独的账号、单独的库、单独的容器、单独的环境等。具体在哪一层隔离看方便程度。
yinmin
2023-03-27 17:33:56 +08:00
最简单的方法,软件部署到 docker 里,然后 2 小时 recreate 一下
yinmin
2023-03-27 17:52:39 +08:00
做演示系统,重置数据库最方便的方式是用 docker 。

例如,你使用的是 mysql 数据库,你先从官方镜像创建一个 mysql 容器模版,数据目录留在容器里,不要 volume 到主机;然后把演示数据导入 mysql ;然后用容器模版生成新镜像。

从这个新镜像创建新的数据库容器给演示系统使用,定期(例如 2 小时) recreate 这个数据库容器,recreate 一般只需要几百毫秒,非常快。也可以创建多个数据库容器副本给不同的客户。

演示系统的程序部分也可以使用类似的方式用 docker 部署。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/927276

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX