温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

ASP.NET中Session如何使用

发布时间:2021-07-15 15:33:02 来源:亿速云 阅读:132 作者:Leah 栏目:编程语言

ASP.NET中Session如何使用,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

Session 的管理,我们传统的asp 程序其实是一种 dead 的Session 联结,系统其实在我们的客户端书写了一个Cookie,当我们把我们浏览器的 安全设置中的 Cookie 设置成 Prompt 的时候,当我们访问一个有Session 的页面的时候,就会出现一个是否允许Cookie 的提示,当设置成为 不允许 Cookie 的时候,我们的Session 总是不能成功.例如:

﹤%  Session("username")="豆腐" Session("URL")="http://www.asp888.net" %﹥

在ASP.NET 的环境中,ASP.NET Session使用的情况是被完全的重新进行了定义,由于豆腐现在的ASP.NET 的环境是PDC 版本的,所以,没有对Beta1 版本进行Demo,我在这里如果涉及到 Beta1 的内容,都是仅仅是材料上介绍的,没有经过豆腐的测试

其实,对于一些不愿意深究的同志们,豆腐 说:其实 ASP.NET Session使用方法和ASP Session使用的使用方法完全相同,甚至更为简单,因为 根据豆腐 的观察,我们根本不用继续 去考虑 客户端 的cookie 选项 的状态,因为不管客户端的设置如何,Session都可以顺利的传递

下面我们就对ASP.NET Session使用机制进行一些简单的深入了解,限于技术,我有的问题也不是很清楚,所以欢迎大家一同来探讨 这个 文章

在PDC 版本中,我们打开 %systemroot%\complus\(version)\config.web 文件,我们找到 Sessionstate可以看到以前的内容:

﹤Sessionstate  inproc="true" usesqlserver="false" cookieless="false" timeout="20" server="localhost" port="42424" /﹥

当 inproc 为True 的时候,ASP.NET 将采取一种称为 in-process 的机制,将Session 的数据保存在这一台服务器上,如果inproc 和usesqlserver 同时为 false ,则采取一种 out process 的机制,将Session 存储在 一台 专门用来保存Session 的服务器上,这样就可以解决当访问 一个站点的 不同主机的时候,Session 的共享,这个以前在ASP中绝对是不可能的.在 Beta1 的版本上 config.web 改变了很多,我们简单的看一下:

﹤!-- Sessionstate attributes:  mode = "inproc" | "sqlserver" | "stateserver" cookieless = "true" | "false" timeout = ﹤Session timeout in minutes, a whole number greater than 0﹥  sqlconnectionstring = ﹤acceptable values for SQLConnection.ConnectionString,  only used when mode="sqlserver"﹥  server = ﹤server name, only used when mode="stateserver"﹥  port = ﹤port number, only used when mode="stateserver"﹥  --﹥

关于 config.web 文件的Session 部分我们就先说到这里,下面我们来看看 cookieless 的问题:

这个Cookieless 不是我们平常理解的是否在 客户端 保存Cookie 根据豆腐的观察,ASP.NET的Session

是不会在 浏览器客户端生成任何的cookie的

我们首先把 cookieless 设置成为 false 的时候,我们来看看这个程序

﹤%@ Page Language="VB" %﹥  ﹤%Session("name")="豆腐"%﹥  ﹤%=Session("name")%﹥

程序执行结束后,我们没有从浏览器得到任何的 提示,虽然我们也使用到了Session当我们 把 cookieless 设置成为 true 以后,再次运行这个程序,我们发现 程序仍然是正确的执行,但是浏览器的地址栏发生了一些变化,我们以前是

http://host/testSession.aspx 现在变成了 http://host/(包含有很多字符串的内容)/testSession.aspx豆腐估计这是 因为 这个Session 甚至在 服务器上也没有 生成Cookie 的原因,只好用 (包含有很多字符串的内容)的内容来保存Session的内容了

当我们将inproc 和 usesqlserver 都设置成为 false 表示我们将使用 out process 这个时候,我们就要指定server 的name 这个server 就是同意保存 Session 的 服务器,我们需要在这个服务器上将asp state 的服务启动

当我们需要使用 sql server 的时候,我们必须填写 sql server的连接字符串,这样 Session 就会被保存到sql server 的一个database ,当然这个database 是要生成的,,不过在PDC版本中,我没有找到这个database 的安装文件。

关于ASP.NET中Session如何使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI