文档章节

多线程Java服务器简单实现

twins
 twins
发布于 2014/06/15 15:35
字数 263
阅读 12
收藏 0

代码主要由两个类构成:

  1. 服务类,默认开启一个8089的http服务

package com.twins.server;

import java.io.IOException;
import java.net.ServerSocket;

public class HttpServer {

	public static void main(String[] args) throws NumberFormatException, IOException {
		ServerSocket ss = new ServerSocket((args.length == 0) ? 8089 : Integer.parseInt(args[0]));
		System.out.println("Service started");
		while(true) {
			new HttpThread(ss.accept()).start();
			//ss.close();
		}
	}
}

 2.Http线程类,封装每个Http请求的处理操作

package com.twins.server;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.Socket;
import java.util.StringTokenizer;

public class HttpThread extends Thread{
	Socket socket;
	HttpThread(Socket ss) {
		this.socket = ss;
	}
	@Override
	public void run() {
		// TODO Auto-generated method stub
		try {
			BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream(), "gbk"));
			OutputStream out = socket.getOutputStream();
			String temp = null;
			
			/** 打印客户端请求参数 */
			while(!(temp = in.readLine()).equals("")) {
				
				//按行读取,解析GET协议
				if(temp.contains("GET")) {
					System.out.println(temp + " @"+ socket.getLocalSocketAddress());
					StringTokenizer st = new StringTokenizer(temp, " ");
					if(st.countTokens()>=2 && st.nextToken().equalsIgnoreCase("get")) {
						String path = st.nextToken();
						String filename = null;
						if(path.startsWith("/") && !path.endsWith("/")) {
							filename = path.substring(1);
						
						} else {
							
							/** 默认输出index.html*/
							filename = "index.html";
						}
						//解析html文本
						if(new File(filename).exists()) {
							InputStream file= new FileInputStream(filename);
							byte[] data = new byte[file.available()];
							file.read(data);
							out.write(data);
						} else {
							out.write(filename.getBytes());
						}
						break;
					}
				}
				
			}
			out.close();
			out.flush();
		} catch (UnsupportedEncodingException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} finally{
			try {
				socket.close();
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}
}

 

© 著作权归作者所有

共有 人打赏支持
twins
粉丝 4
博文 92
码字总数 27330
作品 0
哈尔滨
程序员
synchronized与ThreadLocal

synchronized是实现java的同步机制。同步机制是为了实现同步多线程对相同资源的并发访问控制。保证多线程之间的通信。 同步的主要目的是保证多线程间的数据共享。同步会带来巨大的性能开销,...

bigYuan
2013/07/18
0
2
【转】15个顶级Java多线程面试题及回答

Java 线程面试问题   在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分。如果你想获得任何股票投资银行的前台资讯职位,那么你应该准备很多关于多线程的问题。在投资银行业务...

一只死笨死笨的猪
2014/09/30
0
0
15个顶级Java多线程面试题及回答

Java 线程面试问题 在任何Java面试当中多线程和并发方面的问题都是必不可少的一部分。如果你想获得任何股票投资银行的前台资讯职位,那么你应该准备很多关于多线程的问题。在投资银行业务中多...

LCZ777
2014/05/27
0
0
Java高级-解析Java中的多线程机制

一、进程与应用程序的区别 进程(Process)是最初定义在Unix等多用户、多任务操作系统环境下用于表示应用程序在内存环境中基本执行单元的概念。以Unix操作系统为例,进程是Unix操作系统环境中...

陶邦仁
2012/11/11
0
0
java多线程之ThreadLocal

java中的java.lang.ThreadLocal,为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类可以很简洁地编写出优美的多线程程序,ThreadLocal并不是一个Thread,而是Thread的局部变量。...

飞翔的兔兔
2017/07/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

基于TP5的微信的公众号获取登录用户信息

之前讲过微信的公众号自动登录的菜单配置,这次记录一下在TP5项目中获取自动登录的用户信息并存到数据库的操作 基本的流程为:微信设置自动登录的菜单—>访问的URL指定的函数里获取用户信息—...

月夜中徘徊
今天
0
0
youTrack

package jetbrains.teamsys.license.runtime; 计算lis package jetbrains.ring.license.reader; 验证lis 安装后先不要生成lis,要把相关文件进行替换 ring-license-checker-1.0.41.jar char......

max佩恩
今天
0
0
12.17 Nginx负载均衡

Nginx负载均衡 下面的dig看到可以返回2个IP,就是解析出来的IP,这样我们可以做负载均衡。 dig www.qq.com 1.vim /usr/local/nginx/conf/vhost/fuzai.conf 2.添加如下配置 upstream qq //定义...

芬野de博客
今天
0
0
SSE(Server Send Event 服务端发送事件)

package com.example.demo.controller;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframe......

Canaan_
今天
0
0
jvm调优

1.jvm运行模式 client模式:启动快,占用内存少,jit编译器生成代码的速度也更快. server模式:主要优势在于代码优化功能,这个功能对于服务器应用而言尤其重要. tiered server模式:结合了client与...

Funcy1122
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部