好多示例只是示例,没有说这个问题,既然发现了,我就就地解决一下!
我的方法很简单,对要传送的内容进行编码!
Java后台和JS前台都有包装的编解码方法,可以直接使用看效果!
后台编码(解码自己搞):
package com; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.Date; import nl.justobjects.pushlet.core.Event; import nl.justobjects.pushlet.core.EventPullSource; public class HelloWorldPlushlet { static public class HwPlushlet extends EventPullSource { // 休眠五秒 @Override protected long getSleepTime() { return 2000; } @SuppressWarnings("deprecation") @Override protected Event pullEvent() { Event event = Event.createDataEvent("/cuige/he"); try { SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String text = format.format(new Date()); String str = "传递中文测试!" + text + "!"; str = URLEncoder.encode(str,"UTF-8"); event.setField("cnmess", str); } catch (Exception e) { event.setField("mess", "异常错误!"); } return event; } } }
URLEncoder.encode有两个方法,一个参数的两个参数的,由于一个参数的已经不建议使用,所以这里使用了两个参数的方法!
至于编码方式,这个由所在系统约定,这里使用UTF-8编码!加上个时间戳看效果!
前台解码(JS也可以编码,自己搞):
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta http-equiv="Pragma" content="no-cache" /> <script type="text/javascript" src="ajax-pushlet-client.js"></script> <script type="text/javascript"> PL._init(); PL.joinListen('/cuige/he'); function onData(event) { document.getElementById("mess").innerHTML=decodeURIComponent(event.get("cnmess")); } </script> </head> <body> <center> <h1> my first pushlet! </h1> <br><br><br> <div id="mess"></div> </center> </body> </html>
直接使用decodeURIComponent方法进行解码!
当然JS中编解码方式方法很多,不是这里所述重点不再啰嗦!
如果不解码会看到内容:
%E4%BC%A0%E9%80%92%E4%B8%AD%E6%96%87%E6%B5%8B%E8%AF%95%EF%BC%812012-10-08+11%3A38%3A02%EF%BC%81
你绝对认识的,至于值的对应关系,参考http://www.w3school.com.cn/tags/html_ref_urlencode.html !
如果解码后会看到应该看到的汉字:
传递中文测试!2012-10-08+11:39:34!
如果不没有采取任何方式而直接使用网上的示例进行开发,一旦有中文的话就会出现消息不能推送的问题!
而且观察后台打印会发现,回话一旦传递中文,传递一次后回话就会被移除!
请您到ITEYE网站看原创,谢谢!
http://cuisuqiang.iteye.com/ !
自建博客地址:http://www.javacui.com/ ,内容与ITEYE同步!
相关推荐
Pushlet 是一个开源的、基于Java的实时信息发布系统,它采用推送技术(Push Technology)实现服务器向客户端实时发送数据,而无需客户端频繁发起请求。这种技术在实时性要求高的场景,如股票交易、在线聊天、实时...
java web开发中服务器推送pushlet.jar解决中文乱码
总的来说,Comet框架的Pushlet实现是一种高效的服务器推送技术,它通过持久化连接解决了传统Web应用实时性不强的问题,对于需要实时数据更新的应用场景具有显著的优势。开发者可以利用Pushlet轻松构建出实时交互的...
《Pushlet官方示例解读与改造》 Pushlet是一种基于HTTP长轮询技术的轻量级推送服务,它允许服务器主动向客户端推送数据,而无需客户端持续发起请求。这种技术在实时性要求较高的应用场景,如在线聊天、股票更新、...
Pushlet的核心组件是Pushlet Server和Pushlet Client。Pushlet Server作为服务端,接收并处理客户端的连接,当有新的数据可用时,会主动将数据推送到已经建立连接的客户端。Pushlet Client则是在用户端运行的程序,...
在"Pushlet点对点发送消息"这个主题中,我们可以深入探讨以下几个关键知识点: 1. **Pushlet框架**:Pushlet是Apache Cocoon项目的一部分,它提供了一种基于HTTP长连接的推送机制。Pushlet使用了Servlet和Java...
Pushlet 是一个基于 Comet ...总的来说,Pushlet 提供了一个高效且易于集成的解决方案,用于实现服务器端到客户端的数据实时推送。通过正确配置和理解其工作原理,你可以有效地利用 Pushlet 构建实时互动的 Web 应用。
服务器推 pushlet 服务器推 pushlet 服务器推 pushlet 服务器推 pushlet
服务器推送技术在现代Web开发中扮演着至关重要的角色,它使得服务器能够主动向客户端发送数据,而无需客户端持续不断地发起请求。Pushlet是基于Comet技术的一种实现,它为Java开发者提供了一种高效的服务器推送解决...
Pushlet是一种基于Java的实时数据推送技术,由荷兰JustObjects公司开发。Pushlet库的核心功能是实现实时的服务器向客户端推送数据,而无需客户端频繁发起请求,这大大提高了网络应用的效率和用户体验。以下是对...
这个"pushlet定时向页面发送消息demo"是一个实例,展示了如何使用Pushlet库来实现定时向用户页面发送更新信息。 首先,理解Pushlet的基本工作原理。Pushlet采用了一个叫做Comet的技术,Comet是长连接的一种实现方式...
总之,Pushlet技术为实时通信提供了一种高效且灵活的解决方案,特别适合需要实时更新数据的场景,如在线聊天、股票行情、游戏等。通过学习和实践"pushlet实现简单的用户聊天",开发者可以掌握这种技术,并将其应用于...
Pushlet项目是由Peter Mularien开发的,它提供了一个简单、轻量级的解决方案,允许服务器端主动向浏览器或其他客户端应用程序发送数据,而无需客户端不断地发起HTTP请求(即长轮询或短轮询)。 在Pushlet框架中,...
### Pushlet 白皮书知识点总结 #### 一、引言 **Pushlet**是一种基于Servlet的技术,它允许服务器向浏览器客户端推送数据。...通过不断的研究和发展,**Pushlet**有望在未来成为Web实时通信领域的关键技术之一。
此外,不支持老版本的浏览器可能无法使用Pushlet。 5. **Pushlet的现代替代方案** - 随着WebSocket协议的出现,它提供了双向全双工的通信能力,已经成为现代服务器推送的首选。WebSocket相比Pushlet,更高效、更...
【Pushlet服务器推技术】是一种实时通信技术,主要用于构建能够实时推送信息的Web应用程序,比如聊天、股票更新、在线游戏等场景。Pushlet是基于Java的开源项目,它利用了HTTP的长连接特性,实现了服务器主动向...
标题中的"pushlet 扩充,sessionid 采用userid"涉及到的是一个实时通信技术的应用,Pushlet 是一种基于服务器推送(Server-Sent Events, SSE)的技术,它允许服务器主动向客户端(通常是Web浏览器)发送数据,而不是...
"pushlet.jar 和示例工程"是一个专注于实现服务器端向客户端主动推送消息的框架,它在Web开发领域中扮演着重要角色。Pushlet框架的设计旨在克服传统的HTTP协议中客户端请求、服务器响应的被动通信模式,转而采用一种...
Pushlet是一种基于Java的实时数据推送技术,它允许服务器向客户端主动推送数据,而无需客户端持续不断地轮询请求。在Web应用中,Pushlet能够显著提高用户体验,因为它减少了延迟并优化了服务器资源的使用。本示例...
PushLet就是为了解决这个问题,它允许服务器主动向客户端推送数据,无需客户端不断轮询。 PushLet的核心概念是“Push Channel”(推送通道)。服务器创建一个Push Channel,客户端订阅这个通道,然后服务器可以在...