用FLASH COM+asp.net技术实现在线视频聊天

网络视频聊天 交流目前很是热门

但用WEB视频就不是那么简单了

以前有两种方式可以实现 一个是用客服ACTIVE控件 二是用JAVA APP但两种都不很理想
一个是网络信号采集不能自适应带宽,二是技术上的难题 现在流行的BCHAT(碧聊用的)就是采用第一种方式,但我还是不能把控件给分离出来,网上了也没有 免费 或者商业的现成控件卖  第二个方式我就不说了,因为WIN XP以上不支持JAVA所以免谈

但是现Macromedia推出的新技术Flash Communication Server MX确很方便实现了,关于这个方面的介绍大家可以去网上找
下载测试版后有几个现成的例子,在这说说怎么利用ASPX和FLASH通信实现两个ID的交流


这里发一下成品的图片
这是我是asp.net+SQL写的仿QQ的在线通信系统

功能还不错 QQ的功能在这都有了

最让我得意是终于实现了视频的功能

FLASH的视频功能是b-s-b模式 也就是在服务段会有个零时视频文件
具体代码就打包让下载好了

这个写点重点
SP.aspX

<% @Language = " C# " %>
< script runat = " server " >

private   void  Page_Load( object  sender, System.EventArgs e)
            
{
               Response.Write(
"conn=1&Sendid="+Session["nmd"]+"&Recvid="+Session["Recvid"]);
            }

</ script >


Cam.aspx

<% @ Page Language = " C# "   %>
< script runat = " server " >

    
private   void  Page_Load( object  sender, System.EventArgs e)
                
{
                  Session[
"RecvId"]=Request.QueryString["RecvId"];
                }

</ script >
< html >
< head >
< meta http - equiv = " Content-Language "  content = " zh-cn " >
< meta http - equiv = " Content-Type "  content = " text/html; charset=gb2312 " >
< title > 无标题文档 </ title >
</ head >

< body leftmargin = " 0 "  topmargin = " 0 "  marginwidth = " 0 "  marginheight = " 0 " >
< object  classid = " clsid:D27CDB6E-AE6D-11cf-96B8-444553540000 "  codebase = " http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,29,0 "  width = " 220 "  height = " 200 " >
  
< param name = " movie "  value = " SP.swf " >
  
< param name = " quality "  value = " high " >
  
< embed src = " SP.swf "  quality = " high "  pluginspage = " http://www.macromedia.com/go/getflashplayer "  type = " application/x-shockwave-flash "  width = " 220 "  height = " 200 " ></ embed ></ object >

</ body >
</ html >


SP.swf的角本
stop();
client_nc = new NetConnection();
//NetConnection.onStatus(para)用来监测server返回的信息
//当server返回的信息时,此处理器被触发
//参数是一个包含着返回信息的对象,包含着两个固定变量level和code,该参数名称可随便命名
client_nc.onStatus = function(info) {
 // 利用trace功能将server返回的信息可视化
 trace("Level: "+info.level+newline+"Code: "+info.code);
};
// 连接到server上,建立rtmp连接
//下面写的是相对地址,原因是我的web server和flash communication server在一台机器上
//如果你的web server和flash communication server不在一台机器上,只要满足两台机器的ip在一个域
//你就可以同样成功建立连接,可以写成client_nc.connect("rtmp:/192.168.0.1/record_video");
//record_video是文件夹的名字,该文件夹必须事先存在
//假设你是按照默认安装的communication server,那么record_video文件夹就应该放在
//C:/Program Files/Macromedia/Flash Communication Server MX/flashcom/applications目录下面
client_nc.connect("rtmp://192.168.0.2/record_video");
// 使用SharedObject.getRemote方法,创建远程SharedObject
//"myvideo"是SharedObject文件名称,对应在server硬盘上的文件是myvideo.fso
// client_nc.uri是一个必要的参数,指向当前rtmp的连接
// 第三个是可选参数,true代表将myvideo.fso写入硬盘,false、null或者省略代表不写入,只作临时存在
rec_so = SharedObject.getRemote("myvideo", client_nc.uri, true);
//sharedobject.onSync(para)用来动态监测sharedobject的变化情况
//每当sharedobject发生变化时,此处理器被触发
//参数是一个数组,记录sharedobject.data中发生变化的内容,该参数名称可随便命名
//该数组的每个成员都是一个对象,对象又有两个成员code和name
//name代表的是发生变化的sharedobject.data里面的发生变化的内容
//code代表的是这个内容发生了什么变化,是系统返回信息
// 将sharedobject功能连接到server上
rec_so.connect(client_nc);
var Recvid;
var Sendid;
GetId();
function Recv() {
  
  //创建新的NetStream流对象,将会用来播放留言信息
  in_ns = new NetStream(client_nc);
  //通过NetStream.play方法播放server上的flv文件
  in_ns.play(Recvid);
  mybox.attachVideo(in_ns);
}

function Send() {
  this.cam = Camera.get();
     this.mic = Microphone.get();
  // 在client_nc连接上,创建NetStream对象
  out_ns = new NetStream(client_nc);
  // 通过NetStream.attachVideo方法获得摄像头的图像
  out_ns.attachVideo(this.cam);
  // 通过NetStream.attachAudio方法获得麦克风的声音
  out_ns.attachAudio(this.mic);
  out_ns.publish(Sendid, "live");
}

function GetId(){
 //构造一个新的LoadVars对象
myload = new LoadVars();
//设定myload的动作,以便服务器验证
myload.action = "post";
//验证和服务器连接的函数
myload.onLoad = function(success) {
//如果和服务器成功连接则…
if (success) {
//如果验证动作成功则…
  if (this.conn == "1") {
         //将返回对象中的output变量赋值给场景中var为output的Dynamic Text框
   _root.Recvid = this.Recvid;
   _root.Sendid = this.Sendid;
   Send();
   Recv();
  }
} else {
        //如果和服务器连接不成功则返回失败消息,需要检查路径是否正确
 
}
};
myload.sendAndLoad("http://localhost/WEBQQ/SP.aspx", myload, "post");
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值