asp.net上传图片

时间:2011-03-25 11:59:41

标签: c# asp.net file-upload

我有一个asp.net Web表单站点,我希望创建一个控件,允许用户浏览图像,然后将图像保存到数据库中。我知道将图像保存到数据库中是不好的做法,但这就是我被告知要做的事情!

有没有人对最佳方法有任何建议?

感谢

3 个答案:

答案 0 :(得分:6)

基本上你只需要一个FileUpload控件和一些代码将它保存到数据库中。 (而且你自然也想做一些输入检查。)有一个非常古老的教程很好地解释了这个概念hereThis one有点近了。但是有no shortage of others

答案 1 :(得分:4)

来自样本:

var intDoccumentLength = FileUpload1.PostedFile.ContentLength;
var newDocument = new byte[intDoccumentLength];

var stream = FileUpload1.PostedFile.InputStream;
stream.Read(newDocument, 0, intDoccumentLength);
var sqlConnection = new SqlConnection(sqlConnectionString);
sqlConnection.Open();

var sqlQuery = "INSERT INTO dbo.DocumentData (DocName, DocBytes, DocData, DocCreatedAt) VALUES (@DocName, @DocBytes, @DocData, @DocCreatedAt);"
                           + "SELECT CAST(SCOPE_IDENTITY() AS INT)";

sqlCommand = new SqlCommand(sqlQuery, sqlConnection);
sqlCommand.Parameters.Add("@DocName", SqlDbType.NVarChar, 255);
sqlCommand.Parameters.Add("@DocBytes", SqlDbType.Int);
sqlCommand.Parameters.Add("@DocData", SqlDbType.VarBinary);
sqlCommand.Parameters.Add("@DocCreatedAt", SqlDbType.DateTime);

sqlCommand.Parameters["@DocName"].Value = FileUpload1.PostedFile.FileName;
sqlCommand.Parameters["@DocBytes"].Value = intDoccumentLength;
sqlCommand.Parameters["@DocData"].Value = newDocument;
sqlCommand.Parameters["@DocCreatedAt"].Value = DateTime.Now;

var newDocumentId = (Int32) sqlCommand.ExecuteScalar();
sqlConnection.Close();

答案 2 :(得分:0)

工具箱中有fileupload工具。您只需在按钮的单击事件中编写以下代码即可。

string filename = FileUpload1.FileName.ToString();
         if (filename != "")
            {

                ImageName = FileUpload1.FileName.ToString();

                ImagePath = Server.MapPath("Images");
                SaveLocation = ImagePath + "\\" + ImageName;
                SaveLocation1 = "~/Image/" + ImageName;
                sl1 = "Images/" + ImageName;
                FileUpload1.PostedFile.SaveAs(SaveLocation);
            }

我希望你的数据库中有一个图像列,然后在插入查询中插入字符串sl1 ..