You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

126 lines
3.9 KiB
C#

using System.IdentityModel.Tokens.Jwt;
using System.Net.Http.Headers;
using System.Security.Claims;
using System.Text;
using HttpClientStudy.Model;
using HttpClientStudy.WebApp.Models;
using Microsoft.AspNetCore.Authentication.Cookies;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.IdentityModel.Tokens;
namespace HttpClientStudy.WebApp.Controllers
{
/// <summary>
/// 账号控制器
/// </summary>
[Route("api/[controller]/[action]")]
[ApiController]
public class AccountController : ControllerBase
{
/// <summary>
/// 构造
/// </summary>
public AccountController() { }
/// <summary>
/// Ping 测试接口
/// </summary>
/// <example>
/// Ping
/// </example>
/// <returns></returns>
[HttpGet]
public IActionResult Ping()
{
return Ok("pong");
}
/// <summary>
/// 获取Token
/// </summary>
/// <returns></returns>
[AllowAnonymous]
[HttpGet]
public IActionResult GetToken(string userName, string password)
{
var account = new Account() { Id = 1, Name = userName, Password = password, Role = "Admin" };
var principal = CreateClaimsPrincipal(account);
var token = CreateJwtToken(principal.Claims.ToList());
var data = new { Id = account.Id, Account = account.Name, Role = account.Role, Token = token };
var result = BaseResultUtil.Success(data);
return new JsonResult(result);
}
/// <summary>
/// 获取Token
/// </summary>
/// <returns></returns>
[AllowAnonymous]
[HttpPost]
public IActionResult GetToken(LoginAccount vm)
{
var account = new Account() { Id = 1, Name = vm.Account, Password = vm.Password, Role = "Admin" };
var principal = CreateClaimsPrincipal(account);
var token = CreateJwtToken(principal.Claims.ToList());
var data = new { Id = account.Id, Account = account.Name, Role = account.Role, Token = token };
var result = BaseResultUtil.Success(data);
return new JsonResult(result);
}
/// <summary>
/// 生成ClaimsPrincipal
/// </summary>
private ClaimsPrincipal CreateClaimsPrincipal(Account account)
{
List<Claim> claims = new List<Claim>
{
new Claim("ID", account.Id.ToString()),
new Claim("Name",account.Name??""),
new Claim("Password", account.Password??"123123"),
new Claim("Role",account.Role),
};
ClaimsIdentity identity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);
ClaimsPrincipal principal = new ClaimsPrincipal(identity);
return principal;
}
/// <summary>
/// 生成JwtToken
/// </summary>
private string CreateJwtToken(List<Claim> claims)
{
//生成Jwt
//jwtTokenOptions 是通过配置获取上面配置的参数信息
var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("0123456789abcdefghigklmnopqrstdf41sadfweqtdfghsdfgsdfweqr"));
var credentials = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
//令牌
var expires = DateTime.Now.AddDays(1);
var token = new JwtSecurityToken
(
issuer: "WWW.WANGGAOFENG.CN",
audience: "WWW.WANGGAOFENG.CN",
claims: claims,
notBefore: DateTime.Now,
expires: expires,
signingCredentials: credentials
);
string jwtToken = new JwtSecurityTokenHandler().WriteToken(token);
return jwtToken;
}
}
}