教育项目之网关模块介绍

1.pom文件介绍

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>GrainOnlineEducation_Parent</artifactId>
        <groupId>com.grain</groupId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>GrainOnlineEducation_Gateway</artifactId>

    <dependencies>
        <!--网关-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>

        <!--服务注册-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>

</project>

2.代码分析

package com.grain.gateway.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;

import javax.servlet.http.HttpServletRequest;

import static org.springframework.cloud.netflix.zuul.filters.support.FilterConstants.PRE_TYPE;

/**
 * @author:Dragon Wen
 * @email:18475536452@163.com
 * @date:Created in 2020/3/14 15:05
 * @description:
 * @modified By:
 * @version: $
 */
@Component
public class LoginFilter extends ZuulFilter {

    //定义过滤器的类型
    @Override
    public String filterType() {
        return PRE_TYPE;  //PRE
    }

    //过滤器执行顺序,返回的值越小,越先执行
    @Override
    public int filterOrder() {
        return 1;
    }

    //决定是否执行下面的run方法
    //如果返回false,表示过滤器放行操作,不执行run方法
    //如果返回true,过滤器没有放行,执行run方法
    @Override
    public boolean shouldFilter() {
        //判断:访问路径包含/eduvod/vid/getPlayAuthFront进行登录校验
        //1 获取请求的路径 uri,HttpServletRequest是请求对象
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletRequest request = currentContext.getRequest();
        String requestURI = request.getRequestURI();

        System.out.println("uri: "+requestURI);

        String palyUrl = "/vod/get-play-auth/";
        //2 根据获取请求路径判断,路径里面是否包含  /vod/get-play-auth/
        if(!StringUtils.isEmpty(requestURI) && requestURI.contains(palyUrl)) {
            //3 如果包含,进行验证操作,return true
            return true; //run方法执行,进行校验
        }
        return false;  //放行
    }

    //run方法写过滤器具体逻辑
    @Override
    public Object run() throws ZuulException {
        System.out.println("run方法执行了.........");
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletRequest request = currentContext.getRequest();

        String token = request.getParameter("token");
        if(StringUtils.isEmpty(token)) {
            //不能访问接口
            currentContext.setSendZuulResponse(false); //不会向后执行
            //设置不能访问状态码
            currentContext.setResponseStatusCode(HttpStatus.UNAUTHORIZED.value());
        }

        return null;
    }
}

对前端发过来的请求进行网关过滤,根据自己的逻辑处理。

package com.grain.gateway;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

/**
 * @author:Dragon Wen
 * @email:18475536452@163.com
 * @date:Created in 2020/3/14 13:15
 * @description:
 * @modified By:
 * @version: $
 */
@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
public class ApiGatewayApplication {

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

3.配置文件

application.properties:

server.port=9001

#环境设置:dev、test、prod
spring.profiles.active=dev

#服务的名称
spring.application.name=grain-api-gateway

### 配置URL 映射 ###(该功能类似于Nginx)
#这里的配置表示,访问path路径 直接重定向到url指定的地址
#如:访问        http://localhost:9001/teacher/list
#    重定向到    http://localhost:8001/teacher/list
#zuul.routes.api-edu.path=/teacher/**
#zuul.routes.api-edu.url=http://localhost:8001/teacher/

#指定注册中心地址
eureka.client.service-url.defaultZone=http://localhost:8004/eureka/
#eureka服务器上获取的是服务器的ip地址,否则是主机名
eureka.instance.prefer-ip-address=true

### 环境隔离配置 ###
#禁止grain-statistics对外提供接口
#zuul.ignored-services=grain-statistics

### 禁止通过网关访问路由 ###
#zuul.ignored-patterns=/**/admin/**

### 自定义路由映射###
#zuul.routes.grain-teacher=/teacher-api/**

#还原被网关过滤的请求头
zuul.sensitive-headers=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 以下是我推荐的几个Java微服务实战项目: 1. Spring Cloud微服务电商项目:这是一个完整的电商应用程序,使用Spring Cloud实现微服务架构。它包括注册中心、配置中心、、商品服务、订单服务、用户服务等多个微服务模块,涵盖了大部分微服务技术点。 2. 微服务在线教育项目:这是一个在线教育平台,使用Spring Cloud实现微服务化。它包括注册中心、配置中心、、用户服务、课程服务、订单服务等多个微服务模块,同时还使用了分布式事务解决方案Seata,涵盖了分布式事务相技术点。 3. 微服务电影购票项目:这是一个电影购票应用程序,使用Spring Cloud实现微服务化。它包括注册中心、配置中心、、影院服务、电影服务、订单服务等多个微服务模块,同时还使用了Spring Cloud Stream实现消息驱动,涵盖了消息驱动相技术点。 希望这些项目对您有所帮助! ### 回答2: 在Java开发领域,有几个热门的微服务实战项目可以推荐。 首先,Spring Cloud是目前非常流行的微服务框架之一。它是基于Spring Boot构建的,提供了一套完善的微服务解决方案。推荐的一个实战项目是使用Spring Cloud搭建一个电子商务平台。该项目模拟了一个完整的电商系统,包括用户管理、商品管理、订单管理等功能。通过这个项目,你可以学习到如何使用Spring Cloud实现服务注册与发现、服务间通信、负载均衡等微服务相的知识。 其次,Quarkus是一种新兴的微服务开发框架,它专注于减小应用程序的资源消耗和启动时间。推荐的一个实战项目是使用Quarkus构建一个在线投票系统。该项目可以让用户创建投票活动,并允许其他用户参与投票。通过这个项目,你可以学习到如何使用Quarkus开发快速、高效的微服务应用。 最后,Micronaut是另一个快速、轻量级的微服务框架。它提供了许多与Spring Boot类似的特性,但更加注重性能和资源利用率。推荐的一个实战项目是使用Micronaut构建一个在线博客平台。该项目包括博客的创建、发布、评论等功能。通过这个项目,你可以学习到如何使用Micronaut开发高性能的微服务应用,以及如何利用其注解驱动的开发模式提高开发效率。 总之,以上推荐的实战项目都可以帮助你深入了解Java微服务的开发实践和常用工具。无论你选择哪一个项目,都应该注重实际动手实践,通过编码和调试来加深对微服务开发的理解。 ### 回答3: 有许多值得推荐的Java微服务实战项目,以下列举几个较为常见的: 1. Spring Cloud Netflix:Spring Cloud Netflix是基于Spring Cloud开发的一套微服务项目实战框架,包含众多组件,如Eureka(服务注册与发现)、Ribbon(负载均衡)、Hystrix(断路器)等,帮助开发者快速构建可扩展的微服务架构。 2. Spring Boot + Docker:结合Spring Boot和Docker可以轻松构建可部署的微服务。使用Spring Boot可以方便地创建独立的、生产级别的Spring应用程序,而Docker则提供了环境隔离和轻量级部署的特性,使得微服务的部署和管理更加便捷。 3. Apache Dubbo:Apache Dubbo是一种高性能、轻量级的Java微服务框架。它支持多语言、多协议的微服务调用,具有服务注册和发现、负载均衡、服务容错等核心功能,适用于大规模的分布式系统。 4. Spring Cloud Alibaba:Spring Cloud Alibaba是Spring Cloud与阿里巴巴集团开发的一套微服务工具链,基于Spring Cloud实现了服务注册与发现、配置中心、消息总线等功能。该项目与阿里巴巴的一些开源产品(如Nacos)深度集成,为开发者提供了更多的选择。 无论选择哪个Java微服务实战项目,了解微服务架构的基本概念和原则是必要的。此外,熟悉分布式系统的设计和开发经验以及相的技术栈(如数据库、消息中间件等)也是必备的。最重要的是,选择的项目要与自己的实际需求相符,并具备社区支持和活跃度,以便在遇到问题时能够得到及时的帮助和解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

bst@微胖子

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

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

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

打赏作者

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

抵扣说明:

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

余额充值