JwtDemo 项目使用教程

JwtDemo 项目使用教程

JwtDemogin基于JWT实现token令牌功能demo项目地址:https://gitcode.com/gh_mirrors/jw/JwtDemo

1. 项目的目录结构及介绍

JwtDemo/
├── src/
│   ├── main/
│   │   ├── java/
│   │   │   ├── com/
│   │   │   │   ├── example/
│   │   │   │   │   ├── controller/
│   │   │   │   │   ├── model/
│   │   │   │   │   ├── service/
│   │   │   │   │   ├── config/
│   │   │   │   │   ├── JwtDemoApplication.java
│   │   ├── resources/
│   │   │   ├── application.properties
├── pom.xml
  • src/main/java/com/example/controller/: 存放控制器类,处理HTTP请求。
  • src/main/java/com/example/model/: 存放数据模型类。
  • src/main/java/com/example/service/: 存放服务类,处理业务逻辑。
  • src/main/java/com/example/config/: 存放配置类,如安全配置、JWT配置等。
  • src/main/java/com/example/JwtDemoApplication.java: 项目的启动类。
  • src/main/resources/application.properties: 项目的配置文件。
  • pom.xml: Maven项目的依赖管理文件。

2. 项目的启动文件介绍

JwtDemoApplication.java 是项目的启动类,包含主方法 main,用于启动Spring Boot应用程序。

package com.example;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class JwtDemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(JwtDemoApplication.class, args);
    }
}

3. 项目的配置文件介绍

application.properties 是项目的配置文件,包含各种配置项,如服务器端口、数据库连接、JWT秘钥等。

# 服务器端口
server.port=8080

# JWT配置
jwt.secret=your_secret_key
jwt.expiration=86400000
  • server.port: 指定服务器端口,默认是8080。
  • jwt.secret: JWT的秘钥,用于签名和验证JWT。
  • jwt.expiration: JWT的过期时间,单位是毫秒。

以上是 JwtDemo 项目的基本使用教程,涵盖了项目的目录结构、启动文件和配置文件的介绍。希望对您有所帮助!

JwtDemogin基于JWT实现token令牌功能demo项目地址:https://gitcode.com/gh_mirrors/jw/JwtDemo

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个 ASP.NET Core JWT 的示例代码,包含生成 Token 和验证 Token 的过程: ```csharp using Microsoft.AspNetCore.Authentication.JwtBearer; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Configuration; using Microsoft.IdentityModel.Tokens; using System; using System.IdentityModel.Tokens.Jwt; using System.Security.Claims; using System.Text; namespace JwtDemo.Controllers { [ApiController] [Route("[controller]")] public class AuthController : ControllerBase { private readonly IConfiguration _configuration; public AuthController(IConfiguration configuration) { _configuration = configuration; } [AllowAnonymous] [HttpPost("token")] public IActionResult Token() { var claims = new[] { new Claim(JwtRegisteredClaimNames.Sub, "user_id"), new Claim(JwtRegisteredClaimNames.Jti, Guid.NewGuid().ToString()), new Claim(JwtRegisteredClaimNames.Iat, DateTime.UtcNow.ToString()) }; var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_configuration["Jwt:Key"])); var creds = new SigningCredentials(key, SecurityAlgorithms.HmacSha256); var token = new JwtSecurityToken( _configuration["Jwt:Issuer"], _configuration["Jwt:Issuer"], claims, expires: DateTime.Now.AddMinutes(30), signingCredentials: creds); return Ok(new { token = new JwtSecurityTokenHandler().WriteToken(token) }); } [Authorize(AuthenticationSchemes = JwtBearerDefaults.AuthenticationScheme)] [HttpGet("data")] public IActionResult GetData() { // 返回数据 return Ok(new { message = "Hello, world!" }); } } } ``` 在上述代码中,首先我们在 `Token()` 方法中生成 JWT Token,使用 `JwtSecurityTokenHandler` 类来生成 Token,然后将其返回给客户端。在 `GetData()` 方法中使用 `[Authorize]` 特性进行身份验证,只允许授权用户访问该接口。 在 `Startup.cs` 中需要添加以下代码: ```csharp public void ConfigureServices(IServiceCollection services) { // 添加 JWT 鉴权 services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme) .AddJwtBearer(options => { options.RequireHttpsMetadata = false; options.SaveToken = true; options.TokenValidationParameters = new TokenValidationParameters { ValidateIssuerSigningKey = true, IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(Configuration["Jwt:Key"])), ValidateIssuer = true, ValidIssuer = Configuration["Jwt:Issuer"], ValidateAudience = true, ValidAudience = Configuration["Jwt:Issuer"], ClockSkew = TimeSpan.Zero }; }); // 其他服务配置 } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { // 添加 JWT 鉴权 app.UseAuthentication(); app.UseAuthorization(); // 其他中间件配置 } ``` 在 `ConfigureServices` 方法中添加 JWT 鉴权服务,使用 `AddJwtBearer` 方法添加 JWT 鉴权。在 `Configure` 方法中添加 JWT 鉴权中间件,使用 `UseAuthentication` 和 `UseAuthorization` 方法启用 JWT 鉴权。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

晏其潇Aileen

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

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

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

打赏作者

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

抵扣说明:

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

余额充值