Pushlet简单应用小结

本文介绍了一种基于 Pushlet 的实时数据推送技术实现方法,包括客户端和服务器端的配置步骤。客户端需引入 ajax-pushlet-client.js 并定义事件接收及错误处理函数,通过 joinListen 函数注册监听特定事件;服务器端则需配置 pushlet.properties 和 web.xml,并通过自定义消息对象触发事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单应用的要点:
[b]客户端:[/b]

1.页面引入 ajax-pushlet-client.js
2.定义两个全局函数:

//事件接收
function onEvent(event) {
if(event.get('p_event') == 'data'){
var str = event.get("source");
str = decodeURIComponent(str);
pr(eval('(' + str + ')'));
}
}



//发生错误
function onError(e) {
alert('error')
}

3.启动事件注册:

function joinListen(){
PL.join();
//事件Test,Test0,Test1,Test2
PL.listen('Test');
PL.listen('Test0');
PL.listen('Test1');
PL.listen('Test2');
}


[b]服务器端[/b]
1.src文件夹下放置pushlet.properties,sources.properties
2.web.xml添加pushlet

<servlet>
<servlet-name>pushlet</servlet-name>
<servlet-class>nl.justobjects.pushlet.servlet.Pushlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>pushlet</servlet-name>
<url-pattern>/pushlet.srv</url-pattern>
</servlet-mapping>

3.事件触发,广播事件对象:

//自己定义的用于发往前台的消息对象
SimpleMessage message = null;
try {
message = new SimpleMessage(i,"Type" + i,URLEncoder.encode("中文#窝窝&wow和欧文" + i, "UTF-8"));
} catch (UnsupportedEncodingException e1) {
}
event.setField("source", JSONObject.fromObject(message).toString());
Dispatcher d = Dispatcher.getInstance();
d.multicast(event);


说明:
1.如果不对中文进行编码,pushlet将无法正常工作。
2.要使用 JSONObject,来自包Json-lib.**.jar,需要依赖一下包。
* jakarta commons-lang
* jakarta commons-beanutils
* jakarta commons-collections
* jakarta commons-logging
* ezmorph
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值