设为首页 收藏本站
查看: 1046|回复: 0

[经验分享] FLEX PHP 交互 简单登录界面(1)源代码

[复制链接]

尚未签到

发表于 2015-8-25 13:03:06 | 显示全部楼层 |阅读模式
  
  
  简单的不能再简单的flex 与 php 交互的 登录界面 (没有使用mysql)
  主要是解决 httpService 的一些问题 代码在附件中 (本例用flex builder 3 和 Deamweaver cs3 完成 下载代码 配置你的服务器 flex 工程直接导入)
  要完成一个表单的提交和返回要通过以下几个环节
  Flex 端全部代码代码
   
         
  • <?xml version=&quot;1.0&quot; encoding=&quot;utf-8&quot;?>        
  • <mx:Application xmlns:mx=&quot;http://www.adobe.com/2006/mxml&quot; layout=&quot;absolute&quot;>        
  • <mx:Script>        
  •     <![CDATA[        
  •         import mx.rpc.events.ResultEvent;        
  •         import mx.controls.Alert;        
  •         private function goLogin():void{        
  •             login.send();        
  •         }        
  •         private function resultHandler(event:ResultEvent):void{        
  •             Alert.show(event.result.html.body.users.a.toString());        
  •         }        
  •       ]]>        
  • </mx:Script>        
  •     <mx:HTTPService id=&quot;login&quot; method=&quot;POST&quot; showBusyCursor=&quot;true&quot; url=&quot;http://localhost/flexlogin.php&quot;      
  •         result=&quot;resultHandler(event)&quot;>        
  •     <mx:request xmlns=&quot;&quot;>        
  •         <mx:username>        
  •             {username.text}        
  •         </mx:username>        
  •         <mx:userpwd>        
  •             {userpwd.text}        
  •         </mx:userpwd>        
  •     </mx:request>        
  •     </mx:HTTPService>        
  •     <mx:Panel width=&quot;310&quot; height=&quot;265&quot; layout=&quot;absolute&quot; title=&quot;登录&quot; fontSize=&quot;12&quot; fontWeight=&quot;normal&quot;>        
  •         <mx:TextInput x=&quot;93&quot; y=&quot;51&quot; id=&quot;username&quot; fontSize=&quot;12&quot;/>        
  •         <mx:TextInput x=&quot;92&quot; y=&quot;95&quot; id=&quot;userpwd&quot; fontSize=&quot;12&quot; displayAsPassword=&quot;true&quot;/>        
  •         <mx:Button x=&quot;73&quot; y=&quot;154&quot; label=&quot;登录&quot; id=&quot;btn1&quot; click=&quot;goLogin()&quot; fontWeight=&quot;normal&quot; fontSize=&quot;12&quot;/>        
  •         <mx:Label x=&quot;32&quot; y=&quot;53&quot; text=&quot;用户名:&quot; fontSize=&quot;12&quot;/>        
  •         <mx:Label x=&quot;43&quot; y=&quot;97&quot; text=&quot;密码:&quot; fontSize=&quot;12&quot;/>        
  •         <mx:Button x=&quot;154&quot; y=&quot;154&quot; label=&quot;注册&quot; fontSize=&quot;12&quot; fontWeight=&quot;normal&quot; id=&quot;btn2&quot;/>        
  •         <mx:Label x=&quot;10&quot; y=&quot;10&quot; text=&quot;测试用 用户名 User 密码 123456&quot; fontSize=&quot;12&quot; width=&quot;243&quot;/>        
  •     </mx:Panel>        
  • </mx:Application>    
