初始化

master
zzh 2024-08-04 15:53:10 +08:00
commit eb5290d55d
9 changed files with 242 additions and 0 deletions

35
.gitignore vendored 100644
View File

@ -0,0 +1,35 @@
target/
!.mvn/wrapper/maven-wrapper.jar
!**/src/main/**/target/
!**/src/test/**/target/
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
### Eclipse ###
.apt_generated
.classpath
.factorypath
.project
.settings
.springBeans
.sts4-cache
### NetBeans ###
/nbproject/private/
/nbbuild/
/dist/
/nbdist/
/.nb-gradle/
build/
!**/src/main/**/build/
!**/src/test/**/build/
### VS Code ###
.vscode/
### Mac OS ###
.DS_Store

30
pom.xml 100644
View File

@ -0,0 +1,30 @@
<?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">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.muyu</groupId>
<artifactId>cloud-common</artifactId>
<version>3.6.3</version>
</parent>
<groupId>com.bwie</groupId>
<artifactId>cloud-common-nacos-remote</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.muyu</groupId>
<artifactId>cloud-common-core</artifactId>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,13 @@
package com.bwie;
/**
* @Authorzhangzhihao
* @name${NAME}
* @Date2024/8/4 14:06
*
*/
public class Main {
public static void main(String[] args) {
System.out.println("Hello world!");
}
}

View File

@ -0,0 +1,28 @@
package com.bwie.nacos.remote;
import com.bwie.nacos.remote.interceptor.NacosNamespaceInterceptor;
import com.bwie.nacos.remote.req.ServiceListReq;
import com.bwie.nacos.remote.resp.ServiceListResp;
import com.dtflys.forest.annotation.BaseRequest;
import com.dtflys.forest.annotation.Body;
import com.dtflys.forest.annotation.GetRequest;
import com.muyu.common.core.constant.Constants;
/**
* @Authorzhangzhihao
* @nameNacosServiceApi
* @Date2024/8/4 14:15
*
*/
@BaseRequest(
baseURL = Constants.HTTP+"#{nacos.addr}/nacos/v1/ns/service",
interceptor = {NacosNamespaceInterceptor.class}
)
public interface NacosServiceRemote {
@GetRequest(
url = "/list"
)
public ServiceListResp serviceList(@Body ServiceListReq serviceListReq);
}

View File

@ -0,0 +1,45 @@
package com.bwie.nacos.remote.interceptor;
import com.dtflys.forest.http.ForestRequest;
import com.dtflys.forest.interceptor.Interceptor;
import com.muyu.common.core.text.Convert;
import lombok.extern.log4j.Log4j2;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Value;
@Log4j2
public class NacosNamespaceInterceptor<T> implements Interceptor<T> {
@Value("${nacos.namespace}")
private String namespaceId;
/**
* , false
* @Param request Forest
*/
@Override
public boolean beforeExecute(ForestRequest req) {
if (StringUtils.isNotEmpty(namespaceId)){
String reqNamespaceId = Convert.str(req.getQuery("namespaceId"), "");
if (reqNamespaceId==null){
log.warn("本次请求nccos的namespaceId未携带,已添加[{}]",namespaceId);
req.addQuery("namespaceId",namespaceId);
}else {
if (StringUtils.equals(reqNamespaceId,namespaceId)){
log.warn("本次请求nccos的namespaceId和项目ID不相符,现已更改[{}->{}]",reqNamespaceId,namespaceId);
req.addQuery("namespaceId",namespaceId);
}
}
}
return true; // 继续执行请求返回true
}
}

View File

@ -0,0 +1,23 @@
package com.bwie.nacos.remote.req;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorzhangzhihao
* @nameBaseReq
* @Date2024/8/4 15:03
*
*/
@Data
@SuperBuilder
@NoArgsConstructor
@AllArgsConstructor
public class BaseReq {
/**
*
*/
private String namespaceId;
}

View File

@ -0,0 +1,36 @@
package com.bwie.nacos.remote.req;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;
/**
* @Authorzhangzhihao
* @nameServiceListReq
* @Date2024/8/4 15:04
*
*/
@Data
@SuperBuilder
@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode(callSuper = true)
public class ServiceListReq extends BaseReq{
/**
*
*/
private int pageNo;
/**
*
*/
private int pageSize=10;
/**
*
*/
private String groupName;
}

View File

@ -0,0 +1,31 @@
package com.bwie.nacos.remote.resp;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Authorzhangzhihao
* @nameServiceListResp
* @Date2024/8/4 15:08
*
*/
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class ServiceListResp {
/**
*
*/
private int count;
/**
*
*/
private List<String> doms;
}

View File

@ -0,0 +1 @@
com.bwie.nacos.remote.interceptor.NacosNamespaceInterceptor