c#.net 6.0我可以离开饼干
我正在通过React登录过程发送用户名和密码。如果用户名和密码正确,我希望用户的浏览器将令牌设置为cookie。但这不会抛出。
[HttpPost("[action]")]
public async Task<ActionResult<Token>> Login( UserLogin userLogin)
{
User user = await context.Users.Include(u => u.UserRoles).ThenInclude(ur => ur.Role).FirstOrDefaultAsync(x=>x.Email == userLogin.Email && x.Password == userLogin.Password);
if(user != null)
{
TokenHandler tokenHandler = new TokenHandler(configuration);
Token token = tokenHandler.CreateAccessToken(user);
user.RefreshToken = token.RefreshToken;
user.RefrestTokenEndDate = token.Expiration.AddMinutes(3);
await context.SaveChangesAsync();
var cookieOptions = new CookieOptions
{
HttpOnly = true,
Expires = DateTime.UtcNow.AddHours(8),
Path = "/login"
};
Response.Cookies.Append("RefreshToken", token.RefreshToken, cookieOptions);
Response.Cookies.Append("AccessToken", token.AccessToken, cookieOptions);
return Ok(token);
}
return null;
}
登录地址:http:// localhost:3000/login
令牌和验证过程没有任何问题。饼干部分有问题...
I am sending username and password by react for login process. If the username and password are correct, I want the user's browser to set the token as a cookie. but it doesn't throw.
[HttpPost("[action]")]
public async Task<ActionResult<Token>> Login( UserLogin userLogin)
{
User user = await context.Users.Include(u => u.UserRoles).ThenInclude(ur => ur.Role).FirstOrDefaultAsync(x=>x.Email == userLogin.Email && x.Password == userLogin.Password);
if(user != null)
{
TokenHandler tokenHandler = new TokenHandler(configuration);
Token token = tokenHandler.CreateAccessToken(user);
user.RefreshToken = token.RefreshToken;
user.RefrestTokenEndDate = token.Expiration.AddMinutes(3);
await context.SaveChangesAsync();
var cookieOptions = new CookieOptions
{
HttpOnly = true,
Expires = DateTime.UtcNow.AddHours(8),
Path = "/login"
};
Response.Cookies.Append("RefreshToken", token.RefreshToken, cookieOptions);
Response.Cookies.Append("AccessToken", token.AccessToken, cookieOptions);
return Ok(token);
}
return null;
}
login adress: http://localhost:3000/login
The token and verification process works without any issues. There is a problem with the cookie part...
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
恐怕您使用React创建一个前端应用程序和.NET 6来创建服务器后端,因此端口彼此不同。因此,您可以在.NET 6应用程序中设置CORS策略。
这是我的一些假设。首先,您可以尝试此cookieoption并进行测试,了解 samesitemode :
我在我的身边进行了测试,并使用了这样的ajax请求
,我的cors策略:
I'm afraid you used React to create a frontend app and .net 6 to create the server backend, so the port are different with each other. So you may set Cors policy in your .net 6 application.
Here's some of my assumption. Firstly, you may try this cookieOption and have a test, learn about SameSiteMode:
I did a test in my side with an ajax request like this
And my cors policy: