c# - 如何使用 TcpClient 将图像作为 HTTP 响应发送
问题描述
在我的工作中,我将服务器和客户端(多个设备)连接到同一个网络。
客户使用他们的网络浏览器与服务器联系。
TcpListener
服务器正在运行一个用于接收来自浏览器的请求的 C# 程序。
我正在尝试将图像发送TcpClient
到客户端设备,但结果如下:
我试过:
- 读取图像文件为
String
- 读取图像文件为
Byte[]
在 Chrome 开发者控制台中进行一些搜索后,我发现了一个错误
net::ERR_CONTENT_LENGTH_MISMATCH
。
我不知道为什么Content-Length: length-in-byte
即使通过new FileInfo(Target).Length
.
我使用的代码:
TcpListener Listener = new TcpListener(local_address, 9090);
Listener.Start();
TcpClient client = Listener.AcceptTcpClient();
NetworkStream ns = client.GetStream();
string target = HeaderKeys.GetValue("target"); /* image file in the request*/
string mime_type = MimeType.Extract(target); /* mime-type of the file */
byte[] content = File.ReadAllBytes(target);
StreamWriter writer = new StreamWriter(ns);
// response header
writer.Write("HTTP/1.0 200 OK");
writer.Write(Environment.NewLine);
writer.Write($"Content-Type: {mime_type}");
writer.Write(Environment.NewLine);
writer.Write("Content-Length: " + content.Length);
writer.Write(Environment.NewLine);
writer.Write(Environment.NewLine);
writer.Write(content);
writer.Flush();
client.Close();
我试过了
NetworkStream
直接地。- 读取图像文件
MemoryStream
并NetworkStream
写入。 - 将图像文件读取为 byte[] 并将其转换为 Base64。
解决方案
问题是因为StreamWriter
我已经使用以下代码解决了这个问题:
TcpClient client = Listener.AcceptTcpClient();
Stream s = client.GetStream();
byte[] file_content = File.ReadAllBytes(file);
StringBuilder header = new StringBuilder();
header.Append("HTTP/1.1 200 OK\r\n");
header.Append($"Content-Type: {mime_type}\r\n");
header.Append($"Content-Length: {file_content .Length}\r\n\n");
byte[] h = Encoding.ASCII.GetBytes(header.ToString());
s.Write(content, 0, content.Length);
s.Write(b, 0, b.Length);
s.Flush();
client.Close();
推荐阅读
- javascript - Firestore 参考密钥(AutoID)在 FOR 循环中表现得非常奇怪
- android - 我无法在 android studio 中安装或更新我的 sdk 组件
- c# - 内存中的 C# 类实例大小
- postman - 当 Postman 中的测试失败时如何在控制台上获得预期和实际结果
- c# - 通过 C# 创建原理图算法
- java - Redisson内存泄漏当我尝试创建客户端时
- java - 如果我只想显示我想在带有 mpAndroidchart 的 Android 折线图中的 X 轴上显示的值怎么办
- ubuntu-14.04 - pocketsphinx 语音识别 - 安装 gconf
- html - CSS 将纵向图像旋转 90 度并使图像全屏显示
- jquery - hoverIntent 插件仍然是防止悬停闪烁的最佳解决方案吗?