我在Application.cfc的onRequestStart
方法中编写了以下代码。因此,只要在创建会话值之前发出请求,它就会始终重定向到login_action.cfm
。
<cfif not IsDefined("session.active")>
<cfinclude template="login_action.cfm">
</cfif>
login_action.cfm
是用于在没有正确身份验证的情况下阻止访问其他页面的代码:
<cfif NOT (IsDefined ("Form.username") AND IsDefined ("Form.password"))>
<cfinclude template="login.cfm">
<cfabort>
<cfelse>
现在我创建了一个注册页面。此页面不需要身份验证。每个人都应该只需点击一下即可访问该页面,但现在无法登录。我可以通过某种方式检查targtedPage
方法的onRequestStart
参数来改变这种情况吗?
有人能帮助我吗?
答案 0 :(得分:6)
<强>问题:强>
我可以通过onRequestStart方法的targtedPage(sic)参数来检查吗?
<强>答案强>
是
使用您现有的代码结构并假设您调用注册页面signup_page.cfm
,您可以执行以下操作。
<cffunction
name="OnRequestStart"
access="public"
returntype="boolean"
output="false"
hint="Fires at first part of page processing.">
<!--- Define arguments. --->
<cfargument
name="TargetPage"
type="string"
required="true" />
<cfif FindNoCase( "signup_page.cfm", arguments.TargetPage)>
<!--- User is at the signup page, no need to check for an active session. Do stuff if necessary here. --->
<cfelse>
<cfif not IsDefined("session.active")>
<!--- User's session is inactive, redirect --->
<cfinclude template="login_action.cfm">
<cfreturn false /> <!--- You should add this return in your existing code. --->
</cfif>
<!--- User is logged in with an active session, do other stuff. --->
</cfif>
<!--- Return out. --->
<cfreturn true />
</cffunction>