动态更改时间戳 - 有建议吗?

发布于 2024-11-28 11:45:05 字数 203 浏览 3 评论 0原文

I'm writing up an online examination site for an educational institution.可以为每次评估设置时间限制,一旦用户开始考试,就会在服务器上创建一个新的时间戳。问题是我们学校的电脑经常死机,学生被迫重新启动,从而浪费了考试时间。

我发现我可以将计时器存储为 cookie,但这很容易被破坏。有什么建议吗?谢谢。

I'm writing up an online examination site for an educational institution. Time limits can be set for each assessment, and once a user begins an exam, a new timestamp is created on the server. The problem is that our school computers often lock up and students are forced to restart, losing exam time.

I figured out I could store the timer as a cookie, but that could easily be compromised. Any suggestions? Thanks.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

并安 2024-12-05 11:45:05

您可以将时间戳存储在链接到其用户的数据库中(如果他们正在考试,我会假设他们有登录名),并每隔几秒执行一次 ajax 调用以检查他们是否仍然在线。

In this ajax check you can update the database with a new timestamp that indicates when they were last online, so if the computer locks up and they have to restart you can figure out how much time was lost.

You could store a timestamp in a database that is linked to their user (I would assume they have a login if they are doing exams) and perform an ajax call every few seconds to check if they are still online.

In this ajax check you can update the database with a new timestamp that indicates when they were last online, so if the computer locks up and they have to restart you can figure out how much time was lost.

凶凌 2024-12-05 11:45:05

您可以生成唯一的哈希值将其存储在 cookie 中

$cookie = md5( $student_name . $test_start_timestamp . $computer_ip );

,并将所有需要的信息存储在数据库中,例如:

INSERT INTO examination
SET student_hash = '$cookie',
test_start = '$test_start_timestamp',
computer_ip = '$computer_ip'

稍后(如果计算机重新启动)您可以从数据库中获取所有信息:

SELECT * FROM examination
WHERE student_hash = '$cookie'

这样学生将无法更改时间戳

You could generate unique hash to store it in the cookie like

$cookie = md5( $student_name . $test_start_timestamp . $computer_ip );

and store all the needed information in the database like:

INSERT INTO examination
SET student_hash = '$cookie',
test_start = '$test_start_timestamp',
computer_ip = '$computer_ip'

and later (if computer is restarted) you can get all the information from the database:

SELECT * FROM examination
WHERE student_hash = '$cookie'

this way the student won't be able to change the timestamp

栩栩如生 2024-12-05 11:45:05

continue

While I realise that this can at times be difficult the only really reliable solution to your dilema is a reliable network.

But lacking that what about another communication media or pathway that confirms the client state? Can you confirm that a domain controller can see the client on the LAN? If the PC is present but the web client isn't it is more likely a user manuipulated situation. Can something (domain controller, other network location?) note the appearance or disappearance of a client from the network?

Any method is open to abuse somehow. I think the only real assurance will come from human monitoring of frequence of and user experiencing restarts.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文