`
joknm
  • 浏览: 62831 次
  • 性别: Icon_minigender_1
  • 来自: 南宁
社区版块
存档分类
最新评论

需要但没有session等会话信息下的程序开发

    博客分类:
  • JAVA
阅读更多
    本人最近在做个小实现:
     需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机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("主服务启动结束");
	}
}
    
分享到:
评论
3 楼 joknm 2009-10-23  
什么是边界接入?可以讲解下吗,或者给些资料,我在网上找不到边界接入的相关资料。谢谢
2 楼 fjlyxx 2009-10-19  
我只看了 上面需求部分

需求:类似于聊天室,但又为更广,些聊天可以通过手机短信,手机JAVA程序,网页,或者其它一些登陆到平台进行聊天。

个人觉得LZ搞懂了边界接入 就可以很好的解决这个问题.
1 楼 qiren83 2009-10-19  
没怎么看明白 楼主能多些文字说明吗?

相关推荐

    java基于用户会话的开发程序

    Spring Session支持将会话信息存储在数据库、Redis等外部存储,这有助于实现会话的分布式管理,并且能够提供更高级的安全特性。 总的来说,Java基于用户会话的开发程序涵盖了会话创建、管理、安全性和分布式等多个...

    asp.net简单会话(session)应用

    ASP.NET中的会话(Session)是Web开发中一个重要的概念,它允许开发者在用户的不同页面请求之间保持数据。本文将详细讲解ASP.NET中会话的应用,帮助你理解其工作机制。 一、什么是会话(Session)? 在Web应用程序...

    session.会话实例源码

    当用户首次访问服务器并登录后,服务器会创建一个新的Session对象,存储用户的登录信息,如用户名、权限等。这个Session对象会在服务器端内存中存储,直到它过期或被显式销毁。Session的生命周期通常可以通过配置...

    微信小程序保持session会话的方法

    微信小程序中保持用户会话状态是移动应用开发中常见的需求,尤其是涉及到用户的登录状态以及安全的用户交互。在传统的Web应用中,通常会通过cookie来保存sessionID,从而维持用户的会话状态。然而,在微信小程序中,...

    谷歌插件-查看Session信息

    标题中的“谷歌插件-查看Session信息”指的是在Google Chrome浏览器中使用的一种扩展程序,它允许用户查看和管理他们的网络会话(Session)。Session在Web开发中是一个重要的概念,它用于跟踪用户在网站上的活动,...

    微信小程序用户登录、注册、SESSION同步、交互等

    - **生成SESSION**:用户成功注册或登录后,后台会生成一个SESSION,它包含了用户的登录状态和其他必要信息,用于保持客户端和服务器之间的会话状态。 - **SESSION存储**:SESSION通常存储在服务器端,避免跨域...

    EJB的开发及应用,Session Bean的开发

    本文将深入探讨EJB的概念、其在Java应用程序中的角色,以及如何开发和应用Session Bean。** **EJB简介** 企业级JavaBeans(EJB)是Java EE(Enterprise Edition)的一部分,它提供了一种规范来创建服务器端的可重用...

    基于Servlet的会话跟踪理解会话跟踪原理

    总之,基于Servlet的会话跟踪是通过HttpSession对象实现的,它使得服务器能够在无状态的HTTP协议之上维持用户的状态信息,从而实现诸如购物车、个性化推荐等需要用户上下文的功能。正确理解和使用会话跟踪技术是构建...

    asp.net不同应用程序Session共享

    ASP.NET是一种广泛使用的Web开发框架,由微软提供,用于构建动态网站、Web应用程序和服务。在ASP.NET中,Session是服务器端存储用户特定信息的一种机制,它允许开发者在用户的不同页面请求间保持数据。然而,当涉及...

    NGINX + TOMCAT 6 + REDIS 实现负载均衡 session会话同步

    本篇文章将详细探讨如何使用NGINX作为负载均衡器,结合TOMCAT 6应用服务器和REDIS作为session会话存储来实现负载均衡下的session会话同步。 首先,我们需要理解负载均衡的基本概念。负载均衡是指在多台服务器之间...

    session的跟踪机制

    具体实现上,当用户浏览商品并添加到购物车时,服务器会为该用户的会话创建或更新相应的Session对象,并将商品信息存储在这个Session对象中。这样,即使用户关闭浏览器重新打开,只要Session没有过期,购物车中的...

    JAVAWEB-10:会话技术之session&JSP

    Session是服务器端会话管理的一种方式,当用户登录网站或进行其他需要保持状态的操作时,服务器会在内存中创建一个与用户相关的Session对象,将用户信息存储在这个对象中,并返回一个唯一的Session ID给客户端(通常...

    PHP session 会话处理函数_.docx

    通过正确地使用`session_start()`、`$_SESSION`数组以及适时地销毁会话,可以有效地提高应用程序的安全性和用户体验。同时,在实际部署过程中,还需要注意采取相应的安全措施,避免会话劫持等风险。

    spring security 3.x session-management 会话管理失效

    - 在Spring Security的XML配置文件中,`&lt;http&gt;`元素下的`&lt;session-management&gt;`用于配置会话管理。例如,可以添加`&lt;concurrency-control&gt;`子元素来设置并发会话策略。 - `&lt;session-management&gt;`还可以配置`...

    微信小程序会话服务nodejs版

    在微信小程序的开发过程中,会话服务扮演着至关重要的角色,因为它是确保用户安全登录并能访问其个人信息的基础。在给定的“微信小程序会话服务nodejs版”中,我们可以看到一个基于Node.js的解决方案,用于处理微信...

    报表session与应用session常识普及

    在Web开发中,session是用于存储特定用户会话所需的信息的一种机制。每个用户访问网站时,服务器都会为该用户创建一个唯一的会话标识(session ID),通过这个标识可以在多次请求之间共享数据。系统session和报表...

    实战EJB之三 开发会话Bean(有状态会话Bean).doc

    开发一个有状态会话Bean需要继承javax.ejb.SessionBean接口,并实现相应的生命周期方法,如ejbCreate()、ejbRemove()、ejbPassivate()、ejbActivate()等。 5. 部署到应用服务器 在部署到应用服务器时,需要配置ejb...

    为微信小程序提供会话管理功能.zip

    在微信小程序开发中,会话管理是一个至关重要的环节,它涉及到用户登录状态的维护、数据交互的安全性以及用户体验的优化。本教程将深入探讨如何为微信小程序构建有效的会话管理系统,确保用户在小程序中的操作流畅且...

    web应用程序开发安全指南

    6. 会话管理:使用安全的会话管理机制,例如 Session 等,保护用户的会话数据。 7. 错误处理:使用安全的错误处理机制,例如 Try-Catch 等,保护用户的数据不被泄露。 8. 日志记录:使用安全的日志记录机制,例如...

    Session实现用户存储

    在Web开发中,Session是一种非常...在实际开发中,还需要考虑到Session的过期策略、安全性(防止Session Hijacking和Session Fixation攻击)以及性能优化(如Session的持久化存储和集群环境下的Session共享)等问题。

Global site tag (gtag.js) - Google Analytics