MVC Shared Layout Parameter to Logoff
I use a shared layout and I am trying to pass the current location to the logoff method, but I'm not sure how to do it. I've tried: Request.Url.OriginalString, Request.Url.Scheme and in the logoff method the parameter type I put the parameter type as string but it isn't working. Anyone have any idea?
Log Off Button on my layout page
<a onclick="location.href = '@Url.Action("Logoff", "Account", "Request.Url.Scheme")'"><span class="logOffSpan">Sign Out</span
public ActionResult LogOff(string url)
{
var local = Convert.ToBoolean(ConfigurationManager.AppSettings["local"]);
if (local)
{
FormsAuthentication.SignOut();
}
else
{
CasAuthentication.SingleSignOut();
}
Session.Clear();
return to Redirect("Some Method","Some Controller");//I want the user to just return to whatever page they were just on when they clicked log off
}
asp.net-mvc
add a comment |
I use a shared layout and I am trying to pass the current location to the logoff method, but I'm not sure how to do it. I've tried: Request.Url.OriginalString, Request.Url.Scheme and in the logoff method the parameter type I put the parameter type as string but it isn't working. Anyone have any idea?
Log Off Button on my layout page
<a onclick="location.href = '@Url.Action("Logoff", "Account", "Request.Url.Scheme")'"><span class="logOffSpan">Sign Out</span
public ActionResult LogOff(string url)
{
var local = Convert.ToBoolean(ConfigurationManager.AppSettings["local"]);
if (local)
{
FormsAuthentication.SignOut();
}
else
{
CasAuthentication.SingleSignOut();
}
Session.Clear();
return to Redirect("Some Method","Some Controller");//I want the user to just return to whatever page they were just on when they clicked log off
}
asp.net-mvc
1
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
1
I updated my original post
– crmckain
Nov 21 '18 at 18:50
add a comment |
I use a shared layout and I am trying to pass the current location to the logoff method, but I'm not sure how to do it. I've tried: Request.Url.OriginalString, Request.Url.Scheme and in the logoff method the parameter type I put the parameter type as string but it isn't working. Anyone have any idea?
Log Off Button on my layout page
<a onclick="location.href = '@Url.Action("Logoff", "Account", "Request.Url.Scheme")'"><span class="logOffSpan">Sign Out</span
public ActionResult LogOff(string url)
{
var local = Convert.ToBoolean(ConfigurationManager.AppSettings["local"]);
if (local)
{
FormsAuthentication.SignOut();
}
else
{
CasAuthentication.SingleSignOut();
}
Session.Clear();
return to Redirect("Some Method","Some Controller");//I want the user to just return to whatever page they were just on when they clicked log off
}
asp.net-mvc
I use a shared layout and I am trying to pass the current location to the logoff method, but I'm not sure how to do it. I've tried: Request.Url.OriginalString, Request.Url.Scheme and in the logoff method the parameter type I put the parameter type as string but it isn't working. Anyone have any idea?
Log Off Button on my layout page
<a onclick="location.href = '@Url.Action("Logoff", "Account", "Request.Url.Scheme")'"><span class="logOffSpan">Sign Out</span
public ActionResult LogOff(string url)
{
var local = Convert.ToBoolean(ConfigurationManager.AppSettings["local"]);
if (local)
{
FormsAuthentication.SignOut();
}
else
{
CasAuthentication.SingleSignOut();
}
Session.Clear();
return to Redirect("Some Method","Some Controller");//I want the user to just return to whatever page they were just on when they clicked log off
}
asp.net-mvc
asp.net-mvc
edited Nov 21 '18 at 18:50
crmckain
asked Nov 21 '18 at 17:58
crmckaincrmckain
816
816
1
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
1
I updated my original post
– crmckain
Nov 21 '18 at 18:50
add a comment |
1
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
1
I updated my original post
– crmckain
Nov 21 '18 at 18:50
1
1
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
1
1
I updated my original post
– crmckain
Nov 21 '18 at 18:50
I updated my original post
– crmckain
Nov 21 '18 at 18:50
add a comment |
1 Answer
1
active
oldest
votes
You can use Request.Url.AbsoluteUri
to get the absolute URL of the current page.
Then you can use this overload of @Url.Action
method which takes a RouteValueDictionary
object as third parameter to build the route params / querystrings.
public virtual string Action (string actionName,
string controllerName,
RouteValueDictionary routeValues);
So your view code will be
<a href="@Url.Action("Logoff", "Account", new { url = Request.Url.AbsoluteUri })">
<span class="logOffSpan">Sign Out</span>
</a>
This will basically generate the anhcor tag with the href
attribute value set to /Account/Logogg?url={yourCurrentPageUrl}
, where {yourCurrentPageUrl}
will be replaced with your current page URL.
Now in your action method you can use the Redirect
method with this aboslute URL value which will be available in your url
parameter.
public ActionResult LogOff(string url)
{
// Your existing logic
return Redirect(url);
}
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53418021%2fmvc-shared-layout-parameter-to-logoff%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
You can use Request.Url.AbsoluteUri
to get the absolute URL of the current page.
Then you can use this overload of @Url.Action
method which takes a RouteValueDictionary
object as third parameter to build the route params / querystrings.
public virtual string Action (string actionName,
string controllerName,
RouteValueDictionary routeValues);
So your view code will be
<a href="@Url.Action("Logoff", "Account", new { url = Request.Url.AbsoluteUri })">
<span class="logOffSpan">Sign Out</span>
</a>
This will basically generate the anhcor tag with the href
attribute value set to /Account/Logogg?url={yourCurrentPageUrl}
, where {yourCurrentPageUrl}
will be replaced with your current page URL.
Now in your action method you can use the Redirect
method with this aboslute URL value which will be available in your url
parameter.
public ActionResult LogOff(string url)
{
// Your existing logic
return Redirect(url);
}
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
add a comment |
You can use Request.Url.AbsoluteUri
to get the absolute URL of the current page.
Then you can use this overload of @Url.Action
method which takes a RouteValueDictionary
object as third parameter to build the route params / querystrings.
public virtual string Action (string actionName,
string controllerName,
RouteValueDictionary routeValues);
So your view code will be
<a href="@Url.Action("Logoff", "Account", new { url = Request.Url.AbsoluteUri })">
<span class="logOffSpan">Sign Out</span>
</a>
This will basically generate the anhcor tag with the href
attribute value set to /Account/Logogg?url={yourCurrentPageUrl}
, where {yourCurrentPageUrl}
will be replaced with your current page URL.
Now in your action method you can use the Redirect
method with this aboslute URL value which will be available in your url
parameter.
public ActionResult LogOff(string url)
{
// Your existing logic
return Redirect(url);
}
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
add a comment |
You can use Request.Url.AbsoluteUri
to get the absolute URL of the current page.
Then you can use this overload of @Url.Action
method which takes a RouteValueDictionary
object as third parameter to build the route params / querystrings.
public virtual string Action (string actionName,
string controllerName,
RouteValueDictionary routeValues);
So your view code will be
<a href="@Url.Action("Logoff", "Account", new { url = Request.Url.AbsoluteUri })">
<span class="logOffSpan">Sign Out</span>
</a>
This will basically generate the anhcor tag with the href
attribute value set to /Account/Logogg?url={yourCurrentPageUrl}
, where {yourCurrentPageUrl}
will be replaced with your current page URL.
Now in your action method you can use the Redirect
method with this aboslute URL value which will be available in your url
parameter.
public ActionResult LogOff(string url)
{
// Your existing logic
return Redirect(url);
}
You can use Request.Url.AbsoluteUri
to get the absolute URL of the current page.
Then you can use this overload of @Url.Action
method which takes a RouteValueDictionary
object as third parameter to build the route params / querystrings.
public virtual string Action (string actionName,
string controllerName,
RouteValueDictionary routeValues);
So your view code will be
<a href="@Url.Action("Logoff", "Account", new { url = Request.Url.AbsoluteUri })">
<span class="logOffSpan">Sign Out</span>
</a>
This will basically generate the anhcor tag with the href
attribute value set to /Account/Logogg?url={yourCurrentPageUrl}
, where {yourCurrentPageUrl}
will be replaced with your current page URL.
Now in your action method you can use the Redirect
method with this aboslute URL value which will be available in your url
parameter.
public ActionResult LogOff(string url)
{
// Your existing logic
return Redirect(url);
}
edited Nov 21 '18 at 19:03
answered Nov 21 '18 at 18:58
ShyjuShyju
146k87331439
146k87331439
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
add a comment |
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
1
1
Thank you so much
– crmckain
Nov 21 '18 at 19:45
Thank you so much
– crmckain
Nov 21 '18 at 19:45
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53418021%2fmvc-shared-layout-parameter-to-logoff%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
1
Share the relevant code and your expected behavior
– Shyju
Nov 21 '18 at 17:59
1
I updated my original post
– crmckain
Nov 21 '18 at 18:50