我已经在这个问题上纠结了大约 5 个小时,我真的很沮丧,需要一些帮助。
我正在编写一个 Perl 脚本,它从 MySQL 表中提取作业,然后执行各种数据库管理任务。当前任务是“创建数据库”。该脚本成功地创建了数据库,但是当我为 PHP 开发人员生成配置文件时,它就崩溃了。
我认为这是引用和取消引用变量的问题,但我不太确定到底发生了什么。我认为在这个函数调用之后,$$result{'databaseName'} 发生了一些事情。这就是我得到结果的方式:$result = $select->fetchrow_hashref()
这是我的函数调用和函数实现:
函数调用(第 127 行):
generateConfig($$result{'databaseName'}, $newPassword, "php");
功能实现:
sub generateConfig {
my($inName) = $_[0];
my($inPass) = $_[1];
my($inExt) = $_[2];
my($goodData) = 1;
my($select) = $dbh->prepare("SELECT id FROM $databasesTableName WHERE name = '$inName'");
my($path) = $documentRoot.$inName."_config.".$inExt;
$select->execute();
if ($select->rows < 1 ) {
$goodData = 0;
}
while ( $result = $select->fetchrow_hashref() )
{
my($insert) = $dbh->do("INSERT INTO $configTableName(databaseId, username, password, path)".
"VALUES('$$result{'id'}', '$inName', '$inPass', '$path')");
}
return 1;
}
错误:
Use of uninitialized value in concatenation (.) or string at ./dbcreator.pl line 142.
Use of uninitialized value in concatenation (.) or string at ./dbcreator.pl line 154.
第 142 行:
$update = $dbh->do("UPDATE ${tablename}
SET ${jobStatus}='${newStatus}'
WHERE id = '$$result{'id'}'");
第 154 行:
print "Successfully created $$result{'databaseName'}\n";
我认为问题出在函数调用的原因是因为如果我注释掉函数调用,一切都会很好!
如果有人可以帮助我了解发生了什么,那就太好了。
谢谢,
ps 如果您发现将整个密码以纯文本形式存储在数据库中存在安全问题,则在正常工作后将得到解决。=P
迪伦