PHP网页游戏学习之Xnova(ogame)源码解读(三)
作者:铁船长 发布时间:2024-06-05 15:41:29
四、 用户注册(reg.php)
在看用户注册之流程之前,我把表的用途做个简单说明,现在只是大概的说明,后面我们再仔细了解,大家可以记下这个说明。
game_aks 联合攻击组记录表,攻击完成删除数据
game_alliance 联盟表
game_annonce 公告表,基本无用
game_banned Ban玩家表
game_buddy 好友表
game_chat 聊天记录表
game_config 系统参数表
game_errors 错误日志表
game_fleets 舰队活动记录表,活动完成删除数据
game_galaxy 星系表
game_iraks 星际导弹活动表,活动完成删除数据
game_lunas 月球列表
game_messages 消息表
game_notes 笔记表
game_planets 星球列表,包括月球
game_rw 战报表
game_statpoints 积分表
game_users 用户表
现在我们开始用户注册流程,一开始又可以看到定义了两个常量,
define('INSIDE' , true);
define('INSTALL' , false);
INSIDE是用来防止攻击的,值为true;INSTALL是用来记录现在是否处于安装游戏的进程中,值为false。接下来又是Include两个文件,extension.inc和common.php;然后又是load语言文件reg.mo。在后面的章节里,我不再介绍了前面这段代码,大家已经明了了。
下面声明了两个函数,用来发送注册成功后的信息,包括用户名和密码等。
function sendpassemail($emailaddress, $username, $password)
function mymail($to, $title, $body, $from = '')
现在介绍Xnova源码里面经常用到的一个结构,下面是伪代码说明,
if ($_POST) { //如果用户有输入
//这里是有用户输入后执行过程
}else{
//这里是无用户输入后的执行过程,包括页面第一次显示的时候
}
我们看用户注册流程,为了说明前面的结构,特意贴了代码。和前面我们讲过的一样,先gettemplate文件,然后parse出来并显示页面。
if ($_POST) {
//代码略
} else {
$parse = $lang;
$parse['servername'] = $game_config['game_name'];
$page = parsetemplate(gettemplate('registry_form'), $parse);
display ($page, $lang['registry'], false);
}
下面看用户输入信息后的流程,一堆的if都是判断用户输入的信息是否合法,并用$errors变量记录错误的数量,$errorlist变量记录错误的消息。如果$errors不为零就输出错误信息;如果没有错误,就进入下面的流程:
1. 检查用户名是否有非法字符
2. 检查Email是否有非法字符
3. 检查星球名是否有非法字符
4. 加密用户的密码,md5
5. 往表users中INSERT用户信息
6. 取得刚刚插入生成的用户ID号备用
7. 一大段代码功能,找一个空的星球坐标给这个用户作为母星,并使用函数CreateOnePlanetRecord()创建星球,这里要使用三个系统参数LastSettedGalaxyPos、LastSettedSystemPos、LastSettedPlanetPos,看命名就应该清楚,分别是最后星系、最后太阳系、最后行星位置
8. 更新users表中的星球ID为刚刚生成的星球ID
9. 向这个玩家发送欢迎信息
10. 向这个玩家发送注册信息邮件
11. 显示注册成功页面,注册结束
以上流程,我们都可以找到对应的代码,代码难度不大,所以没有列出来。函数CreateOnePlanetRecord()以后详细介绍,现在说了反而头大,函数SendSimpleMessage()我们现在看一下,声明在SendSimpleMessage.php文件中。
function SendSimpleMessage ( $Owner, $Sender, $Time, $Type, $From, $Subject, $Message) {
global $messfields;
if ($Time == '') {
$Time = time();
}
if ($Sender == null){
$Sender = 0;
}
$QryInsertMessage = "INSERT INTO {{table}} SET ";
$QryInsertMessage .= "'message_owner' = ". $Owner .", ";
$QryInsertMessage .= "'message_sender' = ". $Sender .", ";
$QryInsertMessage .= "'message_time' = " . $Time . ", ";
$QryInsertMessage .= "'message_type' = ". $Type .", ";
$QryInsertMessage .= "'message_from' = '". addslashes( $From ) ."', ";
$QryInsertMessage .= "'message_subject' = '". addslashes( $Subject ) ."', ";
$QryInsertMessage .= "'message_text' = '". addslashes( $Message ) ."';";
doquery( $QryInsertMessage, 'messages');
$QryUpdateUser = "UPDATE {{table}} SET ";
$QryUpdateUser .= "'".$messfields[$Type]."' = '".$messfields[$Type]."' + 1, ";
$QryUpdateUser .= "'".$messfields[100]."' = '".$messfields[100]."' + 1 ";
$QryUpdateUser .= "WHERE ";
$QryUpdateUser .= "'id' = '". $Owner ."';";
doquery( $QryUpdateUser, 'users');
}
函数的功能是往messages表中插入详细消息,并更新users表的消息数量,很明了,呵呵。另外一个函数message()的功能和display()基本相同,就不详细写了,自己看下吧。至此,用户注册流程就分析完了。


