cometd Dojo jetty整合的一个小例子

需要jdk1.5以上,tomcat5.0以上,具体的安装不再说明。

下载jetty源码,将里面demo的软件包导入到所建的工程,将demo中web路径下org文件夹放在所建工程的webroot下。

将Dojo里面的三个文件夹dijit,dojo,dojox放在webroot路径下。

客户端有两个文件chattest.html,chattest.js。服务端有一个java类ChatTestService.java。

 

 

chattest.html

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 

"http://www.w3.org/TR/html4/loose.dtd">  
<html>  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  
<title>test chat</title>  
<script type="text/javascript" src="../dojo/dojo.js"  

djConfig="parseOnLoad:true"></script>  
<script type="text/javascript" src="t.js"></script>  

 </head>  
 <body>  
 
    <div id="root">
      <div>
       <label>一个简单的聊天程序</label>
      </div>
      <div id="chat"></div>
       <div>
            Chat:
            &nbsp;
            <input id="message" type="text" />
            <button id="sendChat">Send</button>
        </div>
    </div>
 </body>  
 </html>  

chattest.js

dojo.require("dojox.cometd");
dojo.require("dojox.cometd.timestamp");
dojo.require("dojox.cometd.ack");
dojo.require("dojox.cometd.reload");
var root = {
	_chatSubscription: null,
//初始化
	_init: function(){  
//简历链接,握手
		dojox.cometd.init("http://localhost:8080/dojocometd/cometd");
	    root._subscribe();
                //点击按钮时调用_chat方法
		dojo.query("#sendChat").onclick(function(e)
        {
            root._chat();
        }); 
		
	},
//订阅通道,将信息写到界面
	_subscribe: function(){
		 root._chatSubscription = dojox.cometd.subscribe

('/test/testchat',root._receive);
	},
//取消订阅
	_unsubscribe: function(){
		if (room._chatSubscription)
        {
            dojox.cometd.unsubscribe(root._chatSubscription);
        }
        root._chatSubscription = null;
	},
//将客户端信息发送到服务器端
	_chat:function(){
		var text=dojo.byId('message').value;
		dojox.cometd.publish('/test/testchat', {
                clientuser: 'test',
                chatmessageclient: text
            });
         dojo.byId('message').value="";
	},
//接受服务器端的信息,显示到界面
	_receive: function(message)
    {
    	var chat = dojo.byId('chat');
    	var text=message.data.chatmessageservice;
    	chat.innerHTML += "" + "testchat:" + "&nbsp;" + text + "<br/>";
    }
};
//页面初始渲染时,调用_init方法
dojo.addOnLoad(root, "_init");
//关闭页面时断开链接
dojo.addOnUnload(function()
{    root._unsubscribe();
	 dojox.cometd.disconnect();
});

  ChatTestService.java

 

package com.my.service;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.inject.Inject;
import org.cometd.bayeux.server.BayeuxServer;
import org.cometd.bayeux.server.ConfigurableServerChannel;
import org.cometd.bayeux.server.ServerMessage;
import org.cometd.bayeux.server.ServerSession;
import org.cometd.java.annotation.Configure;
import org.cometd.java.annotation.Listener;
import org.cometd.java.annotation.Service;
import org.cometd.java.annotation.Session;
import org.cometd.server.authorizer.GrantAuthorizer;
import org.cometd.server.filter.DataFilter;
import org.cometd.server.filter.DataFilterMessageListener;
import org.cometd.server.filter.JSONDataFilter;
import org.cometd.server.filter.NoMarkupFilter;

@Service
public class ChatTestService {
//用来存储订阅了该服务的客户端ID
	private final List<String> clientId = new ArrayList<String>();
	@Inject
	private BayeuxServer _bayeux;
	@Session
	private ServerSession _session;
	
