服务器之家

服务器之家 > 正文

C#程序中session值的保存方法以及转为字符串的方法总结

时间:2021-11-17 14:30     来源/作者:huangzhe3976

C#中保存Session的三种方法及Web.Config设置

保存session到sql server;,需要指定Sql Server;服务器,这种方法因为要读写数据库最慢

?
1
2
3
4
5
<sessionState
mode="SQLServer"
sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
cookieless="false"
timeout="20" />

保存session到windows进程,要使用这种方法,需要打开aspnet_state.exe服务,通过此方法,我们可以将session保存到其它服务器, 这样可以实现多台服务器的session共享

?
1
2
3
4
5
<sessionState
mode="StateServer"
stateConnectionString="tcpip=127.0.0.1:42626"
cookieless="false"
timeout="20" />

默认情况,.net将session保存到当前进程中,这种方式最快,但是不能多台服务器共享session

?
1
2
3
4
5
<sessionState
mode=”InProc”
cookieless=”false”
timeout=”20”
/>

将Session 的值转为 String
在实际操作当中,我们经常会遇到将 Session 的值转为 String 去判断是否为空或者判断是否有权限访问某页,这里的转换过程如果用得不恰当会抛出异常,给访问者带来不好的用户体验。这里我把它写成笔记,以供参考。

1.当 Session["a"] == null 时,

Session["a"].ToString() 抛出异常;

(string)Session["a"] 为 null;

Convert.ToString(Session["a"]) 为 ""。

2.当 Session["a"] == "" 时,

它们的值都为 ""。

所以,在判断 Session["a"] 是否有值时,如果用“.ToString()”,那么必需按照下面的格式与顺序写:

?
1
if (Session["a"] != null && Session["a"].ToString() != "")

在这里,要注意判断的顺序:先判断是否为 null,再判断是否为 empty。如果 Session["a"] 为 null,则 Session["a"] != null 为 false 自然不会执行 .ToString(),也就不会报错;如果 Session["a"] 不为 null,则执行 .ToString() 也不会报错。

同理 if (Session["a"] == null || Session["a"].ToString() == "") 此句也合法可用。

用 .ToString() 的方法写格式比较固定,如果换成用 (string) 写,会比较自由:

?
1
2
3
if ((string)Session["a"] != null && (string)Session["a"] != "")
 
if (Session["a"] != null && (string)Session["a"] != "")

这两种写法都是可行的,而且对 null 和 empty 的判断顺序没有关系。

最简单的方法就是用 Convert.ToString

?
1
if (Convert.ToString(Session["aaa"]) == "")

不管 Session["a"] 为 null 还是 empty,Convert.ToString(Session["aaa"]) 都是 empty。

标签:

相关文章

热门资讯

yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
2021年耽改剧名单 2021要播出的59部耽改剧列表
2021年耽改剧名单 2021要播出的59部耽改剧列表 2021-03-05
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部