文件上传到数据库,出现 范围超过int 的错误

gy348 2006-02-23 07:04:15
出现 范围超过int 的错误
代码如下:
可能是file 大到一定时候 len=f.Length 超过了 int  
  于是我把int len改成  long ...
   网也就转到  无法显示网页 的页面了
FileInfo f=new FileInfo(address);
fileStream=f.OpenRead();
int len=f.Length
byte[] wordData=new byte[len]; //
int n=fileStream.Read(wordData,0,len); //这个len 超过int 。。。。。

string strSql="" ;
if(LbId.Text.Trim().Substring(0,1)=="1")
{
strSql="insert into ModifyRecord(id, studentid,submitdate,studentProj) values('"+LbId.Text+"','"+LbstudentID.Text+"','"+System.DateTime.Now.ToString()+"','+wordData+')";
}
else
{
strSql="insert into designRecord(id, studentid,submitdate,studentProj) values('"+LbId.Text+"','"+LbstudentID.Text+"','"+System.DateTime.Now.ToString()+"','+wordData+')";
}
SqlCommand cmd=new SqlCommand(strSql,cnn);
cnn.Open();
cmd.ExecuteScalar();
cnn.Close();
fileStream.Close();
...全文
145 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
antiking 2006-03-07
  • 打赏
  • 举报
回复
楼上的楼上眼尖哦...sql有问题的.
robert2004 2006-03-07
  • 打赏
  • 举报
回复
楼上眼睛尖。。。


---------------------------
苦海无边 回头无岸
---------------------------

gsk99 2006-03-07
  • 打赏
  • 举报
回复
老大,你这句Sql语句对吗?
strSql="insert into designRecord(id, studentid,submitdate,studentProj) values('"+LbId.Text+"','"+LbstudentID.Text+"','"+System.DateTime.Now.ToString()+"','+wordData+')";
wordData这个内容传到数据库了吗,没有吧!!!!!!!
gy348 2006-02-23
  • 打赏
  • 举报
回复
int n=fileStream.Read(wordData,0,len); //这个len 超过int 。。。。。
文件不是特别大
<configuration>
<system.web>
<httpRuntime maxRequestLength="1048576" executionTimeout="3600" />
</system.web>
</configuration>
这些我都改过了
孟子E章 2006-02-23
  • 打赏
  • 举报
回复
如果文件过大,会出现网页无法显示的的问题
上载大文件时,可使用 元素的 maxRequestLength 属性来增加文件大小的最大允许值,例如:

<configuration>
<system.web>
<httpRuntime maxRequestLength="1048576" executionTimeout="3600" />
</system.web>
</configuration>

其中:maxRequestLength:指示 ASP.NET 支持的HTTP方式上载的最大字节数。该限制可用于防止因用户将大量文件传递到该服务器而导致的拒绝服务攻击。指定的大小以 KB 为单位。默认值为 4096 KB (4 MB)。executionTimeout:指示在被 ASP.NET 自动关闭前,允许执行请求的最大秒数。在当文件超出指定的大小时,如果浏览器中会产生 DNS 错误或者出现服务不可得到的情况,也请修改以上的配置,把配置数加大。

另外,上载大文件时,还可能会收到以下错误信息:

aspnet_wp.exe (PID: 1520) 被回收,因为内存消耗超过了 460 MB(可用 RAM 的百分之 60)。
或者无法找到网页
如果遇到此错误信息,请增加应用程序的 Web.config 文件的 元素中 memoryLimit 属性的值。例如:

<configuration>
<system.web>
<processModel memoryLimit="80"/>
</system.web>
</configuration>

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