猜你喜欢
- 本文实例讲述了通过 jQuery EasyUI框架创建一个RSS阅读器,分享给大家供大家参考。具体如下:运行效果截图如下:我们将使用以下插件
- 最近做某项目的数据库分析,要实现对海量数据的导入问题,就是最多把200万条数据一次导入sqlserver中,如果使用普通的insert语句进
- 1.使用SQL*PLUS停止数据库$ sqlplus /nologSQL> connect / as sysdbaSQL> sh
- 前言:md5解密,百度了一下发现教程不是很多也不详细。这个图都没一张。。。0x01windows环境,kali也可以啊burpsuitere
- 索引的目的在于提高查询效率,可以类比字典,如果要查“mysql”这个单词,我们肯定需要定位到m字母,然后从下往下找到y字母,再找到剩下的sq
- 一、功能介绍在进行推广时,我们可以告诉对方,我们的微信公众账号是什么,客户可以去搜索,然后关注。二维码给我们提供了极大的便捷,只要简单一扫描
- 我们先看一下浅复制的缺陷,不知多少人中过招呢? var oOriginal = { memNum: 1, // number memStr:
- 我的mysql版本 MYSQL V5.7.9,旧版本请使用:UPDATE mysql.user SET Password=PASSWORD(
- 使用正则表达式限制特殊字符的个数package com.l.dubbo.service; import java.util.HashSet;
- 一、创建飞书机器人自定义飞书机器人操作步骤,具体详见飞书官方文档:《机器人 | 如何在群聊中使用机器人?》二、调用飞书发送消息自定义机器人添
- 前言对于很多接触Python的人而言,字符的处理和语言整体的温顺可靠相比显得格外桀骜不驯难以驾驭。文章针对Python 2.7,主要因为3对
- 当地址栏没有参数"id"时: 代码如下:Request.QueryString["ID"] == n
- 在 ASP 的内建对象中除了用于发送、接收和处理数据的对象外,还有一些非常实用的代表 Active Server 应用程序和单个
- 纯JS五子棋(各浏览器兼容)效果图: 代码下载HTML代码<!DOCTYPE html> <html> &
- 1. 多线程的作用简而言之,多线程是并行处理相互独立的子任务,从而大幅度提高整个任务的效率。2. Python中的多线程相关模块和方法Pyt
- 用下列代码即可:<%On error resume nextSet session=Creat
- 使用python编写了共六种图像增强算法:1)基于直方图均衡化2)基于拉普拉斯算子3)基于对数变换4)基于伽马变换5)限制对比度自适应直方图
- 安装环境:CentOS7 64位 MINI版,安装MySQL5.71、配置YUM源在MySQL官网中下载YUM源rpm安装包:http://
- 1.问题引入假设一个场景,一张用户表,包含3个字段。id,identity_id,name。现在身份证号identity_id和姓名name
- 本文实例讲述了Python3爬虫学习之爬虫利器Beautiful Soup用法。分享给大家供大家参考,具体如下:爬虫利器Beautiful