Windows环境下配置+运行red5源码+AS3连接red5简单示例

Windows环境下配置+运行red5源码+AS3连接red5简单示例

Posted on 18 April 2010

Windows环境下+配置+运行red5源码

Red5发展很快,目前最新版本为0.9.1,与以前的版本(0.8.+、0.7.+、0.6.+)差别很大,中文资料奇缺,鉴于此,我写下这篇文章,希望能帮上您的忙。

由于没有下载到0.9.1的源码,我们现在以red5 0.9.0为例介绍如何配置、编译、运行Red5源码。Red5 0.9.0与red5 0.9.1差不多,你可以用本文所介绍的方式来配置red5 0.9.1。

1.打开red5 0.9.0的下载页面:http://red5.org/wiki/0_9_0

如下图所示:

我们点击“Windows”和”Source”两个链接来下载red5的安装包和red5的源码,我们下载安装包的目的是它包括了所有red5源码所依赖的jar包,这样很方便我们的配置。

2.下载完成之后,首先安装setup-Red5-0.9.0.exe,在安装过程中,如果提示你输入ip地址,则输入0.0.0.0,这样可以允许来自任何域的访问,如果提示输入端口,则输入8000,那么我们的web服务器将会绑定8000端口。

3.打开eclipse java开发环境,如果没有,则到http://eclipse.org/downloads/ 下载Eclipse IDE for Java Developers ,将下载后的压缩包解压到本机你喜欢的地方,然后双击eclipse.exe,如果不能运行,说明你需要一个jdk,就到http://java.sun.com/javase/downloads/widget/jdk6.jsp 下载一个适合你的操作系统的jdk,安装jdk之后,eclipse就可以运行了,打开eclipse开发 环境之后,选择一个你喜欢的工作空间。

4.新建一个Java Project,如下图所示:

5.在新建工程对话框中输入Red5,点击“Finish”按钮则新建一个名为Red5的java工程,如下图所示:

6.将red5安装目录下的所有文件夹拷贝到Red5工程根目录下,操作之后的Red5工程目录结构如下:

7.将下载的red5源文件解压并将org文件夹拷贝到我们的Red5工程的src目录下,操作之后的项目结构图如下所示:

8.这时我们看到工程中有些错误,说明缺少依赖的库,此时我们把lib文件夹中的所有jar文件添加构建路径中,操作如下图 所示:

此时我们可以看到,工程中不再提示错误。

9.我们找到org.red5.server.Bootstrap类,双击Bootstrap.java文件打开此类,按F11运行此工程。当你看到如下输出信息时,说明Red5服务器启动完成。

10.打开浏览器,在地址栏中输入http://localhost:8000,回车,如果你看到如下界面,说明你的Red5已经正在良好的运行。

11.接下来我们安装一个程序来测试一下,访问http://localhost:8000,点击“Install”链接,或者直接 在访问http://localhost:8000/installer/,则进入如下界面:

12.我们选择SOSample,点击“Install”按键安装它,等待安装完成,提示如下:

13.访问http://localhost:8000/,点击“Launch a demo”链接,或者直接访问http://localhost:8000/demos/进入如下界面:

14.在Shared Ball栏目下,我们点击“View demo”进入如下界面:

我们用此地址复制,多打开几个浏览器窗口,如下图所示:

将它们一一连接到red5服务器,尝试拖动Red5的图标,我们可以看到每个客户端的red5图标都被拖动。

15.下面我们一起来制作一个as3与red5通信的例子。

回到eclipse,在webapps目录下新建一个testred5目录,并将webapps里面的SOSample目录中所有内容拷贝到testred5目录中(如果看不见SOSample目录,请刷新一下webapps目录)。

16.在testred5目录下新建一个src目录,并将此目录做为源文件目录,操作如下图所示:

17.打开项目的属性面板,操作如下图所示:

