ASP.NET文件上传并显示在同一页面上.NET Core 2.1

时间:2018-12-03 02:17:23

标签: asp.net asp.net-core asp.net-core-mvc

我是asp.net的新手,我只需要显示一个file upload控件(用于上传pdf),就可以在用户选择文件时显示其中的同一页面,然后在页面的正下方显示pdf。文件上传控件。通过自己设置基础知识,我已经学到了很多东西。但是由于某种原因,我无法使上载的pdf出现在我在页面上设置的object元素中。我确定我在代码中做了很多其他错误,因此请提出改进​​建议。请参阅以下内容。

请原谅这段代码中的幼稚:

Razor CSHTML文件:

@using (Html.BeginForm("PickPdf", "EditPdf", FormMethod.Post, new { id = "fileUploadControl", enctype = "multipart/form-data" }))
{
    <input type="file" name="file" class="chooseFileButton" />

    <input type="submit"
           name="Upload"
           id="Submit"
           value="View PDF"
           class="chooseFileButton"
           onclick="Validation" />
    <br><br>

    <p>@ViewBag.Message</p>

    <object id="pdfObject" name="pdfObject" data=@ViewData["FormFile"] type="application/pdf" width="400" height="200"></object>
}

C#控制器:

    public IActionResult Index()
    {
        return this.CustomView("");
    }    

    [HttpPost]
    public ActionResult PickPdf(){
        var files = Request.Form.Files;

        if(files != null && files.Count > 0)
        {
            IFormFile selectedFile = files[0];
            return this.CustomView(selectedFile.FileName, selectedFile);
        }

        return this.CustomView("File could not be processed");
    }



    private ActionResult CustomView(string message, IFormFile formFile = null){
        var returnView = View("Index");
        returnView.ViewData["Message"] = message;

        if(formFile != null){
            var readStream = formFile.OpenReadStream();
            byte[] bytes = new byte[readStream.Length];
            readStream.Read(bytes, 0, Convert.ToInt32(readStream.Length));
            returnView.ViewData["FormFile"] = bytes;
        }

        return returnView;
    }

2 个答案:

答案 0 :(得分:0)

尝试像这样修改方法。希望对您有帮助,我的朋友:))

private ActionResult CustomView(string message, IFormFile formFile = null)
        {
            var returnView = View("Contact");
            returnView.ViewData["Message"] = message;

            if (formFile != null)
            {
                var readStream = formFile.OpenReadStream();
                byte[] bytes = new byte[readStream.Length];                
                readStream.Read(bytes, 0, Convert.ToInt32(readStream.Length));
                var strBase64 = Convert.ToBase64String(bytes);
                var content = string.Format("data:application/pdf;base64,{0}", strBase64);
                ViewData["FormFile"] = content;
            }

            return returnView;
        }

答案 1 :(得分:0)

如果要在用户选择文件后立即显示PDF,则需要使用JavaScript。使用以下代码将事件处理程序绑定到文件输入的onchange事件:

$('#MyFileInput').on('change', function () {
    var file = this.files[0];

    if (file.type === 'application/pdf') {
        var reader = new FileReader();
        reader.onload = function(e) {
            $('MyObjectTag').data = e.target.result;
        }
        reader.readAsDataURL(file);
    }
});

这使用JavaScript File API读取用户选择的文件的内容,然后创建一个数据URL,然后可以将其分配给对象标记的data。重要的是要检查mime类型,以免有人不能将任何内容加载到对象标签中。

此外,请注意,这实际上并没有“上传”任何东西。用户仍然需要实际提交表单(或者您将需要通过AJAX发送表单数据)才能将实际文件发送到您的服务器。但是,这确实允许他们预览将要上传的内容,而不会导致页面刷新或实际上无法做的任何事情(如果这不是他们真正想要的文件,则可以再次选择)。此外,由于需要File API,因此只能在现代浏览器(IE 10+,以及地球上几乎所有其他浏览器)中使用。