gpt4 book ai didi

PHP 无法从 ActionScript3 接收参数

转载 作者:行者123 更新时间:2023-11-29 23:38:32 26 4
gpt4 key购买 nike

我已经建立了一个网站并与actionscript进行通信。在actionscript中,我构建了一个函数来调用php函数并发布变量以从mysql数据库加载数据。问题是当我调用actionscript函数并将变量发布到php时。php端我调用$_POST['action'];用于从 ActionScript 端接收变量,但是当我想查看这篇文章时 $_POST['action'];错误是这样的

Notice: Undefined index: action in C:\wamp\www\MPA-EM\bin\model.php on line 3

这是一个调用 php 的 ActionScript 函数:

   public function SelectData(TBN:String,TYPE:String):void{
var myrequest:URLRequest = new URLRequest("http://localhost/MPA-EM/bin/model.php");
myrequest.method = URLRequestMethod.POST;

var variables:URLVariables = new URLVariables();
variables.tablename = TBN;
variables.action = TYPE;
myrequest.data = variables;

var loader:URLLoader = new URLLoader();
loader.dataFormat = URLLoaderDataFormat.VARIABLES;
loader.addEventListener(Event.COMPLETE, dataOnLoad);
loader.addEventListener(Event.CANCEL, dataError);

try{
loader.load(myrequest);
}catch(e:Error){
Alert.show(e.toString());
}

}

public function dataOnLoad(evt:Event):void
{
Alert.show(evt.target.data.Result);
if(evt.target.data.Result) {
DText.text = 'ok';
} else DText.text = "Error in select submitted data";

//status is a custom flag passed from back-end
}
public function dataError(e:Event) :void{

DText.text = e.target.errormsg;
}

这是一个 php 函数端 model.php:

<?php 
//test for recive
$actionW = $_POST['action'];//error this line.
echo $actionW;
// end test

if(isset($_POST['action']) && !empty($_POST['action'])) {
$action = $_POST['action'];
echo $action;
switch($action) {
case 'select' :
$tablename = clean($_POST['tablename']);
selectedData($tablename);
break;

case 'blah' : blah();break;
}
}

function selectedData($table){
// create connection
$connection = mysql_connect("localhost", "root", "") or die ("Couldn't connect to the server.");

// select database
$db = mysql_select_db("ideaddcom_maps", $connection) or die ("Couldn't select database.");
// create SQL
$sql = 'SELECT * FROM '.$table;

// execute SQL query and get result
echo $sql;
$sql_result = @mysql_query($sql, $connection) or die ("Couldn't execute query.".mysql_error());


$row = mysql_fetch_object($sql_result);


foreach($row as $cname => $cvalue){
echo "Result=$cvalue";

}

// free resources and close connection
mysql_free_result($sql_result);
mysql_close($connection);

}

//Function to sanitize values received from the form. Prevents SQL injection
function clean($str) {
$str = @trim($str);
if(get_magic_quotes_gpc()) {
$str = stripslashes($str);
}
return mysql_real_escape_string($str);
}



?>

怎么了?请对此有任何想法并谢谢。

最佳答案

我不知道您是否找到了问题的解决方案,但这可能对其他人有帮助。

1 - 看看这里,它可以帮助您:Submitting scores from AS3 to PHP/SQL - #Error 2101

2 - 避免 PHP Undefined index 注意,您应该始终在使用之前验证您的 var 是否已设置,就像您在第 7 行所做的那样。

3 - 避免 PHP 脚本中的 AS 脚本未使用的所有输出,因为 AS只会得到第一个输出。

4 - 如果您使用 forforeach循环以获取 PHP 脚本中的数据,您应该这样做,因为 echo将数据发送到 AS 应该执行一次:

$result = '';
$sep = ',';
foreach($row as $cname => $cvalue){
$result .= $cvalue . $sep;
}
echo 'Result='.$result;

关于PHP 无法从 ActionScript3 接收参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26295359/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com