ASP.NET Core 个人博客项目搭建笔记

举报
Echo_Wish 发表于 2022/08/17 09:16:17 2022/08/17
【摘要】 简易个人博客项目搭建笔记 1.概述 项目梗概通过做一个比较简单,通俗易懂的个人博客项目,很简单的增删改查,来更好学习asp.net core,这个项目使用asp.net core webapi+elementui来做。 2.数据库设计文章表ID文章标题文章内容创建时间文章类型ID浏览量点赞量作者ID文章类型表ID类型名作者表ID姓名账号密码 MD5 3.架构设计仓储层服务层 MD5加密pu...

简易个人博客项目搭建笔记

1.概述

项目梗概

通过做一个比较简单,通俗易懂的个人博客项目,很简单的增删改查,来更好学习asp.net core,这个项目使用asp.net core webapi+elementui来做。

2.数据库设计

文章表

ID
文章标题
文章内容
创建时间
文章类型ID
浏览量
点赞量
作者ID

文章类型表

ID
类型名

作者表

ID
姓名
账号
密码 MD5

3.架构设计

仓储层

服务层

MD5加密

public static string MD5Encrypt32(string password)
{
    string pwd = "";
    MD5 md5 = MD5.Create(); //实例化一个md5对像
    byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(password));
    for (int i = 0; i < s.Length; i++)
    {
        pwd = pwd + s[i].ToString("X");
    }
    return pwd;
}

JWT使用

JWT授权

1.添加一个webapi项目

2.安装Nuget程序包 System.IdentityModel.Tokens.Jwt

var claims = new Claim[]
            {
                new Claim(ClaimTypes.Name, "张三")
            };
var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("SDMC-CJAS1-SAD-DFSFA-SADHJVF-VF"));
//issuer代表颁发Token的Web应用程序,audience是Token的受理者
var token = new JwtSecurityToken(
    issuer: "http://localhost:6060",
    audience: "http://localhost:5000",
    claims: claims,
    notBefore: DateTime.Now,
    expires: DateTime.Now.AddHours(1),
    signingCredentials: new SigningCredentials(key, SecurityAlgorithms.HmacSha256)
);
var jwtToken = new JwtSecurityTokenHandler().WriteToken(token);
return jwtToken;

JWT鉴权

安装Microsoft.AspNetCore.Authentication.JwtBearer

services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
            .AddJwtBearer(options =>
            {
              options.TokenValidationParameters = new TokenValidationParameters
              {
                ValidateIssuerSigningKey = true,
                IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("SDMC-CJAS1-SAD-DFSFA-SADHJVF-VF")),
                ValidateIssuer = true,
                ValidIssuer = "http://localhost:6060",
                ValidateAudience = true,
                ValidAudience = "http://localhost:5000",
                ValidateLifetime = true,
                ClockSkew = TimeSpan.FromMinutes(60)
              };
            });

JWT授权鉴权使用

Swagger想要使用鉴权需要注册服务的时候添加以下代码

c.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme
        {
          In=ParameterLocation.Header,
          Type=SecuritySchemeType.ApiKey,
          Description= "直接在下框中输入Bearer {token}(注意两者之间是一个空格)",
          Name="Authorization",
          BearerFormat="JWT",
          Scheme="Bearer"
        });
        c.AddSecurityRequirement(new OpenApiSecurityRequirement
        {
          {
            new OpenApiSecurityScheme
            {
              Reference=new OpenApiReference
              {
                Type=ReferenceType.SecurityScheme,
                Id="Bearer"
              }
            },
            new string[] {}
          }
        });

AutoMapper

安装Nuget AutoMapper.Extensions.Microsoft.DependencyInjection

定义一个类,继承Profile

public class CustomAutoMapperProfile:Profile
  {
    public CustomAutoMapperProfile()
    {
      base.CreateMap<StudentEntity, StudentDto>();
    }
  }

在服务中注册

services.AddAutoMapper(typeof(CustomAutoMapperProfile));

构造函数注入

private readonly IMapper _mapper;

    public StudentsController(IMapper mapper)
    {
      this._mapper = mapper;
    }

复杂映射

base.CreateMap<Admin, AdminDto>()
        .ForMember(dest => dest.RoleMsg, sourse => sourse.MapFrom(src => src.RoleInfo.RoleMsg));
User:
UserPwd	->不能返回到前端
UserName ->返回到前端
UserDTO:
UserName
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。