회원가입아이디/비번찾기
실시간 TV
홈으로
flex + php + mysql
12년 전
Flex2 와 PHP 와의 연동 예제를 Adobe 에서 직접 친절하게 제시해 주었다.
제시해준데로 간단한 회원 추가/조회 기능의 예제를 만들어 보았다.

예제에 쓰인 준비물 : 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
)



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)
?>


코드를 보면 다 알겠지만 간단히 설명을 덧붙이자면,
$_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>


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 와의 연동은 이정도에 기초해서 응용해 나가는게 좋을법 싶다.
추천추천 : 513 추천 목록
번호 제목
2,885
 input 입력 필드 앞뒤 공백 실시간 제거
2,884
 Placeholder 포커스시 감추기
2,883
 MySQL 중복된 데이터를 삭제
2,882
 MySQL 중복 데이터 확인
2,881
 sessionStorage.getItem 와 sessionStorage.setItem
2,880
 제이쿼리 랜덤으로 배경색 변경
2,879
 preg match에 관한 정규식
2,878
 Stream an audio file with MediaPlayer 오디오 파일 스트리밍 하기
2,877
 Audio Streaming PHP Code
2,876
 PHP $ SERVER 환경 변수 정리
2,875
 Vimeo (비메오) API 를 사용하여 플레이어 컨트롤하기
2,874
 iframe 사용시 하단에 발생하는 공백 제거방법
2,873
 아이프레임(iframe) 전체화면 가능하게 하기
2,872
 부트스트랩(bootstrapk)에서 사용하는 class명 정리
2,871
 부트스트랩 CSS
2,870
 크롬에서 마진 조절
2,869
 PHP 현재 페이지의 도메인명이나 url등의 정보 알아오기
2,868
 PHP preg match all()
2,867
 PHP 로 웹페이지 긁어오기 모든 방법 총정리!
2,866
 [PHP] 원격지 파일 주소 노출 안하고 curl로 다운로드 받기
2,865
 PHP 함수 정리
2,864
 아이프레임(iframe) 비율 유지하면서 크기 조절하는 방법
2,863
 PHP 배열에서 무작위로 하나 뽑아주는 array rand() 함수
2,862
 PHP 정규식 정리
2,861
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
2,860
 php 크롤링 또는 파싱 함수, 정규식 모음
2,859
 제이쿼리 기본 명령어
2,858
 웹페이지 가로 모드세로 모드 인식하기
2,857
 모바일 웹 화면 강제 회전(가로모드 고정)
2,856
 [HTML5]에서 frameset 대체 방법과 iframe 속성
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright ⓒ musictrot All rights reserved.