<?xml version=&quot;1.0&quot; encoding=&quot;utf-8&quot;?>
<mx:Application xmlns:mx=&quot;http://www.adobe.com/2006/mxml&quot; layout=&quot;absolute&quot;>
<mx:Script>
<![CDATA[
import mx.rpc.events.ResultEvent;
import mx.controls.Alert;
private function goLogin():void{
login.send();
}
private function resultHandler(event:ResultEvent):void{
Alert.show(event.result.html.body.users.a.toString());
}    ]]>
</mx:Script>
<mx:HTTPService id=&quot;login&quot; method=&quot;POST&quot; showBusyCursor=&quot;true&quot; url=&quot;http://localhost/flexlogin.php&quot;
result=&quot;resultHandler(event)&quot;>
<mx:request xmlns=&quot;&quot;>
<mx:username>
{username.text}
</mx:username>
<mx:userpwd>
{userpwd.text}
</mx:userpwd>
</mx:request>
</mx:HTTPService>
<mx:Panel width=&quot;310&quot; height=&quot;265&quot; layout=&quot;absolute&quot; title=&quot;登录&quot; fontSize=&quot;12&quot; fontWeight=&quot;normal&quot;>
<mx:TextInput x=&quot;93&quot; y=&quot;51&quot; id=&quot;username&quot; fontSize=&quot;12&quot;/>
<mx:TextInput x=&quot;92&quot; y=&quot;95&quot; id=&quot;userpwd&quot; fontSize=&quot;12&quot; displayAsPassword=&quot;true&quot;/>
<mx:Button x=&quot;73&quot; y=&quot;154&quot; label=&quot;登录&quot; id=&quot;btn1&quot; click=&quot;goLogin()&quot; fontWeight=&quot;normal&quot; fontSize=&quot;12&quot;/>
<mx:Label x=&quot;32&quot; y=&quot;53&quot; text=&quot;用户名:&quot; fontSize=&quot;12&quot;/>
<mx:Label x=&quot;43&quot; y=&quot;97&quot; text=&quot;密码:&quot; fontSize=&quot;12&quot;/>
<mx:Button x=&quot;154&quot; y=&quot;154&quot; label=&quot;注册&quot; fontSize=&quot;12&quot; fontWeight=&quot;normal&quot; id=&quot;btn2&quot;/>
<mx:Label x=&quot;10&quot; y=&quot;10&quot; text=&quot;测试用 用户名 User 密码 123456&quot; fontSize=&quot;12&quot; width=&quot;243&quot;/>
</mx:Panel>
</mx:Application>
   (flex 全部代码)
  (1)httpservice  标签参数表
  <mx:HTTPService

Properties

concurrency=&quot;multiple|single|last&quot;

contentType=&quot;application/x-www-form-urlencoded|application/xml&quot;

destination=&quot;DefaultHTTP&quot;

id=&quot;No default.&quot;

method=&quot;GET|POST|HEAD|OPTIONS|PUT|TRACE|DELETE&quot;

resultFormat=&quot;object|array|xml|e4x|flashvars|text&quot;

showBusyCursor=&quot;false|true&quot;

makeObjectsBindable=&quot;false|true&quot;

url=&quot;No default.&quot;

useProxy=&quot;false|true&quot;

xmlEncode=&quot;No default.&quot;

xmlDecode=&quot;No default.&quot;

Events

fault=&quot;No default.&quot;

result=&quot;No default.&quot;

/>

几个需要注意的地方 url 为你要请求的网址 result 是返回结果处理的函数,函数要给一个参数为event,事件类型为ResultEvent
  Flex代码


  • <mx:HTTPService id=&quot;login&quot; method=&quot;POST&quot; showBusyCursor=&quot;true&quot; url=&quot;http://localhost/flexlogin.php&quot;
  •     result=&quot;resultHandler(event)&quot;>  
  •    <mx:request xmlns=&quot;&quot;>  
  •     <mx:username>  
  •         {username.text}  
  •     </mx:username>  
  •     <mx:userpwd>  
  •         {userpwd.text}  
  •     </mx:userpwd>  
  •    </mx:request>  
  •    </mx:HTTPService> 

