无奈之下,想到了一个下下策,那就是通过分析接受到的输入流,从中提取想要的数据。比如我在上文中提到的数据(两个参数,一个图片文件)
实现思路:读取输入流,通过非文件部份的分析,确定文件在整个流中的位置和大小,再对输入流重新读取以得到文件。
看上面的POST数据,参数部分及分隔符等,说白了都是些字符串。基本上都是英文数字符号等,如有中文发送之前可做一下编码,这样基本上可以确保不会因编码问题造成计算失误(英文字符各编码都是相同的)。这一部分内容(非文件部分,文件部分是二进制格式来的,千万别这样去做)可以得到。
通过接受输入的流转成字符串,如果参数中有中文,请注意客户端POST时使用何种编码:
复制代码 代码如下:
byte[] input = Request.BinaryRead(Request.TotalBytes);
string source = Encoding.UTF8.GetString(input);
然后通过正则表达式,匹配上面的非文件部份内容,此处略,再把得到的内容转成byte[],计算出它的长度。参数的值可以在这里得到了。
复制代码 代码如下:
Regex rginput = new Regex("略");
if (rginput.IsMatch(source))
{
int headLength=Encoding.UTF8.GetBytes(rginput.Match(source).Value)
}
同理计算出结尾出"-----------------------------7da119c1004a6--"的长度(这个每次请求应该是固定的)。注意有换行回车符。
这样,文件之外的部份在整个流中的大小可以确定,也就是说文件在整个流中的位置和大小也确定了。那么通过对原始流的重新读取就可以得到文件部份。如果文件是文本类型的,可以不用这样,直接跟参数部份一样分析获取。
复制代码 代码如下:
//保存文件
FileStream fss = new FileStream("path", FileMode.Create);
fss.Write(input, headLength, input.Length-headLength-footLength);
fss.Close();
代码
复制代码 代码如下:
//得到文件字节数组
byte[] imgcont = new byte[input.Length - headLength-footLength];
MemoryStream ms = new MemoryStream(input);
//光标移动到文件开始处
ms.Seek(headLength,SeekOrigin.Begin);
ms.Read(imgcont, 0, imgcont.Length);
ms.Close();
注:这个方法有一定的风险,就是对文件的大小和位置的确定,一定要计算准确,对输入流的分析要想周到全面;还有当上传文件为多个时,这个方法就麻烦了...如果你有更好的方法,可留言交流。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]