• BS版本的TCP程序


    //        使用Socket对象中的方法getInputStream,获取到网络字节输入流InputStream对象
    InputStream is = socket.getInputStream();
    // 使用网络字节输入流InputStream对象中的方法read读取客户端的请求信息
    /*int len =0;
    byte[] bytes = new byte[2048];
    while ((len=is.read(bytes))!=-1){
    System.out.println(new String(bytes,0,len));
    }*/
    // 把is网络字节输入流对象,转换成字符缓冲输入流
    BufferedReader br = new BufferedReader(new InputStreamReader(is));
    // 把客户端请求的信息的第一行读取出来GET /day19_Net/web/index.html HTTP/1.1
    String line = br.readLine();
    // 把读取的信息进行分割,只要中间一部分/day19_Net/web/index.html
    String[] arr = line.split(" ");
    // 把路径前边的/去掉,进行截取day19_Net/web/index.html
    String htmlpath = arr[1].substring(1);
    // 创建一个本地字节输入流,构造方法中绑定要读取的html路径
    FileInputStream fis = new FileInputStream(htmlpath);
    // 使用socket中的方法getOutputStream获取网络字节输出流outputStream
    OutputStream os = socket.getOutputStream();

    // 写入HTTP协议响应头,固定写法
    os.write("HTTP/1.1 200 OK ".getBytes());
    os.write("Content-Type:text/html ".getBytes());
    // 必须要写写入空行,否则浏览器不解析
    os.write(" ".getBytes());
    // 一读一些复制文件,把服务读取的html文件回显到客户端
    int len = 0;
    byte[] bytes = new byte[2048];
    while ((len = fis.read(bytes)) != -1) {
    os.write(bytes, 0, len);
    }
    fis.close();
    socket.close();
  • 相关阅读:
    求欧拉路径模版 fleury算法
    回学校前的计划
    高斯消元模版
    usaco 3.2 Stringsobits 数位dp
    dijkstra模版
    codeforces AIM Tech Round (Div. 2)
    bnuoj 51275 并查集按深度合并建树
    bzoj3674: 可持久化并查集
    poj2104 求区间第k大 可持久化线段树
    Miller_Rabin判断素数模版
  • 原文地址:https://www.cnblogs.com/newcityboy/p/11286271.html
Copyright © 2020-2023  润新知