问高手一个关于asp.net中session莫名其妙丢失的问题

zbdzjx 2016-07-28 01:54:08
最近一直在改一个asp.net的系统,今天刚发现一个非常奇怪的问题,进入系统,左边菜单中点了一项,右边出现相应的页面。
但其中有一个页面,左边点了菜单,右边出现此页面后,无论是点菜单中的其他项,或是在这个页面上点右键,选刷新,都会报session错误,经过跟踪,刷新了或是选了其他项,都显示session已经空了。
这个页面刚进入时,显示session中有4项,刷新后,就显示session已经空了。
查了这个页面的代码,没有清除session的语句。
搜了整个工程,就登录窗口有清除session的语句,注释掉了,再进入系统,进入那个页面,刷新后,还是报错。

在本机调试,或是放在服务器上,都是这样的问题。

不知有没有高手遇到过这样的问题,或是给点思路。
...全文
429 21 打赏 收藏 转发到动态 举报
写回复
用AI写文章
21 条回复
切换为时间正序
请发表友善的回复…
发表回复
Delta 2016-07-31
  • 打赏
  • 举报
回复
又学习了一下,很受用。
lshfong 2016-07-29
  • 打赏
  • 举报
回复
设置下生命周期看
insus 2016-07-29
  • 打赏
  • 举报
回复
Session丢失,程序动了Web.config,Bin,App_Code等目录的文件,均等于网站重启,Session初始化。
yzf86211861 2016-07-29
  • 打赏
  • 举报
回复
搞定就OK了,解决问题 才是关键的
zbdzjx 2016-07-29
  • 打赏
  • 举报
回复
引用 15 楼 starfd 的回复:
你不会把图片存到bin目录下了吧,然后session的provider默认用的Inproc,而不是StateServer
图片没放到bin目录下,是专门建了一个文件夹来存的。session的provider是用的Inproc,在网上搜了,说这个最不好,要用StateServer或sql server来存。
cy2889792 2016-07-29
  • 打赏
  • 举报
回复
那个取空地址图片会导致本地Cookie里面的AspNet_SessionId的Cookie里的SessionID发生变更,服务器读取的SessionID和之前的不一致,当然就取不到Sesion了。
  • 打赏
  • 举报
回复
你不会把图片存到bin目录下了吧,然后session的provider默认用的Inproc,而不是StateServer
  • 打赏
  • 举报
回复
举了例子,你可以自己测试一下,如果你的数据要创建和删除目录,但是你不按照 asp.net 的规范把它放到 app_data 目录下(的子目录),而是放到其外边,例如你去动态创建、删除一个叫做 MyImages 的目录,这时候你就会发现操作之后,Session集合、Application集合、静态变量值等等全都清空了,asp.net 进程重启了。 Session 丢失有无限种可能性。这是其中一种。
zbdzjx 2016-07-28
  • 打赏
  • 举报
回复
刚才试了一下,单独写了个很简单的程序,测试session和“<img src="../">”是否会有错误出现。 但是,没出现任何错误,一切正常。 看来,并非是简单的由“<img src="../">”导致的,我在改的那个程序,会对这些图片进行预览,不排除是由这部分代码导致的。 奇怪的是,图片已经上传到服务器上了,在本机调试时,图片显示不出来,但是,不会像“<img src="../">”那样导致session丢失。
zbdzjx 2016-07-28
  • 打赏
  • 举报
回复
引用 8 楼 starfd 的回复:
这时候再打开其它页面也报Session没了?
其他页面也报session没有了。 开始我试的时候,就是先点这个页面,再点其他页面,然后其他页面报session没了。再试的时候,就是点这个页面,再刷新 ,还是报session没了。
anythingBlank 2016-07-28
  • 打赏
  • 举报
回复
厉害,很早以前也出过这个问题,后来不了了之
Poopaye 2016-07-28
  • 打赏
  • 举报
回复
我说服务器上代码错误,本地代码出错怎么会影响session
  • 打赏
  • 举报
