dotnet core微服务框架Jimu ~部署和调用演示

首先运行 consul

下载 consul

以开发模式运行

复制代码
consul agent -dev

2. 调试

  1. 用 Visual Studio 2022 IDE 打开项目;
  2. 右击解决方案-选择"属性"
  3. 在属性界面下,选择多项目启动, News.Server, Auth.Server, Register.Server, ApiGateway 几个项目的操作方式选择为"启动";

如下图

3. 部署

  1. 用 Visual Studio 2022 IDE 打开项目;
  2. 右击 News.Server 项目,选择"发布"(Auth.Server,Register.Server,ApiGateway 同理)
  3. 选择发布的文件夹;
  4. 用命令提示符进入文件夹,启动项目
复制代码
dotnet News.Server.dll

如下图

apigateway & server

service service detial

4. postman 调用

调用方不需要知道微服务部署的地址,直接访问网关就可以了。

打开网关的服务列表可以看到所有服务的调用路径,在展开服务的明细可看到更多关于该服务的信息,如授权、角色限制等。

直接复制上面所示的调用地址,下面用 postman 对 api 进行调用:

4.1 Register

4.1.1 判断用户名 grissom 是否可用

  1. 使用 GET 方法请求;
  2. Content-Type 设置为 application/json;

4.1.2 注册会员 grissom

请求路径: http://localhost:5000/api/v1/register/register?name=grissom&nickname=Gil&pwd=123

4.2 Auth

4.2.1 获取 token

上面注册会员都是匿名访问的,但访问受保护的 api 必须先获取 token 请求 token api 需要:

  1. 使用 Post 方法请求;
  2. Content-Type 设置为 application/json;
  3. Body 用 json 格式, 如 {"username":"grissom","password":"123"};

返回结果是一个 json 格式的对象, access_token 就是生成的 token, expired_in (数字时间戳从 1970 到现在的秒数)是 token 的失效时间

复制代码
{
    "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE1MzIzNjUzNzUsInVzZXJuYW1lIjoiZ3Jpc3NvbSIsInJvbGVzIjoiYWRtaW4iLCJtZW1iZXIiOiJ7XCJJZFwiOlwiNTgwMDc4MGYtMjMyMy00ZTdjLWFmMDEtOWEyNzY4NDE0N2MyXCIsXCJOYW1lXCI6XCJncmlzc29tXCIsXCJOaWNrTmFtZVwiOlwiR2lsXCIsXCJSb2xlXCI6XCJhZG1pblwifSJ9.Rr1g94btU8oxJ3ci7dg3OY_QEj2sBhxI-YtyFZQONbQ", "expired_in": 1532365375 } 

4.2.2 获取当前会员信息

  1. 使用 GET 方法请求;
  2. Content-Type 设置为 application/json;
  3. Authorization 设置为上面生成的 token, 格式: Bearer {token} 如
复制代码
Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE1MzIzNjUzNzUsInVzZXJuYW1lIjoiZ3Jpc3NvbSIsInJvbGVzIjoiYWRtaW4iLCJtZW1iZXIiOiJ7XCJJZFwiOlwiNTgwMDc4MGYtMjMyMy00ZTdjLWFmMDEtOWEyNzY4NDE0N2MyXCIsXCJOYW1lXCI6XCJncmlzc29tXCIsXCJOaWNrTmFtZVwiOlwiR2lsXCIsXCJSb2xlXCI6XCJhZG1pblwifSJ9.Rr1g94btU8oxJ3ci7dg3OY_QEj2sBhxI-YtyFZQONbQ
  1. 请求路径: http://localhost:5000/api/v1/member/getcurrentmemberinfo

4.3 News

会员服务: 获取所有新闻、获取指定新闻、发布新闻 都是受保护的 api (EnableAuthorization:true),所以调用时都需要带上 token

4.3.1 获取所有新闻

  1. 使用 GET 方法请求;
  2. Content-Type 设置为 application/json;
  3. Authorization 设置为上面生成的 token, 格式: Bearer {token}
  4. 调用路径: api/v1/news/getallnews

4.3.2 发布新闻

发布新闻的接口接受的是一个对象,所以需要用 POST

  1. 使用 POST 方法请求;
  2. Content-Type 设置为 application/json;
  3. Authorization 设置为上面生成的 token, 格式: Bearer {token}
  4. 调用路径: api/v1/news/postnews

根据返回的 id 获取该篇新闻

4.3.3 角色限制

我们看看发布新闻方法的声明

指定了 Roles="admin", 即需要具有 admin 角色的用户才能访问, 而上面调用发布新闻的用户是 grissom , 在模拟数据里配置了他属于 admin 角色

而用户 Foo 的角色是 guest, 我们换成他去获取 token, 然后再调用发布新闻的 api, 会报错: 未授权

相关推荐
18你磊哥1 分钟前
java中使用微服务的痛点有哪些,怎么解决
java·开发语言·微服务
Pasregret2 分钟前
05-微服务可观测性体系建设:从日志、监控到链路追踪实战指南
java·微服务·云原生·架构
菜鸟起航ing5 小时前
【Java面试系列】Spring Boot微服务架构下的分布式事务处理与性能优化详解 - 3-5年Java开发必备知识
java·spring boot·微服务·性能优化·分布式事务
极客先躯6 小时前
高级java每日一道面试题-2025年4月06日-微服务篇[Nacos篇]-如何诊断和解决Nacos中的常见问题?
java·开发语言·微服务
爱的叹息7 小时前
关于 Spring Boot 微服务解决方案的对比,并以 Spring Cloud Alibaba 为例,详细说明其核心组件的使用方式、配置及代码示例
spring boot·后端·微服务
帝锦_li7 小时前
微服务1--服务架构
分布式·微服务·系统架构
极客先躯9 小时前
高级java每日一道面试题-2025年4月08日-微服务篇[Nacos篇]-生产环境中部署Nacos的最佳实践有哪些?
java·开发语言·微服务
AronTing10 小时前
07-云原生安全深度剖析:从 Kubernetes 集群防护到微服务安全加固
spring·微服务·架构
MrWho不迷糊11 小时前
Spring Boot 怎么打印日志
spring boot·后端·微服务