Android服务端的设计
1.创建自己的MyServletContextListener.java:
package yybwb;
import java.net.ServerSocket;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
public class MyServletContextListener implements ServletContextListener
{ //这里使该类实现 ServletContextListener监听接口,在Tomcat启动时会调用实现该接口
//的 contextInitialized方法
ServerSocket ss = null;//声明ServerSocket对象
ServerThread st = null;//声明ServerThread对象
//创建服务线程,并将其启动,本方法在tomca启动时调用
public void contextInitialized(ServletContextEvent sce){
try{ ss = new ServerSocket(8888);
st = new ServerThread(ss);
st.start();
}catch(Exception e){ e.printStackTrace();
} }
//停止服务线程,本方法在tomca停止时调用
public void contextDestroyed(ServletContextEvent sce){
try{ st.flag = false;
ss.close();
ss = null;
st = null; }catch(Exception e){ e.printStackTrace();
} } }
2.在Web.xml中配置上面的监听类
<Listener> <Listener-class>XX.MyServletContextListener</Listener-class> </Listener>
3.创建服务线程ServerThread类如:
package yybwb;
import java.net.ServerSocket;
import java.net.Socket;
import java.net.SocketException;
public class ServerThread extends Thread{
public ServerSocket ss; //声明ServerSocket对象
public boolean flag = false; //循环标志位
public ServerThread(ServerSocket ss){ //构造器
this.ss = ss;
flag = true; }
//run方法创建ServerSocket 监听
public void run(){
while(flag){
try{
Socket socket = ss.accept();
//客户连接后,创建代理线程 ServerAgent,负责与该客户的通讯
ServerAgent sa = new ServerAgent(socket);
sa.start();
}
catch(SocketException se){
try{ ss.close();
ss = null;
System.out.println("ServerSocket closed");
}catch(Exception ee){
ee.printStackTrace();
}
}
catch(Exception e){
e.printStackTrace();
}
}
}
}
4.代理线程ServerAgent,如:
package yybwb;
/**LastDate:2014-10-22 * 更新菜单-#GET_MENULIST# * Author:Wuchyuan */
import static yybwb.ConstantUtil.DELETE_SUCCESS;
import static yybwb.ConstantUtil.DIARY_SUCCESS;
import static yybwb.ConstantUtil.REGISTER_FAIL;
import static yybwb.ConstantUtil.UPDATE_STATE_SUCCESS;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.EOFException;
import java.io.IOException;
import java.net.Socket;
import java.net.SocketException;
import java.sql.Blob;
import java.util.ArrayList;
import java.util.List;
public class ServerAgent extends Thread{
public Socket socket;
public DataInputStream din;
public DataOutputStream dout;
boolean flag = false;
public ServerAgent(Socket socket)
{ this.socket = socket;
try { this.din = new DataInputStream(socket.getInputStream()); this.dout = new DataOutputStream(socket.getOutputStream());
flag =true;
} catch (IOException e) { e.printStackTrace(); } } //方法:线程执行方法
public void run(){
while(flag){
try { String msg = din.readUTF(); //接收客户端发来的消息
// System.out.println("收到的消息是:"+msg);
if(msg.startsWith("<#LOGIN#>")){ //消息为登录
String content = msg.substring(9); //获得消息内容
String [] sa = content.split("\\|");
ArrayList<String> result = DBUtil.checkLogin(sa[0], sa[1]);
if(result.size()>1){ //登录成功
StringBuilder sb = new StringBuilder();
sb.append("<#LOGIN_SUCCESS#>");
for(String s:result){
sb.append(s);
sb.append("|"); }
String loginInfo = sb.substring(0,sb.length()-1);
dout.writeUTF(loginInfo); //返回用户的基本信息 }
else{ //登录失败
String loginInfo = "<#LOGIN_FAIL#>"+result.get(0);
dout.writeUTF(loginInfo); } }
//mealSvr发来的消息 2014-7-9
else if(msg.startsWith("<#PRINT_DINGD#>")){
//消息为查询打印订单2014-7-9
msg = msg.substring(15); //提取内容
String [] sa = msg.split("\\|"); //分割字符串
boolean result = DBUtil.QueryPrint(sa[0]); //查询是否有需打印订单
// if(result){ //有订单
dout.writeUTF("<#HAVE_DINGD#>"); //发回成功消息
dout.flush();
} else{
dout.writeUTF("<#NOT_DINGD#>"); //发回创建失败消息
dout.flush(); } }
//2014-10-22 检查用户密码
else if(msg.startsWith("<#CHECK_USERPASSWD#>")){
// msg = msg.substring(20); //提取内容
String [] sa = msg.split("\\|"); //分割字符串
boolean result = DBUtil.CheckUserPw(sa[0],sa[1]); //查询是否有需打印订单
System.out.println("查询"+sa[0]+"密码是否正确");
if(result){ //有
dout.writeUTF("<#CHECKPWD_HAVE#>"); //发回成功消息
dout.flush(); }
else{
dout.writeUTF("<#CHECKPWD_NOT#>"); //发回创建失败消息
dout.flush();
}
}
}
} catch(SocketException se){ try {
dout.close();
din.close();
socket.close();
socket = null;
flag = false;
} catch (IOException e) {
e.printStackTrace(); }
} catch(EOFException eof){
try { dout.close();
din.close();
socket.close();
socket = null;
flag = false;
} catch (IOException e) {
e.printStackTrace(); }
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
Android服务端的设计的更多相关文章
- Android 服务端开发之开发环境配置
Android 服务端开发之开发环境配置 这里是在Eclipse的基础上安装PhpEclipse插件方法,PHPEclipse是Eclipse的 一个用于开发PHP的插件.当然也可以采用Java开发a ...
- erlang-百度云推送Android服务端功能实现-erlang
百度云推送官方地址http://developer.baidu.com/wiki/index.php?title=docs/cplat/push 简单的介绍下原理: 百度云推送支持IOS和Androi ...
- 从服务端架构设计角度,深入理解大型APP架构升级
随着智能设备普及和移动互联网发展,移动端应用逐渐成为用户新入口,重要性越来越突出.但企业一般是先有PC端应用,再推APP,APP 1.0版的功能大多从现有PC应用平移过来,没有针对移动自身特点考虑AP ...
- 移动APP服务端API设计应该考虑到的问题
2014年,移动APP的热度丝毫没有减退,并没有像桌面软件被WEB网站那样所取代, 不但如此,越来越多的传统应用.网站也都开始制作自己的移动APP,也就是我们常说的IOS客户端.android客户端. ...
- APP和服务端-架构设计(二)
1. App架构设计经验谈:接口的设计 App与服务器的通信接口如何设计得好,需要考虑的地方挺多的,在此根据我的一些经验做一些总结分享,旨在抛砖引玉. 1.1 安全机制的设计 现在,大部分App的接口 ...
- APP和服务端-架构设计(一)
架构因人而异,不同的架构师大多会有不同的看法:架构也因项目而异,不同的项目需求不同,相应的架构也会不同.然而,有些东西还是通用的,是所有架构师都需要考虑的,也是所有项目都会有的需求,比如API如何设计 ...
- delphi xe5 android 服务端和手机端的源码下载
xe5 android的服务端和手机客户端的源代码下载地址 http://files.cnblogs.com/nywh2008/AndroidTest.rar
- 谈一款MOBA游戏《码神联盟》的服务端架构设计与实现
一.前言 <码神联盟>是一款为技术人做的开源情怀游戏,每一种编程语言都是一位英雄.客户端和服务端均使用C#开发,客户端使用Unity3D引擎,数据库使用MySQL.这个MOBA类游戏是笔者 ...
- 谈一款MOBA类游戏《码神联盟》的服务端架构设计与实现(更新优化思路)
注:本文仅用于在博客园学习分享,还在随着项目不断更新和完善中,多有不足,暂谢绝各平台或个人的转载和推广,感谢支持. 一.前言 <码神联盟>是一款为技术人做的开源情怀游戏,每一种编程语言都是 ...
随机推荐
- node async基础1
async的基础使用 1 async each 语法格式each(collection, iteratee, [callback]) 用途:遍历集合中的元素,并行对每个元素执行一定的操作,但是 ...
- 利用nodeJs来安装less以及编译less文件为css文件
NodeJs 使用nodejs安装less以及编译less文件为css文件 首先下载nodeJs的安装包,按照步骤,安装nodejs. 链接:http://pan.baidu.com/s/1dEsqY ...
- 全景智慧掌上城,飞入寻常百姓家——VR全景智慧城市
随着腾讯和阿里陆续将AR技术加入到新年抢红包大战之中,人们对于VR.AR未来的应用空间又多了一些想象.同传统的基于二维元素的抢红包不同,借助VR.AR的技术能够让用户获得一种更加真切的体验,这种体验相 ...
- 选择排序——Python实现
选择排序: 选择排序(Selection sort)是一种简单直观的排序算法.它的工作原理如下.首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小( ...
- nodeJS之二进制buffer对象
前面的话 在ES6引入TypedArray之前,JavaScript语言没有读取或操作二进制数据流的机制.Buffer类被引入作为Nodejs的API的一部分,使其可以在TCP流和文件系统操作等场景中 ...
- [52PJ] Java面向对象笔记(转自52 1510988116)
面向对象概念 面向对象三大特征:封装,继承,多态 面向对象编程(OOP,Object Oriented Programing)是相对于面向过程编程说的,之前写的代码基本都是纯的面向过程编程的,当项目复 ...
- Java——面向对象基础
Java继承 继承的概念 继承是java面向对象编程技术的一块基石,因为它允许创建分等级层次的类. 继承就是子类继承父类的特征和行为,使得子类具有父类的各种属性和方法,或子类从父类继承方法,使得子类具 ...
- 流畅的python学习笔记:第三章
字典的变种: OrderedDict 首先来看下面的代码,在一个字典中,有name,age,city,在遍历这个字典的时候.顺序却是随机的,不是按照我们添加的顺序也就是name->age-> ...
- TCP连接中time_wait在开发中的影响-搜人以鱼不如授之以渔
根据TCP协议定义的3次握手断开连接规定,发起socket主动关闭的一方socket将进入TIME_WAIT状态,TIME_WAIT状态将持续2个MSL(Max Segment Lifetime),T ...
- react实现双向绑定
双向绑定功能是在项目中比较常见的一个需求,传统的js实现方式是添加监听函数的方式,Vue框架实现很简单,因为它本身就是基于双向绑定实现的,接下来我将讲解一下如何使用react实现双向绑定的功能是 首先 ...