选择Java Build Path,在Java Build Path面板中选择Source选择卡,然后我们将Default output folder指向到Red5/webapps/testred5/WEB-INF/classes 目录,你可以通过浏览来选择此目录,也可以直接在输入框中输入“Red5/webapps/testred5/WEB-INF/classes”。如下图 所示:

点击“OK”关闭此面板。

18.我们在webapps/testred5/src源文件夹下建立一个Java类叫MainApp,此时项目结构图如下所示:

19.在MainApp类中输入如下代码:

Code block      
import
 org.red5.server.adapter.ApplicationAdapter
;

 
public
 class
 MainApp extends
 ApplicationAdapter{

 
	public
 String

 getValue(
)
{

		return
 "Hello world"
;

	}

}

20.分别修改webapps/testred5/WEB-INF目录下的文件 web.xml、red5-web.xml、red5-web.properties 如下:

web.xml:

Code block      
<?xml
 version
="1.0"
 encoding
="ISO-8859-1"
?>


<web-app


   xmlns
="http://java.sun.com/xml/ns/j2ee"


   xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance"


   xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"


   version
="2.4"
>

 
 
	<display-name> 

testred5</display-name> 


 
	<context-param> 


		<param-name> 

webAppRootKey</param-name> 


		<param-value> 

/testred5</param-value> 


	</context-param> 


 
</web-app> 

red5-web.xml:

Code block      
<?xml
 version
="1.0"
 encoding
="UTF-8"
?>


<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans> 


 
	<bean
 id
="placeholderConfig"
 class
="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
>


	    <property
 name
="location"
 value
="/WEB-INF/red5-web.properties"
 />


	</bean> 


 
	<bean
 id
="web.context"
 class
="org.red5.server.Context"


		autowire
="byType"
 />


 
	<bean
 id
="web.scope"
 class
="org.red5.server.WebScope"


		 init-method
="register"
>


		<property
 name
="server"
 ref
="red5.server"
 />


		<property
 name
="parent"
 ref
="global.scope"
 />


		<property
 name
="context"
 ref
="web.context"
 />


		<property
 name
="handler"
 ref
="web.handler"
 />


		<property
 name
="contextPath"
 value
="${webapp.contextPath}"
 />


		<property
 name
="virtualHosts"
 value
="${webapp.virtualHosts}"
 />


	</bean> 


 
	<bean
 id
="web.handler"


	    class
="MainApp"


		singleton
="true"
 />


 
</beans> 

red5-web.properties:

Code block      
webapp.contextPath=/testred5
webapp.virtualHosts=*, localhost, localhost:8088, 127.0.0.1:8088

21.保存所有工程,按F11启动red5服务器。

22.打开FlashBuilder,创建一个名为Testred5client的ActionScript 项目,在生成的主文件中输入以下代码:

Code block      
package

{

	import
 flash.display
.
Sprite

;

	import
 flash.events
.
NetStatusEvent

;

	import
 flash.net
.
NetConnection

;

	import
 flash.net
.
Responder

;

 
	public
 class
 Testred5client extends
 Sprite


	{

 
		private
 var
 _nc:
NetConnection

;

 
		public
 function
 Testred5client(
)

		{

			_nc=new
 NetConnection

;

			_nc.
addEventListener
(
NetStatusEvent

.
NET_STATUS
,
netStatusHandler)
;

			_nc.
connect
(
"rtmp://localhost/testred5"
)
;

		}

 
		private
 function
 netStatusHandler(
event:
NetStatusEvent

)
:
void
{

			switch
(
event.
info
.
code
)
{

				case
 "NetConnection.Connect.Success"
:

					_nc.
call
(
"getValue"
,
new
 Responder

(
result)
)
;

					break
;

			}

		}

 
		private
 function
 result(
obj:
Object

)
:
void
{

			trace
(
obj)
;

		}

	}

}

23.按F11运行此代码,如果你看到输出面板中输出了Hello world,如下图所示,则说明你成功了。

你可能感兴趣的:(apache,eclipse,Web,windows,bean)