前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SaaS-员工管理

SaaS-员工管理

作者头像
cwl_java
发布2020-01-02 11:50:28
4890
发布2020-01-02 11:50:28
举报
文章被收录于专栏:cwl_Javacwl_Javacwl_Java

1 员工管理

1.1 需求分析

企业员工管理是人事资源管理系统中最重要的一个环节,分为对员工入职,转正,离职,调岗,员工报表导入导出等业务逻辑。需求看似复杂,实际上都是对数据库表的基本操作。

1.2 数据库表概述

对于员工操作而言,涉及到的数据库表如下表格说明:

在这里插入图片描述
在这里插入图片描述

1.3 代码实现

基本CRUD ,请参考之前的管理模块

1.3.1 服务端实现

(1) 创建员工微服务 ihrm_employee (2) 配置文件 application.yml (3) 配置Shiro核心配置类ShiroConfiguration (4) 配置启动类EmployeeApplication (5)导入资源中提供的基本Controller,Service,Dao,Domain代码

1.4 服务发现组件 Eureka

Eureka是Netflix开发的服务发现框架,SpringCloud将它集成在自己的子项目spring-cloud-netflix中,实现SpringCloud的服务发现功能。Eureka包含两个组件:Eureka Server和Eureka Client。

  1. Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。
  2. Eureka Client是一个java客户端,用于简化与Eureka Server的交互,客户端同时也就别一个内置的、使用轮询(round-robin)负载算法的负载均衡器。在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。

1.4.1 Eureka服务端开发

(1)创建ihrm_eureka模块 (2)引入依赖 父工程pom.xml定义SpringCloud版本

<dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.M9</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
</dependencyManagement>

eureka模块pom.xml引入eureka-server

<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eurekaserver</artifactId>
        </dependency>
</dependencies>

(3)添加application.yml

server:
  port: 6868 #服务端口
eureka:
  client:
    registerWithEureka: false #是否将自己注册到Eureka服务中,本身就是所有无需
注册
    fetchRegistry: false #是否从Eureka中获取注册信息
    serviceUrl: #Eureka客户端与Eureka服务端进行交互的地址
      defaultZone: http://127.0.0.1:${server.port}/eureka/

(4) 配置启动类

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

1.4.2 微服务注册

我们现在就将所有的微服务都注册到Eureka中,这样所有的微服务之间都可以互相调用了。 (1)将其他微服务模块添加依赖

<dependency>        
	 <groupId>org.springframework.cloud</groupId>            
	 <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>         
</dependency>

(2)修改每个微服务的application.yml,添加注册eureka服务的配置

eureka:
  client:
    service-url:
      defaultZone: http://localhost:6868/eureka
  instance:
    prefer-ip-address: true

(3)修改每个服务类的启动类,添加注解

@EnableEurekaClient

1.5 微服务调用组件Feign

1.5.1 简介

Feign是简化Java HTTP客户端开发的工具(java-to-httpclient-binder),它的灵感来自于Retrofit、JAXRS-2.0和WebSocket。Feign的初衷是降低统一绑定Denominator到HTTP API的复杂度,不区分是否为restful

1.5.2 快速体验

我们现在在系统微服务调用企业微服务的方法(根据ID查询部门) (1)在ihrm_system模块添加依赖

<dependency>        
	 <groupId>org.springframework.cloud</groupId>            
	 <artifactId>spring-cloud-starter-openfeign</artifactId>            
</dependency>

(2)修改ihrm_system模块的启动类,添加注解

@EnableDiscoveryClient
@EnableFeignClients

(3)在Ihrm_system模块创建com.ihrm.system.client包,包下创建接口

//@FeignClient注解用于指定从哪个服务中调用功能 ,注意里面的名称与被调用的服务名保持一致
@FeignClient(value = "ihrm-company")
public interface DepartmentFeignClient {
    //@RequestMapping注解用于对被调用的微服务进行地址映射
    @RequestMapping(value = "/company/departments/{id}/", method = RequestMethod.GET)
    public Department findById(@PathVariable("id") String id) throws Exception; }

(4)修改Ihrm_system模块的 UserController

 @Autowired    
 private DepartmentFeignClient departmentFeignClient;    
 
 //测试通过系统微服务调用企业微服务方法
 @RequestMapping(value = "/test/{id}")    
    public void findDeptById(@PathVariable  String id){    
   Department dept = departmentFeignClient.findById(id);  
        System.out.println(dept);        
 }

(5)配置Feign拦截器添加请求头

/**
* FeignConfiguration 过滤器,配置请求头信息
*/
@Configuration
public class FeignConfiguration {
    @Bean
    public RequestInterceptor requestInterceptor() {
        return new RequestInterceptor() {
            @Override
            public void apply(RequestTemplate template) {
                ServletRequestAttributes attributes = (ServletRequestAttributes) 
RequestContextHolder
                       .getRequestAttributes();
                if (attributes != null) {
                    HttpServletRequest request = attributes.getRequest();
                    Enumeration<String> headerNames = request.getHeaderNames();
                    if (headerNames != null) {
                        while (headerNames.hasMoreElements()) {
                            String name = headerNames.nextElement();
                            String values = request.getHeader(name);
                            template.header(name, values);
                       }
                   }
               }
           }
       };
   }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 员工管理
    • 1.1 需求分析
      • 1.2 数据库表概述
        • 1.3 代码实现
          • 1.3.1 服务端实现
        • 1.4 服务发现组件 Eureka
          • 1.4.1 Eureka服务端开发
          • 1.4.2 微服务注册
        • 1.5 微服务调用组件Feign
          • 1.5.1 简介
          • 1.5.2 快速体验
      相关产品与服务
      数据库
      云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档