为什么MVC上传文件不能带word文件

时间:2018-02-08 04:56:57

标签: asp.net-mvc

我使用MVC创建了文件上传表单。它可以上传pdf,image,txt等文件,但不能上传Microsoft Word文件。列数据类型为varbinary(Max)。 控制器代码:

test_plot_call

查看:

    public ActionResult Create(HttpPostedFileBase postedFile)
    {

        byte[] bytes;
        using (BinaryReader br = new BinaryReader(postedFile.InputStream))
        {
            bytes = br.ReadBytes(postedFile.ContentLength);
        }
        string constr = WebConfigurationManager.ConnectionStrings["MyDataModel"].ConnectionString;
        using (SqlConnection con = new SqlConnection(constr))
        {
            string query = "INSERT INTO mytable (filedata,mimetype) VALUES (@filepath, @filedata,@mimetype)";
            using (SqlCommand cmd = new SqlCommand(query))
            {
                cmd.Connection = con;


                cmd.Parameters.AddWithValue("@filepath", Path.GetFileName(postedFile.FileName));
                cmd.Parameters.AddWithValue("@mimetype", postedFile.ContentType);
                cmd.Parameters.AddWithValue("@filedata", bytes);
                con.Open();
                cmd.ExecuteNonQuery();
                con.Close();

            }

        }
        return View();
    }
问题在哪里?感谢。

1 个答案:

答案 0 :(得分:0)

检查您的Web服务器设置,以查看.docx文件是否允许文件类型:

MIME类型: 应用/ vnd.openxmlformats-officedocument.wordprocessingml.document

这取决于Web服务器的类型和版本。

从IIS中的内存中,右键单击网站节点> HTTP标头>哑剧类型。