330 Identity with Web API

步骤

1、安装NuGet包

为CitiesManager.Core和CitiesManager.Infrastructure项目安装如下NuGet包(启用Identity)

<PackageReference Include="Microsoft.AspNetCore.Identity.EntityFrameworkCore" Version="8.0.6" />

2、添加User和Role类

CitiesManager.Core项目中新建Identity文件夹,添加两个类

ApplicationUser.cs

using Microsoft.AspNetCore.Identity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CitiesManager.Core.Identity
{
    public class ApplicationUser : IdentityUser<Guid>
    {
        public string? PersonName { get; set; }
    }
}

ApplicationRole.cs

using Microsoft.AspNetCore.Identity;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CitiesManager.Core.Identity
{
    public class ApplicationRole : IdentityRole<Guid>
    {

    }
}

3、更新DbContext

ApplicationDbContext.cs中DbContext改为IdentityDbContext

using CitiesManager.Core.Entities;
using CitiesManager.Core.Identity;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore;

namespace CitiesManager.Infrastructure.DatabaseContext
{
    public class ApplicationDbContext : IdentityDbContext<ApplicationUser, ApplicationRole, Guid>
    {
        public ApplicationDbContext(DbContextOptions options) : base(options)
        {

        }

        public ApplicationDbContext()
        {

        }

        public virtual DbSet<City> Cities { get; set; }


        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);

            modelBuilder.Entity<City>().HasData(new City[]
            {
                new City
                {
                    CityID = Guid.Parse("F3D83BDE-F859-4C40-BDBE-A3ED8E48D850"),
                    CityName = "New York",
                },
                new City
                {
                    CityID = Guid.Parse("FE331780-B359-4707-8455-016D472ED64F"),
                    CityName = "London",
                }
            });
        }
    }
}

4、更新Program.cs

//Identity
builder.Services.AddIdentity<ApplicationUser, ApplicationRole>(options =>
{
    options.Password.RequiredLength = 5;
    options.Password.RequireNonAlphanumeric = false;
    options.Password.RequireLowercase = false;
    options.Password.RequireDigit = true;
}).AddEntityFrameworkStores<ApplicationDbContext>().AddDefaultTokenProviders().AddUserStore<UserStore<ApplicationUser, ApplicationRole, ApplicationDbContext, Guid>>().AddRoleStore<RoleStore<ApplicationRole, ApplicationDbContext, Guid>>();

var app = builder.Build();


// Configure the HTTP request pipeline.

app.UseHsts();  //Force to user https
app.UseHttpsRedirection();

app.UseSwagger(); //created endpoint for swagger.json
app.UseSwaggerUI(options =>
{
    options.SwaggerEndpoint("/swagger/v1/swagger.json", "1.0");
    options.SwaggerEndpoint("/swagger/v2/swagger.json", "2.0");
}); //creates swagger UI for testing all Web Api endpoints/action methods

app.UseRouting();
app.UseCors();

app.UseAuthentication();
app.UseAuthorization();

app.MapControllers();

app.Run();

结果

到这里,使用Identity的基础准备工作已经完成。

Gitee获取源码:

https://gitee.com/huang_jianhua0101/asp.-net-core-8.git

  • 9
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,让我来给你提供一些实现上述需求的步骤: 1. 首先,你需要在IntelliJ中创建一个新的Spring Boot项目。可以使用Spring Initializr来快速创建。 2. 接下来,你需要添加一些必要的依赖项,如Spring MVC、JPA、MySQL和JWT。可以在pom.xml文件中添加以下依赖项: ```xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version> </dependency> </dependencies> ``` 3. 然后,你需要定义数据模型。这里我们可以定义一个名为Shipping的类,包含一些基本信息,如id、起始城市、目的城市、货物类型等等。可以在src/main/java目录下创建一个名为Shipping的类。 ```java @Entity @Table(name = "shipping") public class Shipping { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(nullable = false) private String startCity; @Column(nullable = false) private String endCity; @Column(nullable = false) private String goodsType; // 省略getter和setter } ``` 4. 接下来,你需要定义一个Repository接口,用于访问数据库中的Shipping数据。在src/main/java目录下创建一个名为ShippingRepository的接口。 ```java @Repository public interface ShippingRepository extends JpaRepository<Shipping, Long> { List<Shipping> findByStartCityAndEndCity(String startCity, String endCity); } ``` 5. 接下来,你需要定义一个Controller类,用于处理请求并返回响应。可以在src/main/java目录下创建一个名为ShippingController的类。 ```java @RestController @RequestMapping("/api/shipping") public class ShippingController { @Autowired private ShippingRepository shippingRepository; @PostMapping("/search") public List<Shipping> searchShipping(@RequestBody Map<String, String> searchParams) { String startCity = searchParams.get("startCity"); String endCity = searchParams.get("endCity"); return shippingRepository.findByStartCityAndEndCity(startCity, endCity); } } ``` 6. 最后,你需要配置JWT,以确保API的安全性。可以在src/main/java目录下创建一个名为JwtConfig的类。 ```java @Configuration public class JwtConfig { @Value("${jwt.secret}") private String secret; @Bean public JwtEncoder jwtEncoder() { return Jwts.builder().setSigningKey(secret.getBytes()).build(); } @Bean public JwtDecoder jwtDecoder() { return Jwts.parser().setSigningKey(secret.getBytes()).build(); } } ``` 7. 在application.properties文件中添加以下配置: ```properties spring.jpa.hibernate.ddl-auto=create spring.datasource.url=jdbc:mysql://localhost:3306/shipping_db?useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=123456 jwt.secret=your_secret_key_here ``` 现在,你可以运行你的代码,并使用postman等工具来测试API

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄健华Yeah

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值