using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Collections;
using System.Net;
using System.IO;
namespace www.xinduofen.cn
{
/// <summary>
/// C#与http服务器端进行对接的工具类
/// </summary>
class www.xinduofen.com
{
/// <summary>
/// 用于缓存服务器端传输到客户端的SESSIONID或者JSESSIONID
/// </summary>
private Cookie sessionidCookie = null;
/// <summary>
/// 向HttpWebServer端上传文件(使用的是"post"方式)
/// </summary>
/// <param name="url">请求网址</param>
/// <param name="data">请求参数集合,无需参数时传入null值</param>
/// <param name="cookies">请求cookie集合,无需cookie时传入null值</param>
/// <param name="filesSaveAddress">上传文件集合《控件名,上传文件的保存位置(包括"文件名"."扩展名")》,无需上传时传入null值</param>
/// <returns>返回请求结果字符串,返回为null代表请求失败</returns>
public String setFilesToHttpWebServer(String url, Hashtable data, CookieCollection cookies, Hashtable filesSaveAddress)
{
//用于缓存服务器端传输回来的结果字符串
string result = null;
if (string.IsNullOrEmpty(url))
{
return null;//传入参数异常
}
//用于分割信息部分的分隔符(不能与消息原文冲突)
String boundary = "HttpWebTool" + DateTime.Now.Ticks;
//结束分隔符数据流
byte[] andBoundary = Encoding.UTF8.GetBytes("--" + boundary + "--");
//新行字符串数据流
byte[] newline = Encoding.UTF8.GetBytes("\r\n");
try
{
HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(url);
//请求方式
req.Method = "POST";
//声明客户端只接收txt类型的内容
req.Accept = "text/plain";
//以消息的形式向服务器传递参数和数据流
req.ContentType = "multipart/form-data; boundary=" + boundary;
//设置cookie盒子(客户端请求的cookie和服务器端返回的cookie就放在此盒子中)
CookieContainer cookieContainer = new CookieContainer();
if (sessionidCookie != null && !string.IsNullOrEmpty(sessionidCookie.Domain))
{
cookieContainer.Add(sessionidCookie);
}
if (cookies != null)
{
cookieContainer.Add(cookies);//添加调用者传入的cookie集合
}
req.CookieContainer = cookieContainer;
//用于累计数据流长度,初始化为0
long dataCount = 0;
byte[] parameterBytes = getParameterBytes(data, boundary);
if (parameterBytes != null && parameterBytes.Length>0)
{
//累计请求参数字符串数据流大小
dataCount += parameterBytes.Length;
}
//<控件名,上传文件的消息头部分字符流byte[]>
Hashtable uploadFileDeclareBytesSet = new Hashtable();
//如果有要上传的文件
if (filesSaveAddress != null && filesSaveAddress.Count > 0)
{
foreach (DictionaryEntry de in filesSaveAddress)
{
//如果将要上传的文件存在
if (File.Exists(de.Value.ToString()))
{
byte[] uploadFileDeclareBytes = getUploadFileDeclareBytes(de, boundary);
if (uploadFileDeclareBytes!=null)
{
//累计上传文件消息头部描述字符串数据流大小
dataCount += uploadFileDeclareBytes.Length;
//累计上传文件正文数据流大小
dataCount += new FileInfo(de.Value.ToString()).Length;
//累计新行字符串数据流数据流大小
dataCount += newline.Length;
uploadFileDeclareBytesSet.Add(de.Key.ToString(), uploadFileDeclareBytes);
}
}
}
}
//如果有数据流
if (dataCount>0)
{
//累计结束分隔符数据流大小
dataCount += andBoundary.Length;
//请求数据流的长度
req.ContentLength = dataCount;
using (Stream requestStream = req.GetRequestStream())
{
if (parameterBytes != null && parameterBytes.Length > 0)
{
requestStream.Write(parameterBytes, 0, parameterBytes.Length);
}
if (filesSaveAddress != null && filesSaveAddress.Count > 0)
{
foreach (DictionaryEntry de in filesSaveAddress)
{
if (File.Exists(de.Value.ToString()))
{
byte[] uploadFileDeclareBytes = (byte[])uploadFileDeclareBytesSet[de.Key.ToString()];
requestStream.Write(uploadFileDeclareBytes, 0, uploadFileDeclareBytes.Length);
using (FileStream fileStream = new FileStream(de.Value.ToString(), FileMode.Open, FileAccess.Read))
{
//建立字节组,并设置它的大小是多少字节
byte[] bytes = new byte[10240];
int n = -1;
while ((n = fileStream.Read(bytes, 0, bytes.Length)) > 0)
{
requestStream.Write(bytes, 0, n); //将指定字节的流信息写入文件流中
}
}
requestStream.Write(newline, 0, newline.Length);
}
}
}
requestStream.Write(andBoundary, 0, andBoundary.Length);
}
}
//接收返回值
using (HttpWebResponse myResponse = (HttpWebResponse)req.GetResponse()) {
using (StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8)) {
result = reader.ReadToEnd().Trim();
}
if (myResponse.Cookies["SESSIONID"] != null)
{
sessionidCookie = myResponse.Cookies["SESSIONID"];
}
else
{
if (myResponse.Cookies["JSESSIONID"] != null)
{
sessionidCookie = myResponse.Cookies["JSESSIONID"];
}
}
}
}
catch (Exception)
{
Console.WriteLine("请查看传入参数是否正确或者服务器是否关闭");
}
return result;
}
/// <summary>
/// 获得参数data的消息数据流,以"\r\n"结尾
/// </summary>
/// <param name="data">请求参数集合,无需参数时传入null值</param>
/// <param name="boundary">消息分隔符</param>
/// <returns>返回参数data的数据流,返回为空代表获得失败</returns>
private byte[] getParameterBytes(Hashtable data, String boundary)
{
byte[] parameterBytes = null;
//如果有请求参数
if (data != null && data.Count > 0)
{
string parameterStr = "";
foreach (DictionaryEntry de in data)
{
parameterStr += "--" + boundary;
parameterStr += "\r\n" + "Content-Disposition: form-data;name=\"" + de.Key.ToString() + "\"";
parameterStr += "\r\n" + "Content-Type: text/plain; charset=UTF-8";
parameterStr += "\r\n\r\n" + de.Value.ToString();
parameterStr += "\r\n";
}
if (!string.IsNullOrEmpty(parameterStr))
{
parameterBytes = Encoding.UTF8.GetBytes(parameterStr);//将上传字符串数据打包成数据流
}
}
return parameterBytes;
}
/// <summary>
/// 获得上传文件的消息头部分字符流,以"\r\n\r\n"结尾
/// </summary>
/// <param name="de">上传文件《控件名,上传文件的保存位置(包括"文件名"."扩展名")》</param>
/// <param name="boundary">消息分隔符</param>
/// <returns>返回上传文件的消息头部分字符流,返回会为null代表获得失败</returns>
private byte[] getUploadFileDeclareBytes(DictionaryEntry de, String boundary)
{
byte[] uploadFileDeclareBytes = null;
//上传文件的消息头描述部分
string uploadFileDeclareStr = "";
uploadFileDeclareStr += "--" + boundary;
uploadFileDeclareStr += "\r\n" + "Content-Disposition: form-data;name=\"" + de.Key.ToString() + "\"; filename=\"" + de.Value.ToString() + "\"";
uploadFileDeclareStr += "\r\n" + "Content-Type: application/octet-stream";
uploadFileDeclareStr += "\r\n\r\n";
if (!string.IsNullOrEmpty(uploadFileDeclareStr))
{
uploadFileDeclareBytes = Encoding.UTF8.GetBytes(uploadFileDeclareStr);//将上传字符串数据打包成数据流
}
return uploadFileDeclareBytes;
}
相关推荐
在服务器端,确保已设置好正确的文件共享权限,以便客户端可以访问。同时,对于安全性考虑,应该避免直接使用硬编码的用户名和密码,而是推荐使用安全的身份验证机制,例如NTLM或Kerberos。 总之,虽然使用CMD...
FTP服务器端通常由一个程序组成,该程序监听特定端口(默认为21)上的连接请求,处理客户端的登录、文件上传、下载等操作。在C#中,我们可以使用System.Net.FtpServer命名空间中的FtpServer类来创建FTP服务器。首先...
2. 服务器端处理:在C#代码中,我们可以通过`HttpPostedFileBase`类获取到上传的文件。在`btnUpload_Click`事件处理函数中,可以进行文件读取、验证和保存。 ```csharp protected void btnUpload_Click(object ...
总的来说,C# WinForm上传照片到服务器涉及客户端文件操作、HTTP请求和可能的服务器端API开发。使用HttpClient可以方便地实现文件上传,通过调整ContentDisposition可以修改上传时的照片名字。同时,注意对可能出现...
文件上传的基本原理是通过客户端(WinForm应用程序)发起一个HTTP POST请求,将文件作为请求的一部分发送到服务器端指定的URL。服务器端接收到请求后,从中提取出文件数据并保存到指定的位置。 #### 三、具体实现...
总的来说,C#中的Web文件上传涉及到客户端和服务器端的交互,包括HTTP协议、表单提交、文件流处理以及安全性检查。通过使用ASP.NET提供的工具和类库,我们可以轻松实现这一功能,同时保持应用的安全和高效。
这主要包括两部分:一部分是服务器端处理文件上传的`Uploader.ashx`文件,另一部分是客户端用于发送文件的WinForm应用程序。 ### 一、服务器端处理文件上传 #### 1. `Uploader.ashx`文件分析 `Uploader.ashx`文件...
因此,断续上传应运而生,它允许将大文件分割成多个小块,逐个上传并最终在服务器端合并,这样可以有效提高上传的稳定性和效率。 C#中,我们可以利用ASP.NET MVC或ASP.NET Core的API来实现大文件上传。这些框架提供...
总之,通过C#使用Web Service上传视频文件到服务器虚拟机涉及到创建Web服务接口、客户端调用服务、服务器端接收并保存文件以及IIS的部署配置。理解并掌握这一流程对于开发者来说是非常重要的,特别是当涉及到跨平台...
这是服务器端程序,负责接收客户端的连接请求,提供文件列表,处理断点续传请求,并监控客户端的传输进度。服务器需要维护每个客户端的传输状态,以便在客户端重新连接时恢复传输。 5. **FileSyncClient**: ...
记得在实际部署时,确保服务器端的安全配置,如验证客户端的身份,限制上传大小等,以防止恶意文件上传或过大文件导致服务器崩溃。 总之,通过WinForm实现文件上传至服务器涉及客户端的UI设计、文件选择逻辑、HTTP...
### WinForm上传文件到服务器 #### 知识点概述 在.NET Framework中,Windows Forms(简称WinForms)是一种用于创建Windows桌面应用程序的技术。本篇内容介绍如何使用WinForm实现文件的上传功能,即将本地文件传输...
同时,控件可能使用了AJAX技术,通过异步方式发送文件数据,这样用户在上传文件时不会刷新整个页面,提高了交互性。 `Default.aspx`是ASP.NET Web应用程序的默认页面,它会展示用户首次访问应用时看到的内容。在这...
本案例“上传_下载经典案例(支持动态多传,单传)_.NET_C#”聚焦于文件上传和下载功能,这对于任何涉及用户交互的Web平台来说都是至关重要的。下面将详细阐述相关知识点。 1. 文件上传: - HTTP协议:文件上传是...
C# WinForm源代码,可以实现定时截取当前屏幕,然后存为本地图片,再将其上传至远程服务器端,上传图片到服务器。也包含上传文件到服务器端的方法。通过Ftp协议上传,更改源代码中ftp中IP地址、用户名及密码即可使用...
另外,服务器端应验证文件类型和大小,防止恶意文件上传。 10. **性能优化**: - 对于大文件上传,可以考虑使用分块上传或断点续传技术,提高上传效率和用户体验。 以上就是Android设备上传文件到C# WebService的...
在C#编程环境中,开发一个HTTP文件上传客户端是一项常见的任务,尤其在构建Web应用程序或集成API接口时。...在实际项目中,还需要根据服务器端API的具体要求调整代码,例如设置正确的Content-Type、添加认证信息等。
3. **文件分块**:对于大文件,可以将其拆分为小块,分别上传,然后在服务器端进行重组。这有助于提高上传效率和减少因网络问题导致的重传。 4. **断点续传**:如果支持,可以实现文件上传的断点续传功能,以便在...
当文件被上传时,服务器端的控制器或API会接收到这些文件,然后可以将它们保存到硬盘、数据库或进行其他处理。 总之,C#中实现HTTP上传文件的关键在于构造正确的HTTP请求,包括POST方法、multipart/form-data ...
6. **文件I/O操作**:在服务器端处理文件上传时,需要了解如何在磁盘上读写文件。 7. **安全考虑**:确保文件上传功能的安全性,避免恶意文件上传,例如通过验证文件类型、大小和扩展名。 8. **性能优化**:对于大...