- 浏览: 62831 次
- 性别:
- 来自: 南宁
最新评论
-
diwuci:
用response.setContentType(" ...
spring mvc 系列3 返回JSON以及文件上传 -
dickluo:
得花时间好好看下代码了 多谢
spring mvc 系列1 环境配置 -
muqingren:
这个学习了,歇息
spring mvc 系列3 返回JSON以及文件上传 -
JetMah:
Jophy 写道
@RequestMapping(pa ...
spring mvc 系列3 返回JSON以及文件上传 -
LifeFree:
LZ 1.的实现,貌似有笔误。
应该类似:
param = ...
一个小细节现实后的蛋疼结果。
本人最近在做个小实现:
需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机JAVA程序,网页,或者其它一些登陆到平台进行聊天。
本人想破了脑袋也只能想出这一实现,如有做过这一项目,或者有更好意思的,欢迎发表,谢谢。
本人的想法:由于此平台可以通过多个不同的服务进行交互。于是认为必须要一个主服务,此主服务可以通过子服务进行接入处理信息接收。主服务只做登陆人员的信息保存(主服务独立,没有session,application,所有登陆的人员信息要进行保存)。子服务可以随意装配到主服务里面去。主服务与不同子服务之间信息交换时有不同的法则,这个法则就是下面所说的命令。
需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机JAVA程序,网页,或者其它一些登陆到平台进行聊天。
本人想破了脑袋也只能想出这一实现,如有做过这一项目,或者有更好意思的,欢迎发表,谢谢。
本人的想法:由于此平台可以通过多个不同的服务进行交互。于是认为必须要一个主服务,此主服务可以通过子服务进行接入处理信息接收。主服务只做登陆人员的信息保存(主服务独立,没有session,application,所有登陆的人员信息要进行保存)。子服务可以随意装配到主服务里面去。主服务与不同子服务之间信息交换时有不同的法则,这个法则就是下面所说的命令。
package org.pjsh.main; import java.lang.reflect.Method; import java.util.Set; import java.util.TreeMap; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; import org.apache.log4j.Logger; import org.pjsh.dao.JpaServerDao; import org.pjsh.entity.City; import org.pjsh.entity.Country; import org.pjsh.entity.Friend; import org.pjsh.entity.Person; import org.pjsh.entity.Province; import org.pjsh.entity.Scene; import org.pjsh.environment.Area; import org.pjsh.environment.CityEvn; import org.pjsh.environment.CountryEvn; import org.pjsh.environment.ProvinceEvn; import org.pjsh.environment.SceneEvn; import org.pjsh.server.Server; import org.pjsh.server.SocketServer; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Main extends Thread implements ServletContextListener { private Area countryEvn; private JpaServerDao jpaServerDao; private TreeMap<String, String> map = new TreeMap<String, String>(); private Logger log = Logger.getLogger(Main.class); public Main() { System.out.println("start server..."); log.info("主服务启动..."); ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml"); jpaServerDao = (JpaServerDao) ac.getBean("jpaServer"); Country country = this.jpaServerDao.getCountryDao().getCountry(1); if (country != null) { countryEvn = new CountryEvn(country.getId(), country.getName()); Set<Province> lProvice = country.getProvinceList(); if (lProvice.size() > 0) { for (Province p : lProvice) { ProvinceEvn pe = new ProvinceEvn(p.getId(), p.getName()); Set<City> lCity = p.getCityList(); for (City c : lCity) { CityEvn ce = new CityEvn(c.getId(), c.getName()); Set<Scene> lScene = c.getSceneList(); for (Scene s : lScene) { SceneEvn se = new SceneEvn( s.getId(), s.getName(), s.getSalutatory()); ce.addSubArea(se); } pe.addSubArea(ce); } countryEvn.addSubArea(pe); } } } System.out.println("add command..."); log.debug("添加命令行。"); addCommandActuator("DL", "login"); // 添加登陆命令 addCommandActuator("TC", "logout"); // 添加退出命令 addCommandActuator("WZ", "getLocation"); // 添加显示位置命令 } public JpaServerDao getJpaServerDao() { return this.jpaServerDao; } /** * function: addCommandActuator 添加命令执行器与函数的对应关系 * * @param key * 键 * @param value * 值 */ private void addCommandActuator(String key, String value) { map.put(key, value); } /** * function: getCommandActuator 返回命令执行器 * * @param key * 执行器对应的键 * @return String 执行器的名称 */ private String getCommandActuator(String key) { return map.get(key); } /** * function: getCommand 从发送来的消息中获取命令 * * @param message * 消息 * @return String 返回取得的命令 */ private String getCommand(String message) { message = message.trim(); if (message.length() <= 0) { return null; } if (message.charAt(0) == '/') { StringBuffer buf = new StringBuffer(); for (int i = 1; i < message.length(); i++) { if (i >= 4) { break; } if ((message.charAt(i) >= 'a' && message.charAt(i) <= 'z') || (message.charAt(i) >= 'A' && message.charAt(i) <= 'Z')) buf.append(message.charAt(i) + ""); else break; } if (buf.toString().length() <= 1) { return null; } else { return buf.toString().toUpperCase(); } } else { return null; } } private void getLocation(String mobile1, String mobile2, String message) { Person person = countryEvn.getPerson(mobile1); String location = countryEvn.getLocation(person); notifySms(null, mobile1, "您所在的位置是:" + location); } /** * function: resolveCommand 将命令解释成要运行的函数 * * @param command * 命令 * @param sourceMobile * 发送者的手机号码 * @param destMobile * 接收者的手机号码 * @param message * 将命令过滤后的消息 */ public void resolveCommand(String command, String sourceMobile, String destMobile, String message, Server server) { if (command == null || command.length() <= 0) return; String value = this.getCommandActuator(command); Method[] methods = this.getClass().getDeclaredMethods(); for (Method method : methods) { if (value.equalsIgnoreCase(method.getName())) { Class[] classes = method.getParameterTypes(); Object[] object = new Object[classes.length]; for (int i = 0; i < classes.length; i++) { if (classes[i].equals(String.class)) { if (i == 0) { object[i] = sourceMobile; } else if (i == 1) { if (classes.length >= 3) { object[i] = destMobile; } else { object[i] = message; } } else { object[i] = message; } } else if (classes[i].equals(Server.class)) { object[i] = server; } else { } } try { method.invoke(this, object); } catch (Exception e) { // TODO Auto-generated catch block log.error("方法执行失败!"); } } } } /** * function: login 用户登陆 */ private void login(String mobile, Server server) { if (countryEvn != null) { Person person = countryEvn.isLogin(mobile); if (person == null) { person = jpaServerDao.getPersonDao().findByMobile(mobile); if (person == null) { this.notifySms(null, mobile, "未注册,请先注册!"); return; } person.setServer(server); countryEvn.receivePerson(person); this.notifyLogin(person); } else { this.notifySms(null, mobile, "您已经登陆平台。您所在的位置是:" + countryEvn.getLocation(person)); } } } /** * function: login 用户退出登陆 */ private void logout(String mobile) { if (countryEvn != null) { Person person = countryEvn.getPerson(mobile); countryEvn.deletePerson(person); if (person == null) { this.notifySms(null, mobile, "您还没有登陆平台!"); return; } this.notifyLogout(person); } } /** * function: notifyLogout 退出时发出通知消息 * * @param person * 人员信息对象 */ private void notifyLogout(Person person) { if (person == null) return; notifySms(null, person.getMobile(), "成功退出,谢谢您的使用。"); Set<Friend> set = person.getFriendList(); for (Friend friend : set) { Person p = countryEvn.getPerson(friend.getId()); if (p != null) { notifySms( null, p.getMobile(), friend.getName() == null ? (person.getRealname() == null ? person.getRealname() : person.getUsername()) : friend.getName() + "已经离线!"); } } } /** * function: notifyLogin 登陆时发出通知消息 * * @param person * 人员信息对象 */ private void notifyLogin(Person person) { if (person == null) return; Set<Friend> set = person.getFriendList(); for (Friend friend : set) { Person p = countryEvn.getPerson(friend.getId()); if (p != null) { notifySms( null, p.getMobile(), friend.getName() == null ? (person.getRealname() == null ? person.getRealname() : person.getUsername()) : friend.getName() + "上线了!"); } } } /** * function: notifySms 消息发送 * * @param mobile * 接收消息的手机号码 * @param msgStr * 发送的消息 */ private void notifySms(String sourceMobile, String destMobile, String message) { log.debug("消息来自手机:" + sourceMobile + ";目的手机:" + destMobile + ";消息:" + message); if (destMobile == null || message == null) { log.debug("手机号码或者要发送的信息为空!"); } else { log.debug("mobile=" + destMobile + ";message=" + message); countryEvn.notifySms(sourceMobile, destMobile, message); } } public void run() { } public void contextDestroyed(ServletContextEvent arg0) { // TODO Auto-generated method stub } // Tomcat 启动时自动加载 public void contextInitialized(ServletContextEvent arg0) { // 插入SocketServer子服务 SocketServer ss = new SocketServer(this); ss.start(); System.out.println("start server success!"); log.info("主服务启动结束"); } }
- Game.rar (9.9 MB)
- 下载次数: 16
评论
3 楼
joknm
2009-10-23
什么是边界接入?可以讲解下吗,或者给些资料,我在网上找不到边界接入的相关资料。谢谢
2 楼
fjlyxx
2009-10-19
我只看了 上面需求部分
需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机JAVA程序,网页,或者其它一些登陆到平台进行聊天。
个人觉得LZ搞懂了边界接入 就可以很好的解决这个问题.
需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机JAVA程序,网页,或者其它一些登陆到平台进行聊天。
个人觉得LZ搞懂了边界接入 就可以很好的解决这个问题.
1 楼
qiren83
2009-10-19
没怎么看明白 楼主能多些文字说明吗?
发表评论
-
一个小细节现实后的蛋疼结果。
2011-03-07 08:37 1178情况是这样子的,比如你用单击按钮在单数次单击里面要求某个数为0 ... -
eclipse3.6 集成 myeclipse 插件
2010-11-16 14:06 4730最近很是邪恶,不想费钱,但又不想邪恶的去找 myeclipse ... -
spring mvc 系列3 返回JSON以及文件上传
2010-10-10 18:58 9747先来看下spring mvc提供返回为json数据的注解 ... -
spring mvc 系列2 泛型DAO(基于存储过程)
2010-10-06 14:05 5470spring mvc 系列1 中: 感谢 ricoyu 提示 ... -
spring mvc 系列1 环境配置
2010-10-02 18:59 1980废话: 热门?=spring + hibernate + st ... -
finally 浅谈
2010-07-29 10:01 2400近日做程序时突发奇想:try ... finally ... ... -
大量数据访问时,用JPA 对象映射关系会出错?
2009-12-30 09:23 2788昨天在做一JPA调试时出了些莫名其妙的错。 public ... -
单线程处理多任务处理方式
2009-12-27 16:14 4309缘由: 在实际的应用中可能会出现这样一种尴尬:只有一个 ... -
命令模式,解释命令
2009-12-26 21:52 1081用命令模式解释命令 ... -
Hibernate+jpa+spring
2009-12-23 17:34 1350今天搞了一个JPA+HIBERNATE,以下是资料,全英文 h ... -
jpa 多个对象映射同时加载
2009-10-13 23:18 1373jpa 多个对象映射同时加载 FetchType可设置为EA ... -
利用RMI实现JAVA分布式应用
2009-10-10 15:53 1027Java RMI (Remote Method Invocat ... -
一道SQL面试题
2009-09-22 17:28 1110有两个表, table1, table2, Table tab ... -
java 取随机字符串
2009-09-16 13:51 4655package org.jinsheng.util; ... -
junit4单元测试的注释使用说明
2009-08-24 23:16 4793junit4单元测试的使用说明 右键项目->prope ... -
spring2.5注释型 + jpa + 数据库池的配置(4)
2009-08-10 00:57 1331PersonDao.java package org.ji ... -
spring2.5注释型 + jpa + 数据库池的配置(3)
2009-08-10 00:45 1108Person.java(实体文件) package org ... -
spring2.5注释型 + jpa + 数据库池的配置(2)
2009-08-10 00:41 1267文件配置: applicationContext.xml ... -
spring2.5注释型 + jpa + 数据库池的配置(1)
2009-08-10 00:28 1836本人用的环境是:eclipse 3.0 + jdk 6.0_1 ...
相关推荐
Spring Session支持将会话信息存储在数据库、Redis等外部存储,这有助于实现会话的分布式管理,并且能够提供更高级的安全特性。 总的来说,Java基于用户会话的开发程序涵盖了会话创建、管理、安全性和分布式等多个...
ASP.NET中的会话(Session)是Web开发中一个重要的概念,它允许开发者在用户的不同页面请求之间保持数据。本文将详细讲解ASP.NET中会话的应用,帮助你理解其工作机制。 一、什么是会话(Session)? 在Web应用程序...
当用户首次访问服务器并登录后,服务器会创建一个新的Session对象,存储用户的登录信息,如用户名、权限等。这个Session对象会在服务器端内存中存储,直到它过期或被显式销毁。Session的生命周期通常可以通过配置...
微信小程序中保持用户会话状态是移动应用开发中常见的需求,尤其是涉及到用户的登录状态以及安全的用户交互。在传统的Web应用中,通常会通过cookie来保存sessionID,从而维持用户的会话状态。然而,在微信小程序中,...
标题中的“谷歌插件-查看Session信息”指的是在Google Chrome浏览器中使用的一种扩展程序,它允许用户查看和管理他们的网络会话(Session)。Session在Web开发中是一个重要的概念,它用于跟踪用户在网站上的活动,...
- **生成SESSION**:用户成功注册或登录后,后台会生成一个SESSION,它包含了用户的登录状态和其他必要信息,用于保持客户端和服务器之间的会话状态。 - **SESSION存储**:SESSION通常存储在服务器端,避免跨域...
本文将深入探讨EJB的概念、其在Java应用程序中的角色,以及如何开发和应用Session Bean。** **EJB简介** 企业级JavaBeans(EJB)是Java EE(Enterprise Edition)的一部分,它提供了一种规范来创建服务器端的可重用...
总之,基于Servlet的会话跟踪是通过HttpSession对象实现的,它使得服务器能够在无状态的HTTP协议之上维持用户的状态信息,从而实现诸如购物车、个性化推荐等需要用户上下文的功能。正确理解和使用会话跟踪技术是构建...
ASP.NET是一种广泛使用的Web开发框架,由微软提供,用于构建动态网站、Web应用程序和服务。在ASP.NET中,Session是服务器端存储用户特定信息的一种机制,它允许开发者在用户的不同页面请求间保持数据。然而,当涉及...
本篇文章将详细探讨如何使用NGINX作为负载均衡器,结合TOMCAT 6应用服务器和REDIS作为session会话存储来实现负载均衡下的session会话同步。 首先,我们需要理解负载均衡的基本概念。负载均衡是指在多台服务器之间...
具体实现上,当用户浏览商品并添加到购物车时,服务器会为该用户的会话创建或更新相应的Session对象,并将商品信息存储在这个Session对象中。这样,即使用户关闭浏览器重新打开,只要Session没有过期,购物车中的...
Session是服务器端会话管理的一种方式,当用户登录网站或进行其他需要保持状态的操作时,服务器会在内存中创建一个与用户相关的Session对象,将用户信息存储在这个对象中,并返回一个唯一的Session ID给客户端(通常...
通过正确地使用`session_start()`、`$_SESSION`数组以及适时地销毁会话,可以有效地提高应用程序的安全性和用户体验。同时,在实际部署过程中,还需要注意采取相应的安全措施,避免会话劫持等风险。
- 在Spring Security的XML配置文件中,`<http>`元素下的`<session-management>`用于配置会话管理。例如,可以添加`<concurrency-control>`子元素来设置并发会话策略。 - `<session-management>`还可以配置`...
在微信小程序的开发过程中,会话服务扮演着至关重要的角色,因为它是确保用户安全登录并能访问其个人信息的基础。在给定的“微信小程序会话服务nodejs版”中,我们可以看到一个基于Node.js的解决方案,用于处理微信...
在Web开发中,session是用于存储特定用户会话所需的信息的一种机制。每个用户访问网站时,服务器都会为该用户创建一个唯一的会话标识(session ID),通过这个标识可以在多次请求之间共享数据。系统session和报表...
开发一个有状态会话Bean需要继承javax.ejb.SessionBean接口,并实现相应的生命周期方法,如ejbCreate()、ejbRemove()、ejbPassivate()、ejbActivate()等。 5. 部署到应用服务器 在部署到应用服务器时,需要配置ejb...
在微信小程序开发中,会话管理是一个至关重要的环节,它涉及到用户登录状态的维护、数据交互的安全性以及用户体验的优化。本教程将深入探讨如何为微信小程序构建有效的会话管理系统,确保用户在小程序中的操作流畅且...
6. 会话管理:使用安全的会话管理机制,例如 Session 等,保护用户的会话数据。 7. 错误处理:使用安全的错误处理机制,例如 Try-Catch 等,保护用户的数据不被泄露。 8. 日志记录:使用安全的日志记录机制,例如...
在Web开发中,Session是一种非常...在实际开发中,还需要考虑到Session的过期策略、安全性(防止Session Hijacking和Session Fixation攻击)以及性能优化(如Session的持久化存储和集群环境下的Session共享)等问题。