`
gjs622520
  • 浏览: 41865 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

flex3与java通信

阅读更多
flex与java通信可以使用HTTPService、RemoteObject。
HTTPService也可以有多种做法,text、xml、json等。
最简单的例子真接返回text:
flex_java.mxml
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" viewSourceURL="srcview/index.html">
	<mx:HTTPService id="service" url="http://localhost:8888/flex_server/servlet/GetData" result="serviceRequest(event)"
	 method="GET" >	 
	 	<mx:request xmlns="">
	 		<name>
	 			{n.text}
	 		</name>
	 	</mx:request>	 
	 </mx:HTTPService>
	<mx:Script>
		<![CDATA[
			//当 HTTPService 调用成功返回时调度
			private function serviceRequest(event:Event):void{
				r.text=service.lastResult.toString();
			}
			
			private function send():void{
				//发送请求
				service.send();
			}
		]]>
	</mx:Script>
	<mx:Label text="姓名:" x="275" y="55" fontSize="16" fontWeight="bold"/>
	<mx:TextInput id="n" x="367" y="58"/>
	<mx:TextArea id="r" x="275" y="123" height="149" width="252" editable="false" fontSize="16" textAlign="center"/>
	<mx:Label x="275" y="91" text="简介:" fontSize="16" fontWeight="bold"/>
	<mx:Button x="367" y="94" label="查询" width="160" fontSize="15" fontWeight="bold" height="23" click="send()"/>
</mx:Application>

以get方式发送请求,request标签内是参数。
GetData.java
package servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class GetData extends HttpServlet {
	public GetData() {
		super();
	}

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String name=request.getParameter("name");
		response.setContentType("text/xml");
		response.setCharacterEncoding("utf-8");
		PrintWriter out = response.getWriter() ;
		if(name!=null&&!"".equals(name)){
			if(name.equals("gao")){
				out.print("这是个好人呀!");
			}else if(name.equals("wang")){
				out.print("坏人,很坏的人,不是人!");
			}else{
				out.print("外星人!!");
			}
		}
		out.close();
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

	public void init() throws ServletException {
	}
}

以json返回方式:
java端用json生成类的json字符串,发送到flex客户端,flex再解析json为flex的类,这要使用到java的json包和flex的json包,我用的是json-lib-2.2.2-jdk15.jar和as3corelib.swc。
login.mxml:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
	<mx:HTTPService id="form" result="returnResult(event)" resultFormat="text" url="http://localhost:8888/flex_server/LoginServlet">
		<mx:request xmlns="">
			<name>
				{n.text}
			</name>
			<psw>
				{p.text}
			</psw>
		</mx:request>
	</mx:HTTPService>
	<mx:Script>
		<![CDATA[
			import com.adobe.serialization.json.JSON;
			import mx.rpc.events.ResultEvent;
			private function returnResult(event:ResultEvent):void{				
				var person:Object=JSON.decode(event.result.toString());
				t.text+=person.name;
				t.text+=person.age;
				t.text+=person.sex;
			}
			
			private function logins():void{
				form.send();
			}
		]]>
	</mx:Script>
	<mx:TextArea id="t" height="124" width="336" x="297" y="242"/>
	<mx:Form width="336" height="167" x="297" y="44" borderStyle="outset" borderColor="#9263BD" backgroundColor="#9192AC" backgroundAlpha="0.86">
		<mx:FormItem label="用户名:" fontSize="12" >
			<mx:TextInput id="n"/>
		</mx:FormItem>
		<mx:FormItem label="密码:" fontSize="12" >
			<mx:TextInput id="p"/>
		</mx:FormItem>
		<mx:Button label="登录" click="logins()"/>
	</mx:Form>
</mx:Application>

package servlet;

import gjs.Person;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import net.sf.json.JSONObject;

public class LoginServlet extends HttpServlet {

	public LoginServlet() {
		super();
	}
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/xml");
		response.setCharacterEncoding("utf-8");
		PrintWriter out = response.getWriter();
		String name=request.getParameter("name");
		String psw=request.getParameter("psw");
		if("gjs".equals(name)&&"520".equals(psw)){
			Person p=new Person("王八蛋",22,false);
			JSONObject jo=JSONObject.fromObject(p);
			out.print(jo.toString());
			System.out.println(jo.toString());
		}else{
			out.print("");
		}
		out.close();
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

	public void init() throws ServletException {
		// Put your code here
	}

}


跟前面没什么两样,只是用json转了一下,都是按json接口来的,所以使用起来平台差异都不大。

传xml方式:
Servlet:
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/xml");
		response.setCharacterEncoding("utf-8");
		PrintWriter out = response.getWriter();
		StringBuilder sb=new StringBuilder();
		sb.append("<agents>");
		sb.append("<agent id='100' name='大西瓜' age='21' sex='false'/>");
		sb.append("<agent id='101' name='小西瓜' age='23' sex='true'/>");
		sb.append("<agent id='102' name='烂西瓜' age='24' sex='false'/>");
		sb.append("<agent id='103' name='无子西瓜' age='25' sex='true'/>");
		sb.append("<agent id='104' name='打西瓜' age='27' sex='false'/>");
		sb.append("</agents>");
		out.write(sb.toString());
		
	}

mxml:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical">
	<mx:HTTPService id="h" resultFormat="object" url="http://localhost:8888/Flex/AgentServlet" result="getResult(event)" />
	<mx:Panel label="Agent List">	
	<mx:DataGrid dataProvider="{l}" id="dg" width="100%" height="100%">
		<mx:columns>
			<mx:Array>
				<mx:DataGridColumn headerText="id" dataField="id" />
				<mx:DataGridColumn headerText="name" dataField="name" />
				<mx:DataGridColumn headerText="age" dataField="age" />
				<mx:DataGridColumn headerText="sex" dataField="sex" />
			</mx:Array>
		</mx:columns>
	</mx:DataGrid>
	</mx:Panel>
	<mx:Script>
		<![CDATA[
			import mx.events.DataGridEvent;
			import mx.events.ListEvent;
			import mx.events.ItemClickEvent;
			import mx.collections.ArrayCollection;
			import mx.rpc.events.ResultEvent;
			[Bindable]
			private var l:ArrayCollection;
			private var index:int;
			private function getResult(e:ResultEvent):void{				
				l=e.result.agents.agent as ArrayCollection;
				trace(e.result);
			}
			
			private function send():void{
				h.send();
			}
		]]>
	</mx:Script>	
	<mx:Button click="send()" label="Show Agents" x="420" y="324"/>
</mx:Application>




RemoteObject方式:
先要安装lcds,在remoting-config.xml中加这个

	
<destination id="agentJavaObj">
		<properties>
		<source>gjs.Agent</source>
		<scope>application</scope>
		</properties>
	</destination>


Flex.mxml:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical">
	<mx:RemoteObject id="r" destination="agentJavaObj" />
	<mx:Panel label="Agent List">	
	<mx:DataGrid dataProvider="{l}" id="dg" width="100%" height="100%" itemClick="addSub(event)">
		<mx:columns>
			<mx:Array>
				<mx:DataGridColumn headerText="id" dataField="id" />
				<mx:DataGridColumn headerText="name" dataField="name" />
				<mx:DataGridColumn headerText="age" dataField="age" />
				<mx:DataGridColumn headerText="sex" dataField="sex" />
			</mx:Array>
		</mx:columns>
	</mx:DataGrid>
	</mx:Panel>
	<mx:Script>
		<![CDATA[
			import mx.events.DataGridEvent;
			import mx.events.ListEvent;
			import mx.events.ItemClickEvent;
			import mx.collections.ArrayCollection;
			import mx.rpc.events.ResultEvent;
			[Bindable]
			private var l:ArrayCollection;
			private var index:int;
			private function callJava():void{
				r.getAgent();
				//服务成功返回后调用
				r.addEventListener(ResultEvent.RESULT,showJavaObj);
			}
			private function addSub(e:ListEvent):void{
				index=e.rowIndex;						
				r.addAgent(e.rowIndex);
				r.addEventListener(ResultEvent.RESULT,addAgent);
				//去除之前的事件监听showJavaObj否则还会调用
				r.removeEventListener(ResultEvent.RESULT,showJavaObj);
			}
			private function addAgent(e:ResultEvent):void{
				var o:Object=e.result as Object;
				//加入子元素
				l.addItemAt(o,index+1);
			}
			private function showJavaObj(event:ResultEvent):void{
				l=event.result as ArrayCollection;
			}
		]]>
	</mx:Script>	
	<mx:Button click="callJava()" label="Show Agents" x="420" y="324"/>
</mx:Application>


Agent.java:
package gjs;

import java.util.ArrayList;
import java.util.List;

public class Agent {
	private long id;
	private String name;
	private int age;
	private boolean sex;
	//一定要有无参构造,因为写了有参构造没有默认的无参了
	public Agent(){
		
	}
	public Agent(long id,String name,int age,boolean sex){
		this.id=id;
		this.name=name;
		this.age=age;
		this.sex=sex;
	}
	
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public int getAge() {
		return age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public boolean isSex() {
		return sex;
	}
	public void setSex(boolean sex) {
		this.sex = sex;
	}
	public long getId() {
		return id;
	}
	public void setId(long id) {
		this.id = id;
	}
	public List<Agent> getAgent(){
		Agent a1=new Agent(100,"王八蛋",23,false);
		Agent a2=new Agent(101,"王九蛋",22,true);
		Agent a3=new Agent(102,"王十蛋",21,false);
		Agent a4=new Agent(103,"王七蛋",20,true);
		List<Agent> l=new ArrayList<Agent>();
		l.add(a1);
		l.add(a2);
		l.add(a3);
		l.add(a4);
		return l;
	}
	
	public Agent addAgent(long id){
		System.out.println(id);
		Agent a1=new Agent(200,"朱重八",33,true);
		return a1;
	}
}


环境配置有点麻烦,可以参考“Flex + LCDS + Java 入门教程”这个文档。
完成
分享到:
评论

相关推荐

    flex3 java 通信

    5. **Flash Remoting**:虽然不是Flex3与Java通信的首选方式,但Flash Remoting(通过NetConnection和NetStream类)仍然可用于与服务器端进行实时数据交换,不过它通常用于Flash Player而不是Flex。 6. **Security*...

    Flex与Java实现通信

    #### 四、使用BlazeDS进行Flex与Java通信 完成上述步骤后,就可以开始使用BlazeDS进行Flex与Java之间的通信了。具体的通信流程包括: 1. **定义服务接口**:在Java中定义一个服务接口,该接口将被Flex应用程序调用...

    flex与java通信

    Flex和Java之间的通信是Web应用程序开发中的一个重要环节,它允许前端用户界面(UI)与后端服务器进行数据交互。Flex是一种基于Adobe Flash Player或Adobe AIR运行时的富互联网应用程序(RIA)开发框架,而Java则是...

    flex4与Java通信实例

    Flex4与Java通信是开发富互联网应用程序(RIA)时的一项重要技术,允许前端用户界面与后端业务逻辑之间进行高效的数据交换。在本实例中,我们探讨了三种Flex4与Java交互的方式:通过RemoteObject、HTTPService以及...

    最简单的BlazeDS实现flex与java通信.rtf

    最简单的BlazeDS实现flex与java通信..无积分下载...最简单的BlazeDS实现flex与java通信..无积分下载...最简单的BlazeDS实现flex与java通信..无积分下载...最简单的BlazeDS实现flex与java通信..无积分下载...最简单的...

    flex与java通信的完整demo

    包含的`flex_3_with_java.pdf`可能是详细的教程文档,涵盖了Flex与Java通信的基础知识和技术细节。`flexdemo.rar`可能是源代码示例,帮助开发者理解并实践这些概念。 9. **应用场景** 这种通信方式常用于实时股票...

    Flex与java通信源码

    3. AMF(Action Message Format):Flex与Java通信常用的一种协议是AMF,它是一种二进制格式,用于提高数据传输效率。AMF能够将ActionScript对象编码为字节流,然后在Flex客户端和Java服务器之间高效地传输。 4. ...

    flex 3 with java.pdf

    本书是为那些希望掌握使用Flex 3创建动态、交互性强的应用程序,并能够与Java后端进行无缝通信的技术人员准备的。 #### 描述:Flex 3 与 Java 本书是一本优秀的学习资源,尽管评论者本人主要专注于.NET技术栈,但...

    Flex4与Java通信 BY LCDS 访问数据库oracle 配置

    Flex4与Java通过LCDS(LiveCycle Data Services)进行通信并访问Oracle数据库的配置过程是一项技术性较强的任务,涉及到多个组件的安装与配置。以下是详细步骤: 首先,Flex4自身无法直接与Oracle数据库进行交互,...

    Flex与Java通信

    Flex与Java通信是一种常见的技术,用于构建富互联网应用程序(RIA)。在这种架构中,Flex作为前端用户界面,而Java作为后端服务器提供业务逻辑和数据处理。以下是对标题、描述和标签所涉及知识点的详细说明: 1. **...

    flex 与 java通信 并运用SSH框架

    flex3 与 JAVA 通信 并且运用 strust2V2.16 + hibernate3.2 +spring2.5 实例 由于我的上传权限太小 那些jar 有需要可以跟我联系 QQ 826785300

    Flex通信-Java服务端通信实例

    这个过程涉及到了数据的序列化和反序列化,以及错误处理,这些都是Flex与Java通信的重要环节。 在实际项目中,还需要考虑安全性问题,如身份验证和授权。可以使用Flex Security框架和Java的安全组件来实现用户登录...

    flex与Java的通信

    在本主题中,我们将深入探讨Flex与Java通信的详细步骤,以及如何通过BlazeDS作为中间件实现这一目标。 首先,Flex是一种基于Adobe Flash Player的开放源代码框架,用于构建富互联网应用程序。Java,另一方面,是一...

    flex与java的通信 Blazeds remoteObject

    Flex与Java的通信是Web应用程序开发中的一个重要环节,特别是在构建富互联网应用(RIA)时。Blazeds作为Adobe官方推出的中间件,为Flex与Java之间的数据交换提供了强大的支持。本篇将深入探讨Blazeds RemoteObject...

    flex flex和 java交互

    标题"flex 和 java交互"指出了一个关键的技术融合,即Flex与Java的整合,允许Flex前端与Java后端进行数据和功能的通信。这种交互通常是通过AMF(Action Message Format)协议实现的,它提供了一种高效的数据序列化...

Global site tag (gtag.js) - Google Analytics