- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
详细信息:
我正在为一个游戏创建一个注册页面,该游戏有两个具有不同 ip/host 和不同数据库的服务器,另一个在欧洲托管,另一个在美国托管,我正在计划我的注册页面是当用户成功填写表格并单击“注册”按钮时,用户输入的信息将发送到两个不同的数据库,我搜索与我的问题相关的主题,并按照说明进行修复,但是它没有做任何好事。因此,如果您在这里询问我的代码,那就是。
数据库.php
<?php
class Database{
private static $instance = null;
private $stmt = null;
private $host = '';
private $dbname = '';
private $username = '';
private $password = '';
public function __construct(){
$dns = "mysql:dbname=".$this->dbname.";host:".$this->host;
$username= $this->username;
$password= $this->password;
$db = null;
$this->db = new PDO($dns,$username,$password);
}
public static function getInstance(){
if(self::$instance == null){
try{
self::$instance = new Database();
}catch(PDOException $e){
echo $e->getCode();
}
}
return self::$instance;
}
public function query($stmt){
$this->stmt = $this->db->prepare($stmt);
}
//get sql statement
public function getStmt(){
return $this->stmt;
}
public function bind($index, $value, $type = null){
if (is_null($type)) {
switch (true) {
case is_int($value):
$type = PDO::PARAM_INT;
break;
case is_bool($value):
$type = PDO::PARAM_BOOL;
break;
case is_null($value):
$type = PDO::PARAM_NULL;
break;
default:
$type = PDO::PARAM_STR;
}
}
$this->stmt->bindValue($index, $value, $type);
}
public function execute(){
return $this->stmt->execute();
}
public function resultset(){
$this->execute();
return $this->stmt->fetchAll(PDO::FETCH_ASSOC);
}
public function single()
{
$this->execute();
return $this->stmt->fetch(PDO::FETCH_ASSOC);
}
public function __destruct(){
$this->db = null;
}
}
如果我没有添加数据库信息,只是为了安全起见,我很抱歉:),所以我想我需要做的就是在 Database.php 上添加一些东西,但我真的不知道是什么.
下面是我注册页面的验证过程代码
RegistrationProcess.php
<?php
include_once 'Input.php';
include_once 'Database.php';
include_once 'Helper.php';
//variables
$db = Database::getInstance();
$username = '';
$password = '';
$email = '';
$country = '';
$city = '';
$question = '';
$answer = '';
$ip = Helper::get_ip_address();
$valid = true;
$msg = '';
if (Input::hasPost()) {
if (Input::post('username') === null) {
$msg = 'Please put your username.';
$valid = false;
$username = Input::post('username');
} else if (Input::post('password') === null || Input::post('con_password') === null ) {
$msg = 'Input password properly!';
$valid = false;
} else if (Input::post('password') !== Input::post('con_password')) {
$msg = 'Password and confirm password must be the same.';
$valid = false;
} else if (Input::post('country') === 'select') {
$msg = 'Select a country.';
$valid = false;
} else if (Input::post('email') === null) {
$msg = 'Put your email.';
$valid = false;
} else if (!filter_var(Input::post('email'), FILTER_VALIDATE_EMAIL)) {
$msg = 'Invalid email.';
$valid = false;
} else if (Input::post('question') === 'select') {
$msg = 'Select a question.';
$valid = false;
} else if (Input::post('answer') === null) {
$msg = 'Put your answer.';
$valid = false;
}
if ($valid) {
$db = Database::getInstance();
$username = Input::post('username');
$password = Input::post('con_password');
$email = Input::post('email');
$country = Input::post('country');
$question = Input::post('question');
$answer = Input::post('answer');
//banned account
$sql = "SELECT * FROM accounts WHERE IP = :ip AND State = 1";
$db->query($sql);
$db->bind(':ip', $ip);
$banned = $db->single();
// > 1 account
$sql = "SELECT * FROM accounts WHERE IP = :ip";
$db->query($sql);
$db->bind(':ip', $ip);
$anotherAccount = $db->resultset();
//already exist name
$sql = "SELECT * FROM accounts WHERE Username = :username";
$db->query($sql);
$db->bind(':username', $username);
$existAccount = $db->single();
if ($existAccount && (count($existAccount) > 0)) {
$msg = 'The Username is already exist.';
$valid = false;
} else if ($banned && (count($banned) > 0)) {
$msg = 'Sorry you cannot register because your banned!';
$valid = false;
} else if ($anotherAccount && (count($anotherAccount) > 5)) {
$msg= 'Sorry you cannot register because you made to many accounts.';
$valid = false;
} else {
$sql = "INSERT INTO accounts (`Username`, `Password`, `IP`, `Email`, `Question`, `answer`, `Country`)
VALUES (:username, :password, :ip, :email, :question, :answer, :country)";
$db->query($sql);
$db->bind(':username', $username);
$db->bind(':password', $password);
$db->bind(':ip', $ip);
$db->bind(':email', $email);
$db->bind(':question', $question);
$db->bind(':answer', $answer);
$db->bind(':country', $country);
if ($db->execute()) {
$msg = "The user has been succesfully added into the database! You can now log into the community and in-game!";
$msg .= " Thank you for registering for West Gaming!<br>";
$msg .= "<span class='management'>- West Gaming Staff</span>";
$valid = true;
unset($_POST);
} else {
$msg = 'There is a problem in our system <br>';
$msg .= 'Please register again with the same data.';
$valid = false;
}
}
}
}
那就是..希望你能帮助我,如果你能帮助我,在此先感谢你。
最佳答案
只需创建 2 个 Database
类实例。
摆脱,公共(public)静态函数 getInstance(){}
不要这样做:
$db = Database::getInstance();
相反:
$db1 = new Database();
$db2 = new Database();
将 Database
构造器编辑成类似的东西
public function __construct($dns, $username, $password){
$this->db = new PDO($dns,$username,$password);
}
关于php - 如何使 php 代码连接到具有两个不同主机的两个不同数据库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23380477/
我在这里想做的是将所有连接转发到机器一上端口 3306 上的本地主机到本地主机上端口 3306 上的机器二。因此,如果您连接到机器一上的 mysql,它的行为就像您正在连接一样在二号机器上。 我认为
通过Kibana界面,如何获得 flex IP /主机? 我的意思是,与kibana连接的Elastic主机。 那有可能吗?我在这个上挣扎了好几个小时,却一无所获:( 附:不确定此问题是否是题外话,应
我知道这听起来很奇怪,但我有一个情况,Deno 需要关闭自己的主机(并因此杀死自己的进程)。这可能吗? 我特别需要这个用于 linux (lubuntu),如果相关的话。我想这需要 sudo 权限,这
我知道这听起来很奇怪,但我有一个情况,Deno 需要关闭自己的主机(并因此杀死自己的进程)。这可能吗? 我特别需要这个用于 linux (lubuntu),如果相关的话。我想这需要 sudo 权限,这
我有一个基本问题,但谷歌并没有为我产生很多结果(反正不是英文的)。基本上我想做的就是: 我有一个图形需要用作整个应用程序的持久 header ,例如:我不能让它在新的 Intent 调用时从屏幕上滑出
您好,我正在使用 xampp,我正在尝试使用 php 进行连接。 $sql_connections = mysql_connect("$server, $username, $password")
我目前正在尝试一些多人游戏的想法,并正在尝试创建一个 Java 应用程序来为基于网络浏览器的多人游戏提供服务。 我的开发环境是主机上的Eclipse, native 上的notepad + Googl
今天为大家分享一篇关于SSH 的介绍和使用方法的文章。本文从SSH是什么出发,讲述了SSH的基本用法,之后在远程登录、端口转发等多种场景下进行独立的讲述,希望能对大家有所帮助。 什么是SSH?
我已经完成了在裸机 Centos 7 上运行的测试 Kubernets 主机的设置。这将用作测试系统,因为我们将在 IBM Bluemix Kubernetes 服务中部署所有内容。 从 Bluemi
我正在尝试通过带有 4.2(果冻 bean )的 android 设备“nexus 7”通过 USB 与我的 freeduino 板进行通信,该板类似于 arduino uno。 几个月后,我使用开发
我正在使用 nginx,但在设置反向代理时遇到问题。 我的 nginx.conf 是默认的(没有对其进行任何更改),我的站点可用配置是: upstream backend_hosts { se
我在 projectlocker(免费 svn 主机)上有一个帐户,但我不知道如何将我的项目文件上传到它。 我在我的仪表板中找不到任何选项。 我在我的电脑上使用tortoiseSvn,那么如何上传文件
设置batchSize = 1有意义吗?如果我想一次处理一个文件? 尝试过batchSize = 1000和batchSize = 1 - 似乎具有相同的效果 { "version": "2.0"
我只想知道.. docker中现在有任何可用的工具吗?我已经阅读了Docker中有关多主机功能的一些文档,例如, Docker群 Docker服务(带有副本) 我也知道群模式下的volume问题,容器
我想将文件从 Docker 的容器挂载到我的 docker 主机。 数据卷不是我的解决方案,因为它们是从 docker 主机到 docker 容器的装载,我需要相反的方法。 谢谢 最佳答案 当 doc
我是新手。我无法正确理解RMI。互联网上有大量教程,但据我所知,它们都是针对本地主机的。服务器和客户端都运行在同一台机器上。 我想在任何计算机上运行客户端,并且主机将位于一台计算机上,让我们考虑IP
我无法从客户端“A”SSH 到服务器“B”(但我可以从同一子网上的许多其他 ssh 客户端而不是“A”——所有都是 *nux 机器) serverA>ssh -v -p 端口用户@serverB Op
设置batchSize = 1有意义吗?如果我想一次处理一个文件? 尝试过batchSize = 1000和batchSize = 1 - 似乎具有相同的效果 { "version": "2.0"
由于我不是天生的编码员,请多多包涵。 这是我尝试使用HAproxy来实现的目标,但是经过数小时的检查后,我无法以某种方式使其工作。 从 domain.com/alpha domain.com/beta
我正在使用 tomcat 运行 Java Web 应用程序,通过电子邮件将生成的报告发送给用户。我可以发送电子邮件,但几个小时后服务器停止发送电子邮件,并出现以下错误。 javax.mail.Mess
我是一名优秀的程序员,十分优秀!