flex中httpservice与java后台交互的两种传值方式

news/2024/5/19 18:18:40 标签: Flex, Java, Servlet, Adobe, 浏览器

 环境:myeclipse8.5+flex4+blazeds
            描述:flex4中httpservice与服务器端交互的值传递问题
            方式一:通过<s:request/>标签进行交互,在该标签内部以要传递的参数名作为该标签内的子标签,值作为内容进行传递,服务端接受数据采用request.getParmeter("参数名")获取数据.
            示例代码:
            flex中的代码:

<!-- 定义HttpService发送请求 -->
        
< s:HTTPService  id ="service"  
                       url
="http://localhost:8080/testhttpservice/testHttpServiceServlet"  
                       useProxy
="false"  
                       fault
="service_faultHandler(event)"  
                       result
="service_resultHandler(event)" >
            
<!-- 第一种传值方式 -->
            
            
< s:request  >
                
<!-- 参数名称作标签,中间填充参数值 -->
                
< username > {txtusername.text} </ username >
                
< password > {txtpassword.text} </ password >
            
</ s:request >
            
        
</ s:HTTPService >

        后台接受参数的代码:

         // 获取flex传递的参数 username password
        String username = request.getParameter( " username " );
        
// get方式处理乱码
        
// username=new String(username.getBytes("ISO-8859-1"),"utf-8");
        String password = request.getParameter( " password " );
        
// password=new String(password.getBytes("ISO-8859-1"),"utf-8");

        方式二:第二种传值方式通过send()方法传值send方法中传递参数 ,服务端接受数据采用request.getParmeter("参数名")获取数据.
        示例代码:

                 //第二种传值方式 通过send()方法传值 send方法中传递参数 
                //定义一object对象
                var val:Object=new Object();
                //分别将文本框username,password的值传递到后台
                //object对象.参数名=值   传值操作
                val.username=txtusername.text;
                val.password=txtpassword.text;
                service.send(val);

        贴出完整的代码:
        服务器端:

package  com.servlet;

import  java.io.IOException;
import  java.io.PrintWriter;
import  java.util.ArrayList;
import  java.util.List;

import  javax.servlet.ServletException;
import  javax.servlet.http.HttpServlet;
import  javax.servlet.http.HttpServletRequest;
import  javax.servlet.http.HttpServletResponse;

/** */ /**
 * 功能描述:flex httpservice与java交互参数传递探讨<br>
 * 
@author  sxyx2008<br>
 * @date 2010-07-19
 *
 
*/

@SuppressWarnings(
" serial " )
public   class  TestHttpServiceServlet  extends  HttpServlet  {
    
    @Override
    
protected   void  service(HttpServletRequest request, HttpServletResponse response)
            
throws  ServletException, IOException  {
        
// 处理post方式乱码
        request.setCharacterEncoding( " utf-8 " );
        
// 设置浏览器输出字符编码
        response.setCharacterEncoding( " utf-8 " );
        PrintWriter writer
= response.getWriter();
        
// 获取flex传递的参数 username password
        String username = request.getParameter( " username " );
        
// get方式处理乱码
        
        
// username=new String(username.getBytes("ISO-8859-1"),"utf-8");
        String password = request.getParameter( " password " );
        
// password=new String(password.getBytes("ISO-8859-1"),"utf-8");
        
        
// 构建一个list存放一些数据用来模拟用户是否存在这一功能
        List < String >  list = new  ArrayList < String > ();
        list.add(
" 张三 " );
        list.add(
" 李四 " );
        list.add(
" 王五 " );
        list.add(
" 曹操 " );
        list.add(
" 孙权 " );
        list.add(
" 刘备 " );
        
// 检验用户
         if (list.contains(username)) {
            writer.print(
" 存在: " + username + " 客户端传递的密码是: " + password);
        }
else {
            writer.print(
" 找不到: " + username + " 客户端传递的密码是: " + password);
        }

        
    }

}

        flex代码:

<? xml version="1.0" encoding="utf-8" ?>
< s:Application  xmlns:fx ="http://ns.adobe.com/mxml/2009"  
               xmlns:s
="library://ns.adobe.com/flex/spark"  
               xmlns:mx
="library://ns.adobe.com/flex/mx"  minWidth ="955"  minHeight ="600" >
    
< fx:Script >
        
<![CDATA[
            import mx.controls.Alert;
            import mx.rpc.events.FaultEvent;
            import mx.rpc.events.ResultEvent;

            //调用失败
            protected function service_faultHandler(event:FaultEvent):void
            {
                Alert.show("失败了:"+event.message,"提示");
            }

            //调用成功
            protected function service_resultHandler(event:ResultEvent):void
            {
                Alert.show("成功了:"+event.result as String,"提示");
            }
    
            //调用
            protected function button1_clickHandler(event:MouseEvent):void
            {
                //第一种传值方式                
                //service.send();
                
                //第二种传值方式 通过send()方法传值 send方法中传递参数 
                //定义一object对象
                var val:Object=new Object();
                //分别将文本框username,password的值传递到后台
                //object对象.参数名=值   传值操作
                val.username=txtusername.text;
                val.password=txtpassword.text;
                service.send(val);
            }

        
]]>
    
