要使用Request.BinaryRead(),提交的表單應該設置enctype為'multipart/form-data',如下,LZ請檢查一下:
<form id="up" method=post name="" action="cuscontactatt.asp" enctype="multipart/form-data">
</form>

解决方案 »

  1.   

    已经设置了啊:这是代码:(asp.net2.0)
    1.html部分:
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html>
     <head>
      <title>FCKeditor - Uploaders Tests</title>
      <script language="javascript"> 
    function SendFile()
    {
     var sUploaderUrl = cmbUploaderUrl.value ;
     
     if ( sUploaderUrl.length == 0 )
      sUploaderUrl = txtCustomUrl.value ;
     
     if ( sUploaderUrl.length == 0 )
     {
      alert( 'Please provide your custom URL or select a default one' ) ;
      return ;
     }
     
     eURL.innerHTML = sUploaderUrl ;
     txtUrl.value = '' ;
     
     frmUpload.action = sUploaderUrl ;
     frmUpload.submit() ;
    }function OnUploadCompleted( errorNumber, fileUrl, fileName, customMsg )
    {
     switch ( errorNumber )
     {
      case 0 : // No errors
       txtUrl.value = fileUrl ;
       alert( 'File uploaded with no errors' ) ;
       break ;
      case 1 : // Custom error
       alert( customMsg ) ;
       break ;
      case 10 : // Custom warning
       txtUrl.value = fileUrl ;
       alert( customMsg ) ;
       break ;
      case 201 :
       txtUrl.value = fileUrl ;
       alert( 'A file with the same name is already available. The uploaded file has been renamed to "' + fileName + '"' ) ;
       break ;
      case 202 :
       alert( 'Invalid file' ) ;
       break ;
      case 203 :
       alert( "Security error. You probably don't have enough permissions to upload. Please check your server." ) ;
       break ;
      default :
       alert( 'Error on file upload. Error number: ' + errorNumber ) ;
       break ;
     }
    }  </script>
     </head>
     <body>
      <table cellSpacing="0" cellPadding="0" width="100%" border="0" height="100%">
       <tr>
        <td>
         <table cellSpacing="0" cellPadding="0" width="100%" border="0">
          <tr>
           <td nowrap style="height: 43px">
            Select the "File Uploader" to use:<br>
            <select id="cmbUploaderUrl" name="Select1">
             <option selected value="asp/upload.asp">ASP</option>
             <option value="php/upload.php">PHP</option>
             <option value="Upload.aspx?type=image">aspx</option>
            </select>
           </td>
           <td nowrap style="height: 43px">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
           <td width="100%" style="height: 43px">
            Custom Uploader URL:<BR>
            <input id="txtCustomUrl" style="WIDTH: 100%; BACKGROUND-COLOR: #dcdcdc" disabled type="text">
           </td>
          </tr>
         </table>
         <br>
         <table cellSpacing="0" cellPadding="0" width="100%" border="0">
          <tr>
           <td noWrap>
            <form id="frmUpload" target="UploadWindow" enctype="multipart/form-data" action="" method="post">
             Upload a new file:<br>
             <input type="file" name="NewFile"><br>
             <input type="button" value="Send it to the Server" onclick="SendFile();">
            </form>
           </td>
           <td style="WIDTH: 16px">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</td>
           <td vAlign="top" width="100%">
            Uploaded File URL:<br>
            <INPUT id="txtUrl" style="WIDTH: 100%" readonly type="text">
           </td>
          </tr>
         </table>
         <br>
         Post URL: <span id="eURL">&nbsp;</span>
        </td>
       </tr>
       <tr>
        <td height="100%">
         <iframe name="UploadWindow" width="100%" height="100%"></iframe>
        </td>
       </tr>
      </table>
     </body>
    </html>
      

  2.   

    2.后台代码部分(我是想用html页面Post数据到aspx页面)
    using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.IO;
    using System.Text;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using System.Xml;
    using System.Collections.Specialized;
    public partial class Upload : System.Web.UI.Page
    {
        public void SendResults(int errorNumber, string fileUrl, string fileName, string customMsg)
        {
            StringBuilder text = new StringBuilder();
            text.Append("<script type=\"text/javascript\">");
            text.Append("window.parent.OnUploadCompleted(" + errorNumber + ",\"" + fileUrl.Replace("\"", "\\\"") + "\",\"" + fileName.Replace("\"", "\\\"") + "\",\"" + customMsg.Replace("\"", "\\\"") + "\") ;\n");
            text.Append(" </script>");
            Response.Write(text.ToString());
            Response.End();
        }
        public void GetConfig(string type, out string[] allowedExt, out string[] denyedExt, out string savePath, out long maxSize)
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(Server.MapPath(@".\Config.xml"));
            XmlElement root = doc.DocumentElement;
            XmlNodeList imageNodelist = root.GetElementsByTagName(type);
            allowedExt = imageNodelist[0].FirstChild.InnerText.Trim().Split('|');
            denyedExt = imageNodelist[0].LastChild.InnerText.Trim().Split('|');
            savePath = root.GetElementsByTagName("userPath").Item(0).InnerText.Trim();
            try
            {
                maxSize = Convert.ToInt64(root.GetElementsByTagName("maxSize").Item(0).InnerText.Trim());
            }
            catch { maxSize = 1028 * 1024; }
        }
        protected void Page_Load(object sender, EventArgs e)
        {        string[] allowedExt = new string[] { }, denyedExt = new string[] { };
            string savePath = String.Empty;
            long maxSize = 10000;
            string type = Request.QueryString["Type"];
            if (type != null && type != string.Empty)
                type = type.ToLower();
            else
                type = "file";
            if (type == "image")
            {
                GetConfig("image", out allowedExt, out denyedExt, out savePath, out maxSize);
            }
            if (type == "file")
            {
                GetConfig("file", out allowedExt, out denyedExt, out savePath, out maxSize);
            }
            if (type == "flash")
            {
                GetConfig("flash", out allowedExt, out denyedExt, out savePath, out maxSize);
            }
            if (savePath == string.Empty || savePath == "")
                savePath = "~/UserFiles/";
            if (!savePath.EndsWith("/")) savePath += "/";
            /***********************************************************************
             byte[] bytes1 = System.Text.Encoding.Default.GetBytes("这是字符串\n\n\n\n");
             byte[] bytes2 = new byte[] { 1, 33, 23, 3, 0, 56, 55, 235, 5 };//二进制数 
             byte[] bytes = new byte[bytes1.Length + bytes2.Length];         //合并二进制流
             MemoryStream ms = new MemoryStream(bytes);
             ms.Write(bytes1, 0, bytes1.Length);
             ms.Write(bytes2, 0, bytes2.Length);         int count = 0, pos = 0;
             //开始找四个'\n'
             for (int i = 0; i < bytes.Length; i++)
             {
              if (bytes[i] == (int)'\n')
              {
               count++;
               if (count == 4)
               {
                pos -= 4;
                break;
               }
              }
             }         if (count == 4)
             {
              //这里,bytes字节数组里从0 到 pos 的位置就是你要的字符串
              //从pos + 5 开始到最后,就是你要的二进制
             }
             ***********************************************************************/
            byte[] fileData, formData;
            Request.BinaryRead(1);
            formData = Request.BinaryRead(Request.ContentLength);
            string test=formData.ToString();
            Response.Write(test);
            string head = String.Empty;
            Encoding encoding = Encoding.UTF8;        long pos = 0;
            for (long i = 0; i < formData.LongLength; i++)
            {
                if (formData[i] == (byte)'\r' && formData[i + 1] == (byte)'\n' && formData[i + 2] == (byte)'\r' && formData[i + 3] == (byte)'\n')
                {
                    pos = i;
                    break;
                }
            }
            if (pos == 0) { Response.End(); return; }
            head = encoding.GetString(formData, 0, (int)pos);
            fileData = new byte[formData.LongLength - pos - 3];
            Array.Copy(formData, pos + 4, fileData, 0, formData.LongLength - pos - 4);
            /*********************************************************************
            //传来的表单形式是:
            //"-----------------------------7d5fa3820f84\r\nContent-Disposition: form-data; name=\"NewFile\"; filename=\"F:\\Documents\\4(10995).jpg\"\r\nContent-Type: image/pjpeg\r\n\r\n
            //后面是文件数据
             *********************************************************************/
            head = head.ToLower();
            head = head.Remove(0, head.IndexOf("\r\n") + 2);
            head = head.Replace("\"", "");
            string postFileName = string.Empty;
            string fileName;//no path
            string fileType, fileExt;
            postFileName = head.Substring(0, head.IndexOf("\r\n"));//Content-Disposition: form-data; name=\"NewFile\"; filename=\"F:\\Documents\\4(10995).jpg\"
            fileType = head.Remove(0, postFileName.Length + 3);//returns:Content-Type: image/pjpeg
            postFileName = postFileName.Substring(postFileName.IndexOf("filename=") + "filename=".Length);//C:\path\name
            fileName = Path.GetFileName(postFileName);
            fileExt = fileName.Substring(fileName.LastIndexOf(".") + 1);
            if (fileData.LongLength > maxSize)
            {
                SendResults(2, ResolveUrl(savePath + fileName), fileName, "Too large");
                return;
            }
            bool isallow = false;
            foreach (string ext in denyedExt)
            {
                if (ext == fileExt)
                {
                    isallow = false;
                    SendResults(202, ResolveUrl(savePath + fileName), fileName, "forrbiden");
                    return;
                }
            }        foreach (string ext in allowedExt)
            {
                if (ext == fileExt) { isallow = true; break; }
            }
            if (isallow)
            {
                string tmpPath = Server.MapPath(savePath);
                if (!Directory.Exists(tmpPath))
                {
                    try
                    {
                        Directory.CreateDirectory(tmpPath);
                    }
                    catch { SendResults(200, ResolveUrl(savePath + fileName), fileName, "没有写入权限"); }
                }
                //Response.BinaryWrite(fileData);
                FileStream savefileStream = new FileStream(tmpPath + fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite);
                for (long i = 0; i < fileData.LongLength; i++)
                {
                    savefileStream.WriteByte(fileData[i]);
                }
                savefileStream.Close();
                SendResults(0, ResolveUrl(savePath + fileName), fileName, "No errors");        }    }
    }