336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.
Flex2 와 PHP 와의 연동 예제를 Adobe 에서 직접 친절하게 제시해 주었다.
제시해준데로 간단한 회원 추가/조회 기능의 예제를 만들어 보았다.
예제에 쓰인 준비물 : php, mysql, flex2 sdk
1. 회원 정보를 담아둘 간단한 db table 은 만든다.
2. 회원 정보를 추가하는 DB INSERT , 조회할때 XML 데이터로 떨구는 기능의 간단한 php 파일을 만든다.
[request.php]
코드를 보면 다 알겠지만 간단히 설명을 덧붙이자면,
$_POST 값이 넘어오면 db INSERT 가 일어나고,
users 테이블의 데이터를 가져와 xml 데이터 형식으로 만들어서 뿌려준다.
3. flex 와의 연동을 위한 사전 준비작업은 여기까지. 이제 본격적인 flex 코딩이다.
여기서는 편의상 회원 추가폼과 회원 리스트가 한페이지에 구성되어있다.
[user.mxml]
swf 가 로딩이 끝나면(Application 의 creationComplete="userRequest.send()") HTTPService 로 request.php 를 호출하여 request.php 가 만들어준 xml 파일의 데이터를 바인딩 한다.
회원을 추가하고 Submit 버튼을 클릭하면 request.php 로 username,emailaddress 값을 post 방식으로 넘긴다.
flex 가 제공하는 막강한 리스트 (하지만 무거운 ㅎㅎ) DataGrid 로 바인딩한 데이터들을 오름차순(lastResult)으로 뿌려준다.
4. user.mxml 을 컴파일 한 후, 생성된 user.swf 를 request.php 가 있는곳으로 업로드 한다.
경험상, user.swf 와 request.php 파일이 같은 서버에 있지 않으면 http로 시작하는 절대주소로 도메인으로 맞춰준다고 하더라도 통신이 제대로 이루어지지 않는다. 이유는 잘 모르겠다;;
이제 서버에 올려진 user.swf 를 브라우저에서 열어보자.
HTTPService 를 이용해서 매우 간단하게 flex 와 php 사이의 xml 데이터 통신이 이루어졌다.
특별히 php + mysql 에 특화된 방법이라고는 볼 순 없고, 떨구는 xml 형식만 맞춰준다면 jsp,asp 등의 다른 스크립트 언어도 가능하다.
물론 db 역시 꼭 mysql 아니여도 서버측 스크립트와 연동 가능한 모든 db 뿐만 아니라, 떨구는 데이터를 xml 형식으로 맞춰주기만 한다면 파일 형태의 데이터도 가능할 것으로 보인다.
flex 2 의 db 와의 연동은 이정도에 기초해서 응용해 나가는게 좋을법 싶다.
확인해보니 FLEX 3에서도 위와같은 방법은 사용이 가능하다.
출처 : http://julymorning.co.kr/xe/?document_srl=1273
제시해준데로 간단한 회원 추가/조회 기능의 예제를 만들어 보았다.
예제에 쓰인 준비물 : php, mysql, flex2 sdk
1. 회원 정보를 담아둘 간단한 db table 은 만든다.
CREATE TABLE users(
userid INT NOT NULL auto_increment,
username VARCHAR( 255 ) NOT NULL ,
emailaddress VARCHAR( 255 ) NOT NULL
)
userid INT NOT NULL auto_increment,
username VARCHAR( 255 ) NOT NULL ,
emailaddress VARCHAR( 255 ) NOT NULL
)
2. 회원 정보를 추가하는 DB INSERT , 조회할때 XML 데이터로 떨구는 기능의 간단한 php 파일을 만든다.
[request.php]
<?php
define( "DATABASE_SERVER", "localhost" );
define( "DATABASE_USERNAME", "root" );
define( "DATABASE_PASSWORD", "" );
define( "DATABASE_NAME", "sample" );
//connect to the database
$mysql = mysql_connect(DATABASE_SERVER, DATABASE_USERNAME, DATABASE_PASSWORD);
mysql_select_db( DATABASE_NAME );
// Quote variable to make safe
function quote_smart($value)
{
// Stripslashes
if (get_magic_quotes_gpc()) {
$value = stripslashes($value);
}
// Quote if not integer
if (!is_numeric($value)) {
$value = "'" . mysql_real_escape_string($value) . "'";
}
return $value;
}
if( $_POST["emailaddress"] AND $_POST["username"])
{
//add the user
$Query = sprintf("INSERT INTO users VALUES ('', %s, %s)", quote_smart($_POST['username']), quote_smart($_POST['emailaddress']));
$Result = mysql_query( $Query );
}
//return a list of all the users
$Query = "SELECT * from users";
$Result = mysql_query( $Query );
$Return = "<users>";
while ( $User = mysql_fetch_object( $Result ) )
{
$Return .= "<user><userid>".$User->userid."</userid><username>".$User->username."</username><emailaddress>".$User->emailaddress."</emailaddress></user>";
}
$Return .= "</users>";
mysql_free_result( $Result );
print ($Return)
?>
define( "DATABASE_SERVER", "localhost" );
define( "DATABASE_USERNAME", "root" );
define( "DATABASE_PASSWORD", "" );
define( "DATABASE_NAME", "sample" );
//connect to the database
$mysql = mysql_connect(DATABASE_SERVER, DATABASE_USERNAME, DATABASE_PASSWORD);
mysql_select_db( DATABASE_NAME );
// Quote variable to make safe
function quote_smart($value)
{
// Stripslashes
if (get_magic_quotes_gpc()) {
$value = stripslashes($value);
}
// Quote if not integer
if (!is_numeric($value)) {
$value = "'" . mysql_real_escape_string($value) . "'";
}
return $value;
}
if( $_POST["emailaddress"] AND $_POST["username"])
{
//add the user
$Query = sprintf("INSERT INTO users VALUES ('', %s, %s)", quote_smart($_POST['username']), quote_smart($_POST['emailaddress']));
$Result = mysql_query( $Query );
}
//return a list of all the users
$Query = "SELECT * from users";
$Result = mysql_query( $Query );
$Return = "<users>";
while ( $User = mysql_fetch_object( $Result ) )
{
$Return .= "<user><userid>".$User->userid."</userid><username>".$User->username."</username><emailaddress>".$User->emailaddress."</emailaddress></user>";
}
$Return .= "</users>";
mysql_free_result( $Result );
print ($Return)
?>
코드를 보면 다 알겠지만 간단히 설명을 덧붙이자면,
$_POST 값이 넘어오면 db INSERT 가 일어나고,
users 테이블의 데이터를 가져와 xml 데이터 형식으로 만들어서 뿌려준다.
3. flex 와의 연동을 위한 사전 준비작업은 여기까지. 이제 본격적인 flex 코딩이다.
여기서는 편의상 회원 추가폼과 회원 리스트가 한페이지에 구성되어있다.
[user.mxml]
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns="*" layout="absolute" creationComplete="userRequest.send()">
<mx:HTTPService id="userRequest" url="http://yourDomain.com/yourPath/request.php" useProxy="false" method="POST">
<mx:request xmlns="">
<username>{username.text}</username><emailaddress>{emailaddress.text}</emailaddress>
</mx:request>
</mx:HTTPService>
<mx:Form x="22" y="10" width="493">
<mx:HBox>
<mx:Label text="Username"/>
<mx:TextInput id="username"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="Email Address"/>
<mx:TextInput id="emailaddress"/>
</mx:HBox>
<mx:Button label="Submit" click="userRequest.send()"/>
</mx:Form>
<mx:DataGrid id="dgUserRequest" x="22" y="128" dataProvider="{userRequest.lastResult.users.user}">
<mx:columns>
<mx:DataGridColumn headerText="User ID" dataField="userid"/>
<mx:DataGridColumn headerText="User Name" dataField="username"/>
</mx:columns>
</mx:DataGrid>
<mx:TextInput x="22" y="292" id="selectedemailaddress" text="{dgUserRequest.selectedItem.emailaddress}"/>
</mx:Application>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns="*" layout="absolute" creationComplete="userRequest.send()">
<mx:HTTPService id="userRequest" url="http://yourDomain.com/yourPath/request.php" useProxy="false" method="POST">
<mx:request xmlns="">
<username>{username.text}</username><emailaddress>{emailaddress.text}</emailaddress>
</mx:request>
</mx:HTTPService>
<mx:Form x="22" y="10" width="493">
<mx:HBox>
<mx:Label text="Username"/>
<mx:TextInput id="username"/>
</mx:HBox>
<mx:HBox>
<mx:Label text="Email Address"/>
<mx:TextInput id="emailaddress"/>
</mx:HBox>
<mx:Button label="Submit" click="userRequest.send()"/>
</mx:Form>
<mx:DataGrid id="dgUserRequest" x="22" y="128" dataProvider="{userRequest.lastResult.users.user}">
<mx:columns>
<mx:DataGridColumn headerText="User ID" dataField="userid"/>
<mx:DataGridColumn headerText="User Name" dataField="username"/>
</mx:columns>
</mx:DataGrid>
<mx:TextInput x="22" y="292" id="selectedemailaddress" text="{dgUserRequest.selectedItem.emailaddress}"/>
</mx:Application>
swf 가 로딩이 끝나면(Application 의 creationComplete="userRequest.send()") HTTPService 로 request.php 를 호출하여 request.php 가 만들어준 xml 파일의 데이터를 바인딩 한다.
회원을 추가하고 Submit 버튼을 클릭하면 request.php 로 username,emailaddress 값을 post 방식으로 넘긴다.
flex 가 제공하는 막강한 리스트 (하지만 무거운 ㅎㅎ) DataGrid 로 바인딩한 데이터들을 오름차순(lastResult)으로 뿌려준다.
4. user.mxml 을 컴파일 한 후, 생성된 user.swf 를 request.php 가 있는곳으로 업로드 한다.
경험상, user.swf 와 request.php 파일이 같은 서버에 있지 않으면 http로 시작하는 절대주소로 도메인으로 맞춰준다고 하더라도 통신이 제대로 이루어지지 않는다. 이유는 잘 모르겠다;;
이제 서버에 올려진 user.swf 를 브라우저에서 열어보자.
HTTPService 를 이용해서 매우 간단하게 flex 와 php 사이의 xml 데이터 통신이 이루어졌다.
특별히 php + mysql 에 특화된 방법이라고는 볼 순 없고, 떨구는 xml 형식만 맞춰준다면 jsp,asp 등의 다른 스크립트 언어도 가능하다.
물론 db 역시 꼭 mysql 아니여도 서버측 스크립트와 연동 가능한 모든 db 뿐만 아니라, 떨구는 데이터를 xml 형식으로 맞춰주기만 한다면 파일 형태의 데이터도 가능할 것으로 보인다.
flex 2 의 db 와의 연동은 이정도에 기초해서 응용해 나가는게 좋을법 싶다.
확인해보니 FLEX 3에서도 위와같은 방법은 사용이 가능하다.
출처 : http://julymorning.co.kr/xe/?document_srl=1273
'# IT, Computer Science > ETC' 카테고리의 다른 글
Flex DataGrid Auto Sort / dispathcEvent (0) | 2010.05.02 |
---|