回复
你应该用fiddler(其实F12工具也可以)之类的抓下请求发送的数据,与正常页面对比,看一下发送请求的Cookie部分,不光看值,还要注意域和路径两列
  • 打赏
  • 举报
回复
这时候再打开其它页面也报Session没了?
zbdzjx 2016-07-28
  • 打赏
  • 举报
回复
引用 6 楼 starfd 的回复:
就是../退到上层导致错误?是这个img部分报错,不是页面报错?
但不知为什么会影响到session。 在每个页面load时,会判断Session["User"]存不存在,不存在,就提示重新登录 。 img部分报错,我在刷新页面时,就提示Session["User"]为null,session中的内容全部被清除了。
  • 打赏
  • 举报
回复
就是../退到上层导致错误?是这个img部分报错,不是页面报错?
zbdzjx 2016-07-28
  • 打赏
  • 举报
回复
引用 1 楼 shingoscar 的回复:
引用 2 楼 u014445111 的回复:
引用 4 楼 wylp_19 的回复:
终于搞定了,虽然还是没弄明白为什么。 原因是,昨天用户提出一个需求,不强制上传图片,于是我放开了限定。 今天有一条记录就没上传图片。 在显示页面时,就生了类似“<img src="../">”这样的内容,结果就出现这样的错误了。 我改了一下js语句,判断,没有上传图片,就不显示 img,现在就OK了。 害的我折腾了大半天,从IIS到专案的配置,从各种超时到语句中一点一点的return、break、注释。
wylp_19 2016-07-28
  • 打赏
  • 举报
回复
时间过期了吗?????
zbdzjx 2016-07-28
  • 打赏
  • 举报
回复
引用 2 楼 u014445111 的回复:
看看你点的这个页面是不是对那个session做了什么处理之类的,或者用SessionStateModule.End事件监听一下,看看log
引用 1 楼 shingoscar 的回复:
1、检查下浏览器设置,是不是把那个页面的cookie给禁用了 2、页面是否有严重错误 3、监听SessionStateModule.End事件,记下log,看啥时候结束的
1、我试了三个浏览器(IE8,chrome,FF),都是这样。 2、页面应该没什么错误吧。IE8中没提示,chrome中我看了,没错误。 3、这个我要试一下。 刚才我在页面的代码中一点点的试了。最终,在js文件中有“$("#tableList").append(trList).append(trListDetail);”这一句,就是将查询出来的结果,一条条的增加到table中去显示 。 如果将这句注释掉,页面不显示数据,但怎么操作都不报错了。 如果改成“$("#tableList").append(trList);”,还是报错。 如果改成“$("#tableList").append(trListDetail);”,就不报错了。 javascript语句会影响到session吗? 这段语句产生的数据量也不大,有其他页面,显示的内容比这个还多,也是正常的。代码有控制,一页只显示 10条记录。 还是说,trList中的内容会导致jquery等出现严重错误?
丿_雪菲 2016-07-28
  • 打赏
  • 举报
回复
看看你点的这个页面是不是对那个session做了什么处理之类的,或者用SessionStateModule.End事件监听一下,看看log
加载更多回复(1)
网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令做个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表添加 Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要添加的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次会话。如果在本次会话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表已有的条目。   bootcfg /disableredirect 在启动引导程序禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执行彻底检查。该参数不对驱动器做任何更改。 /r   找到坏扇区并恢复可读取的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)找到该文件,将试着在 Windows 安装 CD 找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建新的分区。   /delete   删除现有分区。   device_name   要创建或删除分区的设备。设备名称可从 map 命令的输出获得。例如,设备名称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除分区。仅与 /delete 同时使用。以下是驱动器名称的范例:   D:   partition_name   以分区名称表示的待删除分区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是分区名称的范例:   DeviceHardDisk0Partition1    大小   要创建的分区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除分区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上添加一个 20 MB 的分区:   diskpart /add Device HardDisk0 20   Fixboot

62,041

社区成员

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

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

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

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