<mx:HTTPService id=&quot;login&quot; method=&quot;POST&quot; showBusyCursor=&quot;true&quot; url=&quot;http://localhost/flexlogin.php&quot;
result=&quot;resultHandler(event)&quot;>
<mx:request xmlns=&quot;&quot;>
<mx:username>
{username.text}
</mx:username>
<mx:userpwd>
{userpwd.text}
</mx:userpwd>
</mx:request>
</mx:HTTPService>
  httpService 标签
  request 标签为你要请求发送的表单,再往里面 <mx:username> 为自己定义,注意:你面的名称为向php方接收的参数名称。
  这段代码发送了两个参数 一个是 username 一个是 userpwd
  Flex代码


  • private function goLogin():void{  
  •             login.send();  
  •         } 

private function goLogin():void{
login.send();
}
  然后点击登录 ,由httpservice 实例的.send()发送请求 (客户端的代码先告一段落)
  下面是php端的全部代码
  Php代码


  • <!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;>  
  • <html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;>  
  • <head>  
  • <meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=utf-8&quot; />  
  • <title>flex login</title>  
  • </head>  


  • <body>  
  • <?php       
  • $return=&quot;&quot;;  
  • if(isset($_POST[username]) && isset($_POST[userpwd])){  
  • if (&quot;User&quot;==$_POST[username] && &quot;123456&quot;==$_POST[userpwd])  
  • $return=&quot;ok&quot;;  
  • else
  • $return=&quot;error&quot;;  
  • }  
  • $xml_return = '<users>';  
  • $xml_return.= '<a>'.$return.'</a>';  
  • $xml_return.= '</users>';  
  • echo $xml_return;  


  • ?>  
  • </body>  
  • </html> 

<!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;>
<html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;>
<head>
<meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=utf-8&quot; />
<title>flex login</title>
</head>
<body>
<?php     
$return=&quot;&quot;;
if(isset($_POST[username]) && isset($_POST[userpwd])){
if (&quot;User&quot;==$_POST[username] && &quot;123456&quot;==$_POST[userpwd])
$return=&quot;ok&quot;;
else
$return=&quot;error&quot;;
}
$xml_return = '<users>';
$xml_return.= '<a>'.$return.'</a>';
$xml_return.= '</users>';
echo $xml_return;
?>
</body>
</html>
  (注意:这是在Dreamweaver cs3 中写的代码)根据你写代码的不同返回的结果不同
    需要说一下的是返回的是什么?
      返回的是一个对象 为什么 event.result.html.body.users.a 呢?
  首先可以确定的是 event.result这部分后面就要看情况了。
  我们可以用event.message.body.toString() 看一下 (结果如下)
  Java代码


  • <!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;>  


  • <html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;>  


  • <head>  


  • <meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=utf-8&quot; />  


  • <title>flex login</title>  


  • </head>  






  • <body>  


  • <users><a><STRONG>ok</STRONG></a></users></body>  


  • </html> 

<!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Transitional//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd&quot;>
<html xmlns=&quot;http://www.w3.org/1999/xhtml&quot;>
<head>
<meta http-equiv=&quot;Content-Type&quot; content=&quot;text/html; charset=utf-8&quot; />
<title>flex login</title>
</head>

<body>
<users><a>ok</a></users></body>
</html>
  所以要根据返回的结果的不同 来分析event 到底是一个什么养的对象 否则放回的结果永远是[object Object]
  所以本例的处理函数为
  Java代码


  • private function resultHandler(event:ResultEvent):void{  
  •             Alert.show(event.result.html.body.users.a.toString());  
  •         } 

private function resultHandler(event:ResultEvent):void{
Alert.show(event.result.html.body.users.a.toString());
}
  论坛上还有一个例子是只有php代码的<?php  ?> 不知道event.result 后面怎么写的时候 ,可以尝试打印一下 event.message.body.toString() ;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-104048-1-1.html 上篇帖子: php.ini中配置php错误报告级别 下篇帖子: PHP 12 :字符串的操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表