asp.net向sql server导入文件主要用到fileupload控件的filebytes属性。该属性从fileupload控件所指定的文件返回一个字节数组 。
1.数据库准备
为了方便大家能够理解,这里我们只设计两个字段,一个是文件类型字段,字段名为filetype,另一个是存放文件内容字段,字段名为filecontent。创建数据库
,数据库名为varfile,语句如下:
create database varfile
go
创建表,表名为fileinout,语句如下:
use varfile
go
create table fileintou
(
filetype nvarchar(30) not null,
filecontent varbinary(max) null
)
2.添加控件
运行vs2008并新建一个网站,在页面default.aspx中添加一个fileupload控件,id 为fileupload1.同时添加三个button按钮,id分别为fileup和fileload。text属性分别设置为“上传文件”和“下载文件”。
3.添加代码
(1)添加命名空间,因为和sql server数据库连接,所以添加using system.data.sqlclient和using system.data命名空间。又因为要设置输出流的http的字符集为”gb2312″字符编码,所以添加using system.text命名空间。同时又因为要把导出文件强类型化为字符串,所以添加using system.collections.specialized命名空间。
(2)添加“上传文件”按钮的事件代码。当单击“上传文件”按钮后,获取fileupload控件所选择的文件的文件类型以及文件的字节数组插入数据库中。切换到设计视图,双击“上传文件”按钮,添加”上传文件”按钮事件代码,代码如下:
复制代码 代码如下:
protected void fileup_click(object sender,eventargs e)
{
if(fileupload1.filename==string.empty)
{
response.write(“<script>altert(‘请选择要上传的文件’)</script>”);
return;
}
string mailto:connstr=@%22data source=69f638102711447\sql2008;initial catalog=varfile;integrated security=ture”; //数据库连接字符串
string the selected=fileupload1.filename; //获取上传文件的后缀名
string extension=theselected.substring(theselected.lastindexof(“.”)).tolower();
if(checkfiletype(extension)) //如果有指定的文件类型
{
string contenttype=getcontenttype(extension);
string sqlstr=”insert into fileinout values(@filetype,@filecount)”; //上传文件的sql语句
string sqlstrclear=”truncate table fileinout”; //清空数据库sql语句
sqlconnection con=new sqlconnection(connstr); //实例化数据库连接对象
sqlcommand cmd=new sqlcommand(sqlstr,con); //实例化上传文件sql命令
sqlcommand cmdclear=new sqlcommand(sqlstrclear,con); //实例化清空数据库sql命令
//定义问价类型参数
cmd.parameters.add(new sqlparameter(“@filetype”,slqdbtype.nvarchar,30));
cmd.parameters[“@filetype”].value=contenttype; //定义文件内容参数
cmd.parameters.add(new sqlparameter(“@filecount”,sqldbtype.nvarchar,30)); //将文件转化为字节数组作为@filecount的值
cmd.parameters[“@filecount”].value=fileupload1.filebytes;
con.open();
cmdclear.executenonquery(); //执行清空数据库命令
cmd.executenonquery(); //执行上传文件命令
}
}
(3)添加获取文件类型和获得文件导出方式的函数方法。首先查看所要上传文件类型是否在指定问价类型内,如果在,则可以直接导入文件,然后根据文件类型
获取此文件导出方式并存放在filetype字段中,代码如下:
复制代码 代码如下:
public static bool checkfiletype(string type)
{
stringdictionary sd=new stringdictionary(); //实例化集合stringdictionary类
sd.add(“.doc”,”application/msword”);
sd.add(“.ppt”,”application/vnd.ms-powerpoint”);
sd.add(“.xsl”,”application/vnd.ms-excel”);
sd.add(“.rtf”,”application/msword”);
sd.add(“.html”,”text/html”);
sd.add(“.htm”,”text/html”);
sd.add(“.txt”,”text/plain”);
sd.add(“.pdf”,”application/pdf”);
return sd.containskey(type); //确定stringdictionary是否包含特定键
}
public static string getcontenttype(string extension) //获取输出文件方式
{stringdictionary sd=new stringdictionary();
sd.add(“.doc”,”application/msword”);
sd.add(“.ppt”,”application/vnd.ms-powerpoint”);
sd.add(“.xsl”,”application/vnd.ms-excel”);
sd.add(“.rtf”,”application/msword”);
sd.add(“.html”,”text/html”);
sd.add(“.htm”,”text/html”);
sd.add(“.txt”,”text/plain”);
sd.add(“.pdf”,”application/pdf”);
return sd[extension]; //返回对应键的值
}
(4)上传文件,选择一个pdf文件,单击”上传文件”按钮后,打开数据库中的fileinout表,如图所示可以看到。