</ fx:Script >
    
< fx:Declarations >
        
<!--  将非可视元素(例如服务、值对象)放在此处  -->
        
<!-- 定义HttpService发送请求 -->
        
< s:HTTPService  id ="service"  
                       url
="http://localhost:8080/testhttpservice/testHttpServiceServlet"  
                       useProxy
="false"  
                       fault
="service_faultHandler(event)"  
                       result
="service_resultHandler(event)" >
            
<!-- 第一种传值方式 -->
            
            
< s:request  >
                
<!-- 参数名称作标签,中间填充参数值 -->
                
< username > {txtusername.text} </ username >
                
< password > {txtpassword.text} </ password >
            
</ s:request >
            
        
</ s:HTTPService >
        
        
    
</ fx:Declarations >
    
< s:TextInput  x ="332"  y ="196"  id ="txtusername" />
    
< s:TextInput  x ="332"  y ="256"  id ="txtpassword"  displayAsPassword ="true" />
    
< s:Button  x ="357"  y ="311"  label ="发送"  click ="button1_clickHandler(event)" />
    
< s:Label  x ="290"  y ="206"  text ="用户名:" />
    
< s:Label  x ="297"  y ="266"  text ="密码:" />
</ s:Application >

http://www.niftyadmin.cn/n/1003243.html

相关文章

一个微博数据库设计带来的简单思考

在微博系统中&#xff0c;当前用户、关注者&#xff08;也就是粉丝&#xff09;、被关注者&#xff08;崇拜对象&#xff09; 这三种角色是少不了的。他们之间看似简单的关系&#xff0c;但是其中数据库表将如何设计&#xff0c;却让我很难琢磨&#xff0c;在如下解决方案中&am…

S5PV210 LCD显示

第一节 S5PV210 LCD控制器要使一块LCD正常显示文字或图像&#xff0c;不仅需要LCD驱动器&#xff0c;还需要相应的LCD控制器。LCD控制器的主要作用是将在系统存储器中的显示缓冲区中的LCD图像数据传送到外部LCD驱动器&#xff0c;并产生必要的控制信号&#xff0c;例如VSYNC、H…

页面上显示PDF, 但是不显示工具栏(IE).

有些时候我们要在IE上显示一个PDF, 例如服务器上生成的PDF. 但是不想让用户保存下来. 本质上来说这是实现不了的, 因为显示PDF用的是客户端的acrobat的ActiveX控件. 既然数据已经到了客户端, 想要找到数据的内容总是可以找到的. 下面提供一种方法, 可以把acrobat控件的工具栏隐…

python中的import

import importable import * 这种语法格式将从模块中导入所有对象的(或从包中导入所有模块) from os.path import * 将导入大约40个名称,包含dirname,exists以及split等名称 鉴于import * 这种语法格式潜在的导致名称冲突的语法,有些team在指南中只能使用import importable这种…

程序员的七种武器(转载)

2019独角兽企业重金招聘Python工程师标准>>> 信息技术的发展时间虽然不长&#xff0c;但其爆炸式的发展速度使信息技术迅速覆盖社会和人类生活的各个角落。程序员们是这场信息化浪潮的见证者之一&#xff0c;更是其中的主要参与者&#xff0c;这是时代赋予每个程序员…

PMP项目经理认证

PMP认证是由美国项目管理学会(PMI)在全球范围内推出的针对项目经理的资格认证体系&#xff0c;通过该认证的项目经理叫"PMP"&#xff0c;即Project Management Professional&#xff08;项目管理专业人员&#xff09;。 自从1984年以来&#xff0c;美国项目管理协会&…

2013年元旦记

平凡的日记&#xff0c;开心每一天 呵&#xff5e;&#xff0c;又到一年辞旧迎新时&#xff0c;这里祝福亲朋好友新年快乐&#xff0c;元旦三天假正悄声无息的流走&#xff0c;元旦第一天晚上&#xff0c;同事们在宿舍一起打火锅&#xff0c;弄的年味十足&#xff0c;各种好吃的…

NOSQL系列-memcached安装管理与repcached高可用性

Memcached &#xff1a;基于内存工作键值存储型数据库&#xff0c;可以作为应用->memcached 缓存层->数据库。Danga Interactive公司开发&#xff0c;最初为了加速LiveJournal访问速度而开发的&#xff0c;后来成为广泛应用的开源项目。 一、实验环境 1.系统类型 [leoh4 …