当用户请求页面时,是否为该用户启动会话?据我所知,一旦你发出页面请求,会话就开始了......
如果是这种情况,您何时创建会话变量?即用户名,密码,偏好等......只是随时?
答案 0 :(得分:5)
配置和使用会话变量的基础是explained here。
会话基本上是客户端和应用程序之间的逻辑关系,因此会话变量可以从客户端对应用程序的第一个请求中获得,并且会话通常在使用唯一标识会话的cookie的请求之间保留,尽管这可以也可以通过在URL中传递标识符来完成。值得注意您的会话超时设置,例如,您可能希望为未设置cookie的机器人/爬虫提供更短的超时,从而为每个页面请求(more details on this)启动新会话。 / p>
答案 1 :(得分:4)
是的,用户的会话范围是在第一个请求上设置的。但是,这取决于您希望何时设置各种标志和值的偏好。您可能不希望在会话范围中输入密码。
我喜欢做的是将用户特定的值放在用户结构中。所以在请求开始时我会检查变量并设置它是否不存在。例如......
<cfif not structkeyexists(session, "user")>
<cfset session.user = {
authorized = false
, admin = false
, username = ''
, accountid = ''
<!--- etc --->
} />
</cfif>
当用户登录时,您可以填写相应的值并设置session.user.authorized = true
当用户注销关于此方法的好处时,您可以删除用户结构。
<cfset structdelete(session, "user") />
然后在下一页上,将再次检查用户结构,如果它不存在则创建。