1

如果这已经得到回答/非常基本/问题措辞不正确,请原谅我,我对此很陌生并且正在苦苦挣扎。

基本上我有生成 XML 的后端 PHP,然后闪存生成器继承数据。我遇到困难的地方是了解 Flash 构建器如何通过 HttpService 向 PHP 发送参数,例如

这是它目前的解释:

http://..../file.php?action=getitems

我希望 flash builder 发送的是

&class=fruit (<- the class would be dependant on what is selected from the drop down in the application)

整体创建这个字符串

http://..../file.php?action=getitems&class=fruit

如果这是胡说八道,谢谢并道歉。我正在使用 Flash Builder 4。

4

3 回答 3

1

总的来说,我会使用 push 方法而不是传递变量,从而减少从中间被黑客入侵的机会。

我的 http 调用的 AS3 代码:

    public function someRequest() : void
    {
        var service : HTTPService = new HTTPService();
        service.url = "http://localhost/getData.php";
        service.useProxy = false;
        service.method = "POST";
        service.contentType = "application/xml";    // Pass XML data.
        service.request = "<ID>somevalue</ID>";     // The XML data.
        service.resultFormat = "xml";               // Recieve XML data.
        service.addEventListener(ResultEvent.RESULT, createFields);
        service.addEventListener(FaultEvent.FAULT, handleFault);
        service.send();
    }

    private function createFields(event : ResultEvent) : void
    {
        var result : String = event.result.toString();
        returnData = XML(result);
    }

    private function handleFault(event : FaultEvent) : void
    {
        var faultstring : String = event.fault.faultString;
        Alert.show(faultstring);
    }

正如您在中间看到的,有一个用于输入变量的 XML 空间。我使用这种方法从 PHP 到 AS3 来回传递数据。

PHP 是:

<?php

define("DATABASE_SERVER", "localhost");
define("DATABASE_USERNAME", "root");
define("DATABASE_PASSWORD", "**");
define("DATABASE_NAME", "dbName");

//connect to the database.
$mysql = mysql_connect(DATABASE_SERVER, DATABASE_USERNAME, DATABASE_PASSWORD);

mysql_select_db(DATABASE_NAME);

$Query  = "SELECT * from data WHERE employeeID = '" . ($_POST['ID']) . "'";
$Result = mysql_query($Query);

$Return = "<data>";

while ($User = mysql_fetch_object($Result))
{
    $Return .= "<user><userid>" . $User->userid . "</userid><username>" . $User->username . "</username><emailaddress>" . $User->emailaddress . "</emailaddress></user>";
}
$Return .= "</data>";
mysql_free_result($Result);
print ($Return)
?>

希望对您有所帮助。

于 2012-04-25T17:03:09.667 回答
1

这实际上在 Flex 中相当简单......

var service : HTTPService = new HTTPService();
service.url = "http://localhost/getData.php";
service.method = "POST";


var parameters:Object = new Object();
parameters["action"] = "getitems";
parameters["class"] = "fruit";

service.send(parameters);

... 完毕!

于 2012-04-25T18:30:46.237 回答
1

我通常通过 [POST] 而不是 [GET] 来处理这个

在您的动作脚本功能中:

private function sendRequest():void {
var obj:Object = new Object();
obj.action="getitems";
obj.class="fruit";

myService.send(obj);

你的 httpService

<s:HTTPService id='myService' url='urlToYourPHP' method='POST' result='yourResultHandler' fault='yourFaultHandler' resultFormat='XML'/>

正如 powelljf3 所说,POST 比 GET 更安全,尽管它仍然可以访问。

于 2012-04-26T10:53:48.923 回答