Java编程利用socket多线程访问服务器文件代码示例

这篇文章将向大家展示Java编程利用socket多线程访问服务器文件代码示例,如果您想先了解Java多线程socket编程的基础知识,可以看下这篇文章:Java多线程编程实现socket通信示例代码。

接下来进入正文,我们看看利用socket多线程访问服务器代码:

ServerMain.java

package com.ysk.webServer;
import java.io.File;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
public class ServerMain {
  static boolean start = true;
  public static void main(String[] args) {
    // 1.声明所用的对象
    // ServerSocket
    // Socket
    // BufferedReader
    // PrintStream 因为这个流是用来按照http相应规则返回数据给浏览器的,
    // http响应规则中可能既要写字符又要写字节 所以使用这个流
    try {
      // 2 赋值,为try catch语句块外面的变量赋值
      ServerSocket serverSocket = new ServerSocket(7878);
      while (true) {
        while (start) {
          System.out.println("服务端已启动,等待客户端连接。。");
          Socket socket = serverSocket.accept();
          System.out.println("客户端已连接");
          Thread thread = new ServerThread(socket);
          thread.start();
        }
        // 3 处理请求,即从socket中拿出浏览器按照http协议封装好的请求(字符串)
        // 关心请求行
        // 按照空格拆分字符串,拆出来的第一部分是请求方式
        // 拆出来的第二部分是资源路径
        // 4 处理响应
        // 如果 请求方式 是GET即代表没有请求体
        // 从请求行中寻找到要访问的文件
        // 从本地目录下查找(不是遍历整个文件系统
        // 代表着我们要定义一个目录位置,此位置为数据仓库,
        // 专门来存放客户端可能会访问的数据
        // 咱们暂定这个目录为“项目/files”)
        // 看看是否有此文件,对于/ 资源特殊处理,代表
        // 如果有文件,利用输出流,把数据拼成http响应格式的数据,
        // 返回给客户端(数据找到了,响应码200)
        // 如果没有文件,返还error.html文件(代表比较友好的提示方式),
        // 也得按照http响应格式返还error.html
      }
      // 如果是post方式,暂不处理
    } catch (Exception e) {
    }
  }
  // 关闭资源
  // 什么时候关服务器,什么时候关客户端
}

ServerThread.java

