Session value not preserved or not working in dotnetcore webapi
Below is my code from startup.cs,
public void ConfigureServices(IServiceCollection services){
services.AddMvc().AddJsonOptions(options =>{
options.SerializerSettings.ContractResolver = new DefaultContractResolver();
});
services.AddDistributedMemoryCache();
services.AddSession(options => {
// Set a short timeout for easy testing.
options.IdleTimeout = TimeSpan.FromSeconds(36000);
options.Cookie.HttpOnly = true;
});
services.AddCors(options => {
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env{
if (env.IsDevelopment()){
app.UseDeveloperExceptionPage();
}
app.UseStaticFiles();
//app.UseCors("CorsPolicy");
// global cors policy
app.UseCors(x => x
.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
app.UseSession();
app.UseAuthentication();
app.UseMvc();
}
Below is the code to set and get userid in session:
HttpContext.Session.SetInt32("UserId", user.Id);
int userId = (int)HttpContext.Session.GetInt32("UserId");
I am getting below exception while reading session in a different action from the action where it is set. Any reason why session is not working?
c# session asp.net-web-api .net-core
add a comment |
Below is my code from startup.cs,
public void ConfigureServices(IServiceCollection services){
services.AddMvc().AddJsonOptions(options =>{
options.SerializerSettings.ContractResolver = new DefaultContractResolver();
});
services.AddDistributedMemoryCache();
services.AddSession(options => {
// Set a short timeout for easy testing.
options.IdleTimeout = TimeSpan.FromSeconds(36000);
options.Cookie.HttpOnly = true;
});
services.AddCors(options => {
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env{
if (env.IsDevelopment()){
app.UseDeveloperExceptionPage();
}
app.UseStaticFiles();
//app.UseCors("CorsPolicy");
// global cors policy
app.UseCors(x => x
.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
app.UseSession();
app.UseAuthentication();
app.UseMvc();
}
Below is the code to set and get userid in session:
HttpContext.Session.SetInt32("UserId", user.Id);
int userId = (int)HttpContext.Session.GetInt32("UserId");
I am getting below exception while reading session in a different action from the action where it is set. Any reason why session is not working?
c# session asp.net-web-api .net-core
What exception do you get?
– Nick
Nov 14 '18 at 18:36
If I get you right. You are settingHttpContext.Session.SetInt32("UserId", user.Id);inmethod A, and thenmethod Ais calling themethod Bwhere you try to useHttpContext.Session.SetInt32("UserId", user.Id);?
– Sebastian 506563
Nov 14 '18 at 22:04
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44
add a comment |
Below is my code from startup.cs,
public void ConfigureServices(IServiceCollection services){
services.AddMvc().AddJsonOptions(options =>{
options.SerializerSettings.ContractResolver = new DefaultContractResolver();
});
services.AddDistributedMemoryCache();
services.AddSession(options => {
// Set a short timeout for easy testing.
options.IdleTimeout = TimeSpan.FromSeconds(36000);
options.Cookie.HttpOnly = true;
});
services.AddCors(options => {
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env{
if (env.IsDevelopment()){
app.UseDeveloperExceptionPage();
}
app.UseStaticFiles();
//app.UseCors("CorsPolicy");
// global cors policy
app.UseCors(x => x
.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
app.UseSession();
app.UseAuthentication();
app.UseMvc();
}
Below is the code to set and get userid in session:
HttpContext.Session.SetInt32("UserId", user.Id);
int userId = (int)HttpContext.Session.GetInt32("UserId");
I am getting below exception while reading session in a different action from the action where it is set. Any reason why session is not working?
c# session asp.net-web-api .net-core
Below is my code from startup.cs,
public void ConfigureServices(IServiceCollection services){
services.AddMvc().AddJsonOptions(options =>{
options.SerializerSettings.ContractResolver = new DefaultContractResolver();
});
services.AddDistributedMemoryCache();
services.AddSession(options => {
// Set a short timeout for easy testing.
options.IdleTimeout = TimeSpan.FromSeconds(36000);
options.Cookie.HttpOnly = true;
});
services.AddCors(options => {
options.AddPolicy("CorsPolicy",
builder => builder.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
});
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env{
if (env.IsDevelopment()){
app.UseDeveloperExceptionPage();
}
app.UseStaticFiles();
//app.UseCors("CorsPolicy");
// global cors policy
app.UseCors(x => x
.AllowAnyOrigin()
.AllowAnyMethod()
.AllowAnyHeader()
.AllowCredentials());
app.UseSession();
app.UseAuthentication();
app.UseMvc();
}
Below is the code to set and get userid in session:
HttpContext.Session.SetInt32("UserId", user.Id);
int userId = (int)HttpContext.Session.GetInt32("UserId");
I am getting below exception while reading session in a different action from the action where it is set. Any reason why session is not working?
c# session asp.net-web-api .net-core
c# session asp.net-web-api .net-core
edited Nov 14 '18 at 21:24
kit
1,1063816
1,1063816
asked Nov 14 '18 at 17:57
MaheshMahesh
87214
87214
What exception do you get?
– Nick
Nov 14 '18 at 18:36
If I get you right. You are settingHttpContext.Session.SetInt32("UserId", user.Id);inmethod A, and thenmethod Ais calling themethod Bwhere you try to useHttpContext.Session.SetInt32("UserId", user.Id);?
– Sebastian 506563
Nov 14 '18 at 22:04
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44
add a comment |
What exception do you get?
– Nick
Nov 14 '18 at 18:36
If I get you right. You are settingHttpContext.Session.SetInt32("UserId", user.Id);inmethod A, and thenmethod Ais calling themethod Bwhere you try to useHttpContext.Session.SetInt32("UserId", user.Id);?
– Sebastian 506563
Nov 14 '18 at 22:04
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44
What exception do you get?
– Nick
Nov 14 '18 at 18:36
What exception do you get?
– Nick
Nov 14 '18 at 18:36
If I get you right. You are setting
HttpContext.Session.SetInt32("UserId", user.Id); in method A, and then method A is calling the method B where you try to use HttpContext.Session.SetInt32("UserId", user.Id); ?– Sebastian 506563
Nov 14 '18 at 22:04
If I get you right. You are setting
HttpContext.Session.SetInt32("UserId", user.Id); in method A, and then method A is calling the method B where you try to use HttpContext.Session.SetInt32("UserId", user.Id); ?– Sebastian 506563
Nov 14 '18 at 22:04
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44
add a comment |
1 Answer
1
active
oldest
votes
This solution works only for dotnetcore 2.1 or above. My solution was dotnetcore 2.0
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%2f53306204%2fsession-value-not-preserved-or-not-working-in-dotnetcore-webapi%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
This solution works only for dotnetcore 2.1 or above. My solution was dotnetcore 2.0
add a comment |
This solution works only for dotnetcore 2.1 or above. My solution was dotnetcore 2.0
add a comment |
This solution works only for dotnetcore 2.1 or above. My solution was dotnetcore 2.0
This solution works only for dotnetcore 2.1 or above. My solution was dotnetcore 2.0
answered Nov 16 '18 at 4:14
MaheshMahesh
87214
87214
add a comment |
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%2f53306204%2fsession-value-not-preserved-or-not-working-in-dotnetcore-webapi%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
What exception do you get?
– Nick
Nov 14 '18 at 18:36
If I get you right. You are setting
HttpContext.Session.SetInt32("UserId", user.Id);inmethod A, and thenmethod Ais calling themethod Bwhere you try to useHttpContext.Session.SetInt32("UserId", user.Id);?– Sebastian 506563
Nov 14 '18 at 22:04
nullable object must have a value.
– Mahesh
Nov 15 '18 at 4:34
No Sebastian. If it is the same action then I don't need session itself right. Session we need for maintaining state between different HTTP requests. I am Setting session in the different controller action and getting it in a different controller action.
– Mahesh
Nov 15 '18 at 4:44