	@SuppressWarnings("unused")
//配置通道
	@Configure("/test/testchat")
	private void configureTestChat(ConfigurableServerChannel channel) {
		DataFilterMessageListener noMarkup = new DataFilterMessageListener(
				_bayeux, new NoMarkupFilter(), new BadWordFilter());
		channel.setPersistent(true);
		channel.addListener(noMarkup);
		channel.addAuthorizer(GrantAuthorizer.GRANT_PUBLISH);
	}
//通道监听
	@Listener("/test/testchat")
	public void privateTestChat(ServerSession client, ServerMessage message) {
                //判断list中是否保存了客户端id
		if (!clientId.contains(client.getId()))
			clientId.add(client.getId());
                //获取客户端数据
		Map<String, Object> data = message.getDataAsMap();
                //获取所有的client对应的ServerSession
		ArrayList<ServerSession> ssvs= new ArrayList<ServerSession>(
				clientId.size());
		for (String ssvid: clientId) {

			if ssvid!= null) {
				ServerSession ssv = _bayeux.getSession(peerId);
				if (ssv != null)
					ssvs.add(ssv);
			}
		}
		if (ssvs.size() > 0) {

			Map<String, Object> chat = new HashMap<String, Object>();

			chat.put("userserivce", data.get("clientuser"));
			chat.put("chatmessageservice", data.get("chatmessageclient"));
			ServerMessage.Mutable forward = _bayeux.newMessage();
			forward.setChannel("/test/testchat");
			forward.setId(message.getId());
			forward.setData(chat);
                        //将数据发布到每个订阅的客户端
			for (ServerSession ssv: ssvs)
				if (ssv != client)
					ssv.deliver(_session, forward);
			
			client.deliver(_session, forward);
		}

	}
	class BadWordFilter extends JSONDataFilter {
		@Override
		protected Object filterString(String string) {
			if (string.indexOf("dang") >= 0)
				throw new DataFilter.Abort();
			return string;
		}
	}

}

 配置一下web.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" 
	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">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

  <display-name>Cometd Test WebApp</display-name>

    <!--  Request that Jetty create an MBean to manage the Bayeux instance -->
    <context-param>
        <param-name>org.eclipse.jetty.server.context.ManagedAttributes</param-name>
        <param-value>org.cometd.bayeux,org.cometd.oort.Oort</param-value>
    </context-param>
      <!-- Filter to support cross domain requests -->
    <filter>
        <filter-name>cross-origin</filter-name>
        <filter-class>org.eclipse.jetty.servlets.CrossOriginFilter</filter-class>
        <!--async-supported>true</async-supported-->
    </filter>
    <filter-mapping>
        <filter-name>cross-origin</filter-name>
        <url-pattern>/cometd/*</url-pattern>
    </filter-mapping>
  
      <!-- Cometd Servlet -->
    <servlet>
        <servlet-name>cometd</servlet-name>
        <servlet-class>org.cometd.java.annotation.AnnotationCometdServlet</servlet-class>
        <!--async-supported>true</async-supported-->
        <init-param>
            <param-name>timeout</param-name>
            <param-value>20000</param-value>
        </init-param>
        <init-param>
            <param-name>interval</param-name>
            <param-value>0</param-value>
        </init-param>
        <init-param>
            <param-name>maxInterval</param-name>
            <param-value>10000</param-value>
        </init-param>
        <init-param>
            <param-name>maxLazyTimeout</param-name>
            <param-value>5000</param-value>
        </init-param>
        <init-param>
            <param-name>long-polling.multiSessionInterval</param-name>
            <param-value>2000</param-value>
        </init-param>
        <init-param>
            <param-name>logLevel</param-name>
            <param-value>0</param-value>
        </init-param>
        <init-param>
            <param-name>services</param-name>
            <param-value>com.my.service.ChatTestService</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>cometd</servlet-name>
        <url-pattern>/cometd/*</url-pattern>
    </servlet-mapping>
</web-app>

 将代码发布到tomcat下,访问cometdtest.html文件即可,最好用火狐浏览器

你可能感兴趣的:(JavaScript,eclipse,Web,servlet,dojo)