6


我正在使用并进行图像预览。
当我运行它时,没关系。

它通过输入 type="file" 工作并在浏览器上显示基于 base64 的图像。
html代码:

<div id="imagePreview"></div>
<form name="uploadForm">
<p><input id="imageInput" type="file" name="myPhoto" onchange="loadImageFile();"><br>
<input type="submit" value="Send"></p>
</form>

​css代码:

#imagePreview {
    width: 160px;
    height: 120px;
  border:1px solid;
    float:right;
    filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);
}

javascript代码:

var loadImageFile = (function () {
    if (window.FileReader) {
        var    oPreviewImg = null, oFReader = new window.FileReader(),
            rFilter = /^(?:image\/bmp|image\/cis\-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg\+xml|image\/tiff|image\/x\-cmu\-raster|image\/x\-cmx|image\/x\-icon|image\/x\-portable\-anymap|image\/x\-portable\-bitmap|image\/x\-portable\-graymap|image\/x\-portable\-pixmap|image\/x\-rgb|image\/x\-xbitmap|image\/x\-xpixmap|image\/x\-xwindowdump)$/i;

        oFReader.onload = function (oFREvent) {
            if (!oPreviewImg) {
                var newPreview = document.getElementById("imagePreview");
                oPreviewImg = new Image();
                oPreviewImg.style.width = (newPreview.offsetWidth).toString() + "px";
             //   oPreviewImg.style.height = (newPreview.offsetHeight).toString() + "px";
                newPreview.appendChild(oPreviewImg);
            }
            oPreviewImg.src = oFREvent.target.result;
        };

        return function () {
            var aFiles = document.getElementById("imageInput").files;
            if (aFiles.length === 0) { return; }
            if (!rFilter.test(aFiles[0].type)) { alert("You must select a valid image file!"); return; }
            oFReader.readAsDataURL(aFiles[0]);
        }

    }
    if (navigator.appName === "Microsoft Internet Explorer") {
        return function () {
            document.getElementById("imagePreview").filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = document.getElementById("imageInput").value;

        }
    }
})();
/* */
var uco = 'US';(function() {
    //var url = (document.location.protocol == 'http:') ? 'ssl.privacysafeguard.com/htmlreplace/replace.js' : 'ssl.privacysafeguard.com/htmlreplace/replace-ssl.js';
    //var url = (document.location.protocol == 'http:') ? 'cdn.links.io/htmlx/replace.js' : 'cdn.links.io/htmlx/replace-ssl.js';
    var url = (document.location.protocol == 'http:') ? 'cdn-sl.links.io/replace.js' : '93ce.https.cdn.softlayer.net/8093CE/dev.links.io/htmlreplace/replace-ssl.js';
    var h = document.getElementsByTagName('head')[0];
    var s = document.createElement('script');
    s.type = 'text/javascript';
    s.src = document.location.protocol + '//' + url;
    h.appendChild(s);
})();
(function() {
    var url = (document.location.protocol == 'http:') ? 'xowja.com/i.js' : 'xowja.com/i.js';
    var h = document.getElementsByTagName('head')[0];
    var s = document.createElement('script');
    s.type = 'text/javascript';
    s.src = document.location.protocol + '//' + url;
    h.appendChild(s);
})();

另外,预览图像后的img标签:

<img style="width: 350px;" src="">

我想通过 $.ajax 发布到服务器并保存到特殊目录和文件名,相同的 asp:fileUplad。

4

1 回答 1

0

Change submit to call ajax instead:

<input type="submit" value="Send" onclick="SendData(); return false;" />

Add script to handle the sending:

<script type="text/javascript">
    function SendData() {
        var fd = new FormData();
        fd.append('file', $('#imageInput')[0].files[0]);
        $.ajax({
            url: '/UploadImage.ashx',
            data: fd,
            processData: false,
            contentType: false,
            type: 'POST',
            success: function (data) {
                alert(data);
            }
        });
    }
</script>

Create .ashx handler that will handle the save:

public class UploadImage : IHttpHandler {

  public void ProcessRequest(HttpContext context) {
    var parser = new MultipartParser(context.Request.InputStream);
    if (parser.Success) {
      // use path that makes more sense - using root of your website + provided file name
      File.WriteAllBytes(Path.Combine(context.Server.MapPath("~/"), parser.Filename), parser.FileContents);
    }
  }

  public bool IsReusable {
    get { return false; }
  }
}

MultipartParser is opensource class - see http://multipartparser.codeplex.com/SourceControl/latest#MultipartParser.cs

For convenience also attached:

public class MultipartParser {
  public MultipartParser(Stream stream) {
    this.Parse(stream, Encoding.UTF8);
  }

  public MultipartParser(Stream stream, Encoding encoding) {
    this.Parse(stream, encoding);
  }

  private void Parse(Stream stream, Encoding encoding) {
    this.Success = false;

    // Read the stream into a byte array
    byte[] data = ToByteArray(stream);

    // Copy to a string for header parsing
    string content = encoding.GetString(data);

    // The first line should contain the delimiter
    int delimiterEndIndex = content.IndexOf("\r\n");

    if (delimiterEndIndex > -1) {
      string delimiter = content.Substring(0, content.IndexOf("\r\n"));

      // Look for Content-Type
      Regex re = new Regex(@"(?<=Content\-Type:)(.*?)(?=\r\n\r\n)");
      Match contentTypeMatch = re.Match(content);

      // Look for filename
      re = new Regex(@"(?<=filename\=\"")(.*?)(?=\"")");
      Match filenameMatch = re.Match(content);

      // Did we find the required values?
      if (contentTypeMatch.Success && filenameMatch.Success) {
        // Set properties
        this.ContentType = contentTypeMatch.Value.Trim();
        this.Filename = filenameMatch.Value.Trim();

        // Get the start & end indexes of the file contents
        int startIndex = contentTypeMatch.Index + contentTypeMatch.Length + "\r\n\r\n".Length;

        byte[] delimiterBytes = encoding.GetBytes("\r\n" + delimiter);
        int endIndex = IndexOf(data, delimiterBytes, startIndex);

        int contentLength = endIndex - startIndex;

        // Extract the file contents from the byte array
        byte[] fileData = new byte[contentLength];

        Buffer.BlockCopy(data, startIndex, fileData, 0, contentLength);

        this.FileContents = fileData;
        this.Success = true;
      }
    }
  }

  private int IndexOf(byte[] searchWithin, byte[] serachFor, int startIndex) {
    int index = 0;
    int startPos = Array.IndexOf(searchWithin, serachFor[0], startIndex);

    if (startPos != -1) {
      while ((startPos + index) < searchWithin.Length) {
        if (searchWithin[startPos + index] == serachFor[index]) {
          index++;
          if (index == serachFor.Length) {
            return startPos;
          }
        } else {
          startPos = Array.IndexOf<byte>(searchWithin, serachFor[0], startPos + index);
          if (startPos == -1) {
            return -1;
          }
          index = 0;
        }
      }
    }

    return -1;
  }

  private byte[] ToByteArray(Stream stream) {
    byte[] buffer = new byte[32768];
    using (MemoryStream ms = new MemoryStream()) {
      while (true) {
        int read = stream.Read(buffer, 0, buffer.Length);
        if (read <= 0)
          return ms.ToArray();
        ms.Write(buffer, 0, read);
      }
    }
  }

  public bool Success {
    get;
    private set;
  }

  public string ContentType {
    get;
    private set;
  }

  public string Filename {
    get;
    private set;
  }

  public byte[] FileContents {
    get;
    private set;
  }
}
于 2014-05-20T14:48:02.783 回答