前一段时间项目需要写一个类似于站内信箱的消息管理的功能,由于对前端不是很熟悉,刚开始不知道怎么做,后来看了网上的方案,现模拟一个非常简单的消息管理。

我们首先看一下最终效果的样式,就是非常简单的一个样子,如下所示:

我这边暂时只写了三个类型的消息,订单、上下架、审核。不同的消息推送过来会显示在不同类型上,消息管理上显示的是三种类型的消息总数量。

好,接下来介绍一下代码。首先是数据库的设计,共有七个字段,分别是一个自增字段id,消息类型type,消息标题title,消息具体内容detail,消息状态status,创建时间time以及用户userId。如下所示:

然后我们看推送消息的后台代码PullMsgServlet,分别有四个方法,分别是获取所有消息的历史记录,获取某人的未读消息,获取未读消息的总数,还有获取某种类型的未读消息总数。

 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String operateType = Base64Util.decode(request.getParameter("operateType"));
msgDao = new MessageDao();
switch (operateType) {
case "showHistory":
showHistory(request, response);
break;
case "showPending":
showPending(request, response);
break;
case "showCount":
showCount(request,response);
break;
case "showCountByType":
showCountByType(request, response);
break;
default:
break;
}
response.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=UTF-8");
response.getWriter().print(Base64Util.encode(result.toString()));
} /**
* 所有消息的历史记录
* @param request
* @param response
* @throws ServletException
* @throws IOException
*/
private void showHistory(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
HttpSession session = request.getSession();
userId = session.getAttribute("userId").toString();
List<Object> historyList = msgDao.getMsgByUserId(userId);
HttpResultList result = new HttpResultList();
result.setResult(historyList.size()>0);
result.setDatas(historyList);
} /**
* 某人的未读消息
* @param request
* @param response
* @throws ServletException
* @throws IOException
*/
private void showPending(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
HttpSession session = request.getSession();
userId = session.getAttribute("userId").toString();
List<Object> pendingList = msgDao.getUnreadMsg();
HttpResultList result = new HttpResultList();
result.setResult(pendingList.size()>0);
result.setDatas(pendingList);
} /**
* 某人未读消息的总数
* @param request
* @param response
* @throws ServletException
* @throws IOException
*/
private void showCount(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
String number = msgDao.getMsgNum()+"";
result = new JSONObject();
result.put("result", number);
} /**
* 某人某种类型的未读消息总数
* @param request
* @param response
* @throws ServletException
* @throws IOException
*/
private void showCountByType(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
Map<String, Integer> map = msgDao.getTypeNum();
//获得返回的type
List<String> keyList = new ArrayList<>();
for (String key : map.keySet()) {
keyList.add(key);
}
//获得返回type的个数
List<Integer> valueList = new ArrayList<>();
for (Integer value : map.values()) {
valueList.add(value);
}
result = new JSONObject();
JSONObject content = new JSONObject();
content.put("type", JSONArray.fromObject(keyList));
content.put("typeNum", JSONArray.fromObject(valueList));
result.put("result", content);
}

接下来我们看前端代码,这边使用了setInterval定时器,设置的js代码每5秒轮询后台一次,请求后台servlet从数据库里面获取的数据,如下所示:

 setInterval(function(){
getType();
},5000); /**
* 得到某个类型的消息数量
*/
function getType(){
var lis = document.getElementById("type").getElementsByTagName("li");
var msgType = "";
for(var i=0; i<lis.length; i++){
msgType = lis[i].innerText;
}
$.ajax({
type:"POST",
url:"PullMsgServlet",
dataType:'json',
processData:false,
data: {
operateType: "showCountByType"
},
success:function(data){
var result = data.result;
var type = "";
if(result){
for(var i=0; i<result.type.length; i++){
type = result.type[i];
if(type == "订单"){
$("#order").html(result.typeNum[i]);
}else if(type == "上下架"){
$("#shelf").html(result.typeNum[i]);
}else if(type == "审核"){
$("#review").html(result.typeNum[i]);
}
}
}
},
error: function () {
// alert("error...");
}
});
}

这样前端每隔5秒就轮询一次PullMsgServlet,查询数据库里是否有未读的消息,如果有,就显示在前端页面上。这样,一个最简单的消息推送以及显示功能就有了,只是我还没有写前端历史列表的查看,等以后写了再更新。。。。

使用Ajax轮询模拟简单的站内信箱(消息管理)功能的更多相关文章

  1. 浅谈Websocket、Ajax轮询和长连接(long pull)

    最近看到了一些介绍Websocket的文章,觉得挺有用,所以在这里将自己的对其三者的理解记录一下. 1.什么是Websocket Websocket是HTML5中提出的新的协议,注意,这里是协议,可以 ...

  2. 浅谈Websocket、Ajax轮询和长轮询(long polling)

    浅谈Websocket.Ajax轮询和长轮询(long p0ll) 最近看到了一些介绍Websocket的文章,觉得挺有用,所以在这里将自己的对其三者的理解记录一下. 1.什么是Websocket W ...

  3. WebSocket原理及与http1.0/1.1 long poll和 ajax轮询的区别【转自知乎】

    一.WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持持久连接的(长连接,循环连接的不算)首先HTTP有1.1和1.0之说,也就是所谓的ke ...

  4. long poll、ajax轮询和WebSocket

    websocket 的认识深刻有木有.所以转到我博客里,分享一下.比较喜欢看这种博客,读起来很轻松,不枯燥,没有布道师的阵仗,纯粹为分享.废话这么多了,最后再赞一个~ WebSocket是出的东西(协 ...

  5. AJAX轮询的实时监控画面

    上一篇我们通过异步刷新Ajax 技术,来实现监控页面监控位号值的刷新,采用Ajax (Asynchronous Javascript And XML)技术,是指一种创建交互式.快速动态网页应用的网页开 ...

  6. Flask框架:运用Ajax轮询动态绘图

    Ajax是异步JavaScript和XML可用于前后端交互,在之前<Flask 框架:运用Ajax实现数据交互>简单实现了前后端交互,本章将通过Ajax轮询获取后端的数据,前台使用echa ...

  7. Flask框架:如何运用Ajax轮询动态绘图

    摘要:Ajax是异步JavaScript和XML可用于前后端交互. 本文分享自华为云社区<Flask框架:运用Ajax轮询动态绘图>,作者:LyShark. Ajax是异步JavaScri ...

  8. Ajax轮询以及Comet模式—写在Servlet 3.0发布之前(转)

    2008 年的夏天,偶然在网上闲逛的时候发现了 Comet 技术,人云亦云间,姑且认为它是由 Dojo 的 Alex Russell 在 2006 年提出.在阅读了大量的资料后,萌发出写篇 blog ...

  9. ajax轮询实时获取数据

    最近做一个评论功能时,想要实现实时异步刷新评论功能,于是使用了ajax轮询,这里简单记录一下ajax轮询的原理及使用方法. ajax轮询的原理就是客户端定时向服务端发送ajax请求,服务器接到请求后马 ...

随机推荐

  1. [Swift]LeetCode377. 组合总和 Ⅳ | Combination Sum IV

    Given an integer array with all positive numbers and no duplicates, find the number of possible comb ...

  2. [Swift]LeetCode904. 水果成篮 | Fruit Into Baskets

    In a row of trees, the i-th tree produces fruit with type tree[i]. You start at any tree of your cho ...

  3. Java数据结构和算法 - 什么是2-3-4树

    Q1: 什么是2-3-4树? A1: 在介绍2-3-4树之前,我们先说明二叉树和多叉树的概念. 二叉树:每个节点有一个数据项,最多有两个子节点. 多叉树:(multiway tree)允许每个节点有更 ...

  4. 火狐l浏览器所有版本

    最近在群里看到好多人需要火狐浏览器的低版本,而且都是跪求,更有甚者是高额悬赏,因此给大家一个链接,免费的,免费的,免费的!!!重要的事说三遍,拿走不谢~~ 火狐所有版本,了解一下,有需要的自行下载. ...

  5. C++日志系统log4cxx使用总结

    原文地址:C++日志系统log4cxx使用总结作者:邵明 本文主要从log4cxx级别.layout.格式化.命名规则.Filter几个方面介绍.   一.log4cxx命名规则         Lo ...

  6. Centos7 防火墙 firewalld 实用操作

    一.前言 Centos7以上的发行版都试自带了firewalld防火墙的,firewalld去带了iptables防火墙.其原因是iptables的防火墙策略是交由内核层面的netfilter网络过滤 ...

  7. K60平台智能车开发工作随手记

    (图片仅为示例,并不一定固定为这种造型) 第十二届全国大学生智能汽车竞赛有一个分项是光电四轮车的竞速(任务A),Seven她们组采购到的配件使用了freescale Crotex-M4内核的CPU,T ...

  8. [Python Web]部署完网站需要做的基本后续工作

    简述 今天自己上线了一个简单的 Page,没有什么功能就是一个展示页. 但是,我发现部署完,上线后,还要弄不少东西.下面就是我记录.整理的一些上线网站基本都会用到的网站和配置. 加入统计代码 这个是必 ...

  9. Java基础20:Java8新特性终极指南

    更多内容请关注微信公众号[Java技术江湖] 这是一位阿里 Java 工程师的技术小站,作者黄小斜,专注 Java 相关技术:SSM.SpringBoot.MySQL.分布式.中间件.集群.Linux ...

  10. HashMapd的存取原理你知道多少

    在java的容器集合中,hashmap的使用频率可以说是相当高的.不过对于hashmap的存(put())以及取(get())的原理可能很多人还不大清楚,今天,我就给大家介绍下它是如何存如何取的. # ...