package com.ysk.webServer;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.net.Socket;
public class ServerThread extends Thread {
  // 和本线程相关的Socket
  Socket socket = null;
  BufferedReader in = null;
  BufferedReader inerror = null;
  PrintStream out = null;
  static boolean result = false;
  static String filepath = "";
  public ServerThread(Socket socket) {
    this.socket = socket;
  }
  @Override
  public void run() {
    try {
      in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
      String temp = in.readLine();
      if (temp != null) {
        ServerMain.start = false;
        String method = temp.split(" ")[0];
        System.out.println(method);
        String filename = temp.split(" ")[1].replaceAll("/", "");
        System.out.println(filename);
        String path = "files";
        findFile(path, filename);
        System.out.println("result:" + result);
        if (result) {
          // 找到文件,以字节方式去读
          String resource = filepath + filename;
          getResource(resource);
        } else {
          // 返回error.html
          String resource = "files\\error.html";
          getResource(resource);
        }
      }
    } catch (Exception e) {
    } finally {
      try {
        if (out != null)
          out.close();
        if (inerror != null)
          inerror.close();
        if (in != null)
          in.close();
        if (socket != null)
          socket.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
  }
//通过流去读文件
  private void getResource(String resource) {
    try {
      FileInputStream fileInputStream = new FileInputStream(resource);
      out = new PrintStream(socket.getOutputStream(), true);
      out.println("HTTP/1.1 200 ok");
      out.println();
      int inttemp;
      while ((inttemp = fileInputStream.read()) != -1) {
        out.write(inttemp);
      }
      out.flush();
      fileInputStream.close();
      ServerMain.start = true;
      result = false;
    } catch (Exception e) {
    }
  }
  // 查找文件
  private static void findFile(String path, String filename) throws IOException {
    File file = new File(path);
    File[] tempList = file.listFiles();
    System.out.println("该目录下对象个数:" + tempList.length);
    for (int i = 0; i < tempList.length; i++) {
      if (tempList[i].isFile() && filename.equals(tempList[i].getName())) {
        System.out.println("已找到该文件:" + filename);
        filepath = path + "\\";
        result = true;
      } else if (tempList[i].isDirectory()) {
        // 读取某个文件夹下的所有文件夹
        System.out.println("读取某个文件夹下的所有文件夹");
        findFile(tempList[i].getParent() + "\\" + tempList[i].getName(), filename);
      }
    }
  }
}

总结

以上就是本文关于Java编程利用socket多线程访问服务器文件代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:Java网络编程基础篇之单向通信、Java多线程编程安全退出线程方法介绍等,有什么问题,欢迎大家留言交流讨论,感谢朋友们对我们网站的支持!

(0)

相关推荐

  • Java Socket实现多线程通信功能示例

    本文实例讲述了Java Socket实现多线程通信功能的方法.分享给大家供大家参考,具体如下: 前面的文章<Java Socket实现单线程通信的方法示例>说到怎样写一个最简单的Java Socket通信,但是文章中的例子有一个问题就是Server只能接受一个Client请求,当第一个Client连接后就占据了这个位置,后续Client不能再继续连接,所以需要做些改动,当Server没接受到一个Client连接请求之后,都把处理流程放到一个独立的线程里去运行,然后等待下一个Client连接请求

  • Java Web项目中使用Socket通信多线程、长连接的方法

    很多时候在javaweb项目中我们需要用到Socket通信来实现功能,在web中使用Socket我们需要建立一个监听程序,在程序启动时,启动socket监听.我们的应用场景是在java项目中,需要外接如一个硬件设备,通过tcp通信,获取设备传上来的数据,并对数据做回应. 先看一下web的监听代码: import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; public class

  • Java基于Socket实现简单的多线程回显服务器功能示例

    本文实例讲述了Java基于Socket实现简单的多线程回显服务器功能.分享给大家供大家参考,具体如下: 需要两个类,一个是EchoServer,代表服务器.另外一个是EchoServerClient,代表客户端.代码如下: package interview; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter

  • Java编程利用socket多线程访问服务器文件代码示例

    这篇文章将向大家展示Java编程利用socket多线程访问服务器文件代码示例,如果您想先了解Java多线程socket编程的基础知识,可以看下这篇文章:Java多线程编程实现socket通信示例代码. 接下来进入正文,我们看看利用socket多线程访问服务器代码: ServerMain.java package com.ysk.webServer; import java.io.File; import java.io.IOException; import java.net.ServerSoc

  • Java编程GUI中的事件绑定代码示例

    程序绑定的概念: 绑定指的是一个方法的调用与方法所在的类(方法主体)关联起来.对java来说,绑定分为静态绑定和动态绑定:或者叫做前期绑定和后期绑定 静态绑定: 在程序执行前方法已经被绑定,此时由编译器或其它连接程序实现.例如:C. 针对java简单的可以理解为程序编译期的绑定:这里特别说明一点,java当中的方法只有final,static,private和构造方法是前期绑定 动态绑定 后期绑定:在运行时根据具体对象的类型进行绑定. 若一种语言实现了后期绑定,同时必须提供一些机制,可在运行期间

  • Java编程实现五子棋人人对战代码示例

    利用Java,在控制台操作下,编写的五子棋,作为复习二维数组,面向对象等基础知识.w表示白棋,b表示黑棋 import java.util.Scanner; public class MainMethod { public static char[][] c = new char[10][10]; public static void main(String[] args) { MainMethod mainMethod = new MainMethod(); mainMethod.init()

  • Java编程线程间通信与信号量代码示例

    1.信号量Semaphore 先说说Semaphore,Semaphore可以控制某个资源可被同时访问的个数,通过acquire()获取一个许可,如果没有就等待,而release()释放一个许可.一般用于控制并发线程数,及线程间互斥.另外重入锁ReentrantLock也可以实现该功能,但实现上要复杂些. 功能就类似厕所有5个坑,假如有10个人要上厕所,那么同时只能有多少个人去上厕所呢?同时只能有5个人能够占用,当5个人中的任何一个人让开后,其中等待的另外5个人中又有一个人可以占用了.另外等待的

  • Java编程将汉字转Unicode码代码示例

    上一次接触到编码的知识,还是上大学的时候,那时候学的是通信工程专业,有关编码的内容,不记得是在通信原理还是信息论与编码里面学到的了.却依然记得那个信息论与编码的老师,最喜欢吃的是尖椒肥肠盖饭,不知道是尖椒肥肠吃多了还是太聪明的缘故,三十多岁就开始拜顶了.那四年真是一段难忘的回忆... 话不多说,咱们进入正题.这里是一个简单的Java编程将汉字转Unicode码代码示例,下面是代码: package me.socketthread; public class ToUnicode { /** * @

  • Java编程实现邻接矩阵表示稠密图代码示例

    我们知道,要表示结点,我们可以用一个一维数组来表示,然而对于结点和结点之间的关系,则无法简单地用一维数组来表示了,我们可以用二维数组来表示,也就是一个矩阵形式的表示方法. 我们假设A是这个二维数组,那么A中的一个元素aij不仅体现出了结点vi和结点vj的关系,而且aij的值正可以表示权值的大小. 邻接矩阵模型类 邻接矩阵模型类的类名为AMWGraph.java,能够通过该类构造一个邻接矩阵表示的图,且提供插入结点,插入边,取得某一结点的第一个邻接结点和下一个邻接结点. import java.u

  • Java编程IP地址和数字相互转换代码示例

    最近才知道,将ip地址转换成十进制.八进制.十六进制同样可以访问网站. IP转为数字(第二种算法.用左移.按位或实现.效率更高.): public long ipToLong(String ipAddress) { long result = 0; String[] ipAddressInArray = ipAddress.split("\\."); for (int i = 3; i >= 0; i--) { long ip = Long.parseLong(ipAddress

  • Java编程常见内存溢出异常与代码示例

    Java 堆是用来存储对象实例的, 因此如果我们不断地创建对象, 并且保证 GC Root 和创建的对象之间有可达路径以免对象被垃圾回收, 那么当创建的对象过多时, 会导致 heap 内存不足, 进而引发 OutOfMemoryError 异常. /** * @author xiongyongshun * VM Args: java -Xms10m -Xmx10m -XX:+HeapDumpOnOutOfMemoryError */ public class OutOfMemoryErrorTe

  • Java编程实现深度优先遍历与连通分量代码示例

    深度优先遍历 深度优先遍历类似于一个人走迷宫: 如图所示,从起点开始选择一条边走到下一个顶点,没到一个顶点便标记此顶点已到达. 当来到一个标记过的顶点时回退到上一个顶点,再选择一条没有到达过的顶点. 当回退到的路口已没有可走的通道时继续回退. 而连通分量,看概念:无向图G的极大连通子图称为G的连通分量( Connected Component).任何连通图的连通分量只有一个,即是其自身,非连通的无向图有多个连通分量. 下面看看具体实例: package com.dataStructure.gra

  • java编程实现两个大数相加代码示例

    通常情况,实现大数运算是通过BigInteger和BigDecimal两种方法.这两种方法分别表示不可变的任意精度的整数和不可变的有符号的任意精度的十进制数(浮点数).主要用于高精度计算中.这两个类使得java中的大数,高精度运算变得很简单.但本文介绍的并不是通过上述两种方法实现Java中的大数运算. 主要的思想是:把两个数存在String中了,然后将每个数字取出,放到数组,由最末位开始计算,算加法,判断是否进位,进位则前位+1,若超过长度,则copy到新的数组. 代码如下: public cl

随机推荐