自定义服务器

package com.ligong;

import sun.misc.IOUtils;

import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
/*
    自定义服务器
 */
public class Server {
    public static void main(String[] args) throws IOException {
        ServerSocket ss = new ServerSocket(8080); // 监听指定端口
        System.out.println("server is running...");
        while (true){
        //接收来自客户端的请求
            Socket sock = ss.accept();
            //获取客户端的地址
            System.out.println("connected from " + sock.getRemoteSocketAddress());
            Thread t = new Handler(sock);
            t.start();
        }
    }
}

class Handler extends Thread {
    Socket sock;

    public Handler(Socket sock) {
        this.sock = sock;
    }

    public void run() {
    //读取客户端发来的字节流
        try (InputStream input = this.sock.getInputStream()) {
        //向客户端写数据
            try (OutputStream output = this.sock.getOutputStream()) {
            //处理请求或者响应数据
                handle(input, output);
            }
        } catch (Exception e) {
            try {
                this.sock.close();
            } catch (IOException ioe) {
            }
            System.out.println("client disconnected.");
        }
    }

    private void handle(InputStream input, OutputStream output) throws IOException {
     //字节流转换为字符流
        BufferedReader reader = new BufferedReader(new InputStreamReader(input, StandardCharsets.UTF_8));
        BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(output, StandardCharsets.UTF_8));
        // 读取HTTP请求:
        boolean requestOk = false;
        String first = reader.readLine();
        if (first.startsWith("GET / HTTP/1.")) {
            requestOk = true;
        }
        for (;;) {
            String header = reader.readLine();
            if (header.isEmpty()) { // 读取到空行时, HTTP Header读取完毕
                break;
            }
            System.out.println(header);
        }
        System.out.println(requestOk ? "Response OK" : "Response Error");
        if (!requestOk) {
            // 发送错误响应:
            writer.write("HTTP/1.0 404 Not Found\r\n");
            writer.write("Content-Length: 0\r\n");
            writer.write("\r\n");
            writer.flush();
        } else {
            // 发送成功响应:

            //读取html文件,转换为字符串
            BufferedReader br = new BufferedReader(new FileReader("http/html/a.html"));
            StringBuilder data = new StringBuilder();
            String line = null;
            while ((line = br.readLine()) != null){
                data.append(line);
            }
            br.close();
            int length = data.toString().getBytes(StandardCharsets.UTF_8).length;

            writer.write("HTTP/1.1 200 OK\r\n");
            writer.write("Connection: keep-alive\r\n");
            writer.write("Content-Type: text/html\r\n");
            writer.write("Content-Length: " + length + "\r\n");
            writer.write("\r\n"); // 空行标识Header和Body的分隔
            writer.write(data.toString());
            writer.flush();
        }
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
vue wangeditor可以通过自定义方式将内容黏贴到服务器。首先,我们需要获取到黏贴的内容,可以使用wangeditor提供的黏贴事件监听函数,监听到该事件后,可以获取到黏贴的内容。 然后,我们可以将获取到的内容通过ajax等方式发送到服务器。具体的发送方式可以根据自己的需求选择合适的方法,例如使用axios库发送POST请求。将获取到的内容作为请求体发送到服务器指定的URL。 服务器端接收到请求后,可以对内容进行处理,例如保存到数据库或进行其他操作。根据服务器端的编程语言或框架,可以使用相应的接口来处理这个请求。 在Vue的代码中,我们可以使用官方推荐的axios库来发送POST请求到服务器。下面是一个示例代码: ```javascript import axios from 'axios' // 监听wangeditor的黏贴事件 editor.customConfig.onpaste = (html) => { // 获取到黏贴的内容 const content = html || "" // 将内容发送到服务器 axios.post('http://your-server-url.com/save-paste', { content: content }) .then(response => { console.log(response.data) }) .catch(error => { console.error(error) }) } ``` 在服务器端,根据自己的需求进行处理黏贴的内容。下面是一个示例的Node.js Express路由处理: ```javascript app.post('/save-paste', (req, res) => { const content = req.body.content || "" // 在这里进行对黏贴内容的处理,例如保存到数据库 res.send({ message: '保存成功' }) }) ``` 以上就是通过自定义方式将vue wangeditor的内容黏贴到服务器的一个简单示例。根据实际需求,可以灵活调整代码来满足各种情况的处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值