注册 登录
主题 : 贡献一个好东西。单机游戏防改时间作弊计时器。
级别: 版主

状态: 连续签到 - [33天]
UID: 206863
精华: 1
发帖: 39275
可可豆: 389037 CB
威望: 389085 点
在线时间: 821(时)
注册时间: 2013-01-24
最后登录: 2017-07-27
0 楼:  发表于: 2014-09-25 16:34    发自: Web Page
来源于 程序开发 分类

贡献一个好东西。单机游戏防改时间作弊计时器。   

管理提醒: 本帖被 lyywhg 设置为精华(2015-05-27)
单机游戏计时器防作弊解决方案

一、作弊方法描述
    一些游戏会在某些情况下让玩家等待一段时间,例如candy crush中游戏失败会消耗一点体力,体力不满时,会每隔30分钟涨一点。体力耗尽时就无法再进行游戏,此时玩家可以修改系统时间,调到未来的时间,再回到游戏中,体力就会涨满了。游戏的这种控制就失效了。

    原理:当消耗一点体力时,游戏会记录一个时刻t1,等到当前时刻为t1+30分钟时,就会加上一点体力。如果把系统时间调后半个小时,那就不需要等待直接回复体力了。


二、解决思路
1、通过开机运行时间计算开机时刻
    ios和android都提供了一个方法:获取自开机到现在运行时间。就是利用这个方法来做时间校验。通过获取当前时间(有可能被修改)和开机运行时间,可以计算出开机时刻(前者减后者),如果一直保持开机状态,那么这个开机时刻应该是不变的。如果某次开机时刻算计算出来与上一次不同,那么就可以判断计时器出错。

2、记录开机时刻
    第一次运行游戏时会把开机时刻记录下来,用于之后计算的对比。

3、联网时间修正
    当用户时间异常,比如往后调了1个小时,计算出开机时刻与上次不同,此时需要联网修正时间。从网络上取得正确的当前时间,对比用户时间(有可能被修改),计算出时间差1个小时,记录这个时间差。之后每次获取用户当前时间的时候都要减去这个时间差,结果可以能当成正确的系统时间,再根据1的方法算出开机时刻就比较准确了。时间修正后会重设上次开机时刻做为新的参考值。


三、示例
    进入游戏时,取得当前系统时间8点,获得开机运行3个小时,计算出开机时刻是5点。
    游戏中在9点钟触发了一个30分钟的计时器,应该在9点半的时候完成。此时用户切到设置中修改了系统时间到10点。
    再回到游戏中,会进行计时器检查,系统时间是10点,开机运行4小时,计算出开机时刻是6点,与之前记录的5点不一样,判断出计时器出错。如果用户不进行联网校正,那就无法继续操作。
    用户联网后,取出网络真实时间9点,计算出用户时间差1小时(10-9),重置上次开机时刻,还是5点钟没变(如果是关机再开机这个值会变)。
    校正完后让计时器继续,取用户时间会减去时间差,即可以得到真实时间,那么计时器就可以正常运行了。
    如果用户保持联网状态,那么计时器出错就会瞬间被校正。

四、缺陷
本部分内容设定了隐藏,需要回复后才能看到






=================================


                                          
之前看到猎鹿人有这么个计时器,找了很久问了很多人都不知道怎么做,网上也没有。想了很久没有做,最近动手做了,实现了。
主要是领导让写个文档,要不然也不会想发帖。我想既然写了就分享一下好了。


[ 此帖被masterk在2014-10-11 12:28重新编辑 ]

级别: 新手上路
UID: 134830
精华: 0
发帖: 10
可可豆: 28 CB
威望: 28 点
在线时间: 37(时)
注册时间: 2012-04-06
最后登录: 2015-06-29
1 楼:  发表于: 2014-09-25 17:38    发自: Web Page
看看,
级别: 精灵王

UID: 94657
精华: 0
发帖: 730
可可豆: 4556 CB
威望: 4506 点
在线时间: 1474(时)
注册时间: 2011-09-23
最后登录: 2017-09-07
2 楼:  发表于: 2014-09-25 19:02    发自: Web Page





.........................
[ 此帖被jarod姜赫在2015-09-28 18:46重新编辑 ]

清空我的评分动态本帖最近评分记录: 共1条评分记录
阿花君霸占路人 可可豆 +1 2014-10-11 这个思路还是很棒的
隐藏评分记录
级别: 新手上路
UID: 57259
精华: 0
发帖: 2
可可豆: 2 CB
威望: 2 点
在线时间: 139(时)
注册时间: 2011-03-15
最后登录: 2015-12-10
3 楼:  发表于: 2014-09-25 22:24    发自: Web Page
谢谢楼主的分享
级别: 新手上路
状态: 连续签到 - [8天]
UID: 361290
精华: 0
发帖: 29
可可豆: 162 CB
威望: 146 点
在线时间: 98(时)
注册时间: 2014-08-16
最后登录: 2016-06-15
4 楼:  发表于: 2014-09-26 16:22    发自: Web Page
回 楼主(masterk) 的帖子
谢谢楼主的分享
级别: 侠客
UID: 49552
精华: 0
发帖: 111
可可豆: 103 CB
威望: 183 点
在线时间: 440(时)
注册时间: 2011-02-04
最后登录: 2017-09-25
5 楼:  发表于: 2014-09-26 16:24    发自: Web Page
正好遇到这个问题,先谢谢楼主的分享.
级别: 版主

状态: 连续签到 - [33天]
UID: 206863
精华: 1
发帖: 39275
可可豆: 389037 CB
威望: 389085 点
在线时间: 821(时)
注册时间: 2013-01-24
最后登录: 2017-07-27
6 楼:  发表于: 2014-09-26 16:46    发自: Web Page
版主不给我推荐我过两天就删了。
真没劲。
级别: 版主

状态: 连续签到 - [33天]
UID: 206863
精华: 1
发帖: 39275
可可豆: 389037 CB
威望: 389085 点
在线时间: 821(时)
注册时间: 2013-01-24
最后登录: 2017-07-27
7 楼:  发表于: 2014-09-26 16:50    发自: Web Page
回 2楼(jarod姜赫) 的帖子
用计时器明显是限制玩家无节制的玩,哪里想让玩家多玩了?不是骗取奖励,没有多给奖励,是无视时间间隔。

为什么天天系列都有体力?为什么不做成“将奖励变成某种任务,比如消灭30个坦克,得分超过3000,在距离150到200之间死亡。”?
级别: 精灵王

UID: 94657
精华: 0
发帖: 730
可可豆: 4556 CB
威望: 4506 点
在线时间: 1474(时)
注册时间: 2011-09-23
最后登录: 2017-09-07
8 楼:  发表于: 2014-09-26 17:25    发自: Web Page
回 7楼(masterk) 的帖子
......................
[ 此帖被jarod姜赫在2015-09-28 18:46重新编辑 ]

级别: 圣骑士

状态: 连续签到 - [15天]
UID: 145603
精华: 0
发帖: 571
可可豆: 599 CB
威望: 1067 点
在线时间: 391(时)
注册时间: 2012-05-28
最后登录: 2017-08-17
9 楼:  发表于: 2014-09-26 18:03    发自: Web Page

描述
快速回复

关注本帖(如果有新回复会站内信通知您)

发帖、回帖都会得到可观的积分奖励。查看论坛积分规则

按"Ctrl+Enter"直接提交
    顶部