目标效果图:
实现步骤
1、选择Create NewProject 创建一个新工程
2、创建一个工程,工程下面可以分模块子模块构建依赖maven构建的生态
3、这里可以添加许多依赖模块包,提供为开发者更大的简便,不用的自己配置复杂的配置文件,用着就是爽
<?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> <groupId>com.ernestfei</groupId> <artifactId>spring-ernestfei-timertask</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>spring-ernestfei-timertask</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.9.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>4.5.3</version> </dependency> <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient-cache --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient-cache</artifactId> <version>4.5.3</version> </dependency> <!--httpclinet请求所需包 https://mvnrepository.com/artifact/org.apache.httpcomponents/httpmime --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpmime</artifactId> <version>4.5.3</version> </dependency> <!--springboot web启动包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--springboot读取配置文件类--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson json工具类 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.41</version> </dependency> <!--操作文件工具类--> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> <!-- 可命令行独立编译maven项目下的class文件 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <proc>none</proc> </configuration> </plugin> </plugins> </build> </project>
4、工程创建成功后将配置pom.xml文件,具体配置如上。
5、 工程目录结构如下
6、下面我们配置一下定时任务
启动类中使用 @EnableScheduling 注解来开启任务调度
@SpringBootApplication
@EnableScheduling
public class SpringErnestfeiTimertaskApplication {
public static void main(String[] args) {
SpringApplication.run(SpringErnestfeiTimertaskApplication.class, args);
System.out.println("=======================Springboot实现定时任务客户端demo=========================");
}
}
7、调度方法如下
@Component
public class TimerTasks {
private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");
@Resource
private UrlConfig config;
/**
* 定时任务上传文件到服务器
* */
@Scheduled(cron = "0 0/1 * * * ?")
public void reportCurrentTime() {
Date date = new Date();
File uploadFile = new File(config.getGetFileDir()+"\\1.txt");
FileUploadClient.uploadPassFile(config.getServerUrl(),uploadFile);
System.out.println("{客户端定时任务开启每一分钟发送一次}===>>>"+dateFormat.format(date));
}
}
8、使用HttpClinet实现客户端调度,具体如下
/** * 上传文件 * serverUrl 上传服务器地址 * file 上传的文件 * */ public static void uploadFile(String serverUrl,File file0) { CloseableHttpClient httpclient = HttpClients.createDefault(); try { HttpPost httppost = new HttpPost(serverUrl); FileBody file = new FileBody(file0); StringBody token = new StringBody("1234567", ContentType.create("text/plain", Consts.UTF_8)); StringBody content = new StringBody(">>>{来自于客户端传来的文件}<<<", ContentType.create("text/plain", Consts.UTF_8)); MultipartEntityBuilder builder =MultipartEntityBuilder.create(); HttpEntity reqEntity = builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE) .addPart("file", file) .addPart("token", token) .addPart("content",content) .setCharset(CharsetUtils.get("UTF-8")).build(); httppost.setEntity(reqEntity); long startTime=System.currentTimeMillis(); System.out.println("====开始执行====" + startTime); CloseableHttpResponse response = httpclient.execute(httppost); try { HttpEntity resEntity = response.getEntity(); if(resEntity!=null){ System.out.println("==resEntity=="+resEntity.getContent()); System.out.println("====中文乱码检测===="); System.out.println(EntityUtils.toString(resEntity, Charset.forName("UTF-8"))); } EntityUtils.consume(resEntity); long endTime=System.currentTimeMillis(); System.out.println("====结束执行====" + endTime); System.out.println("====执行时间====" + (endTime - startTime)); } finally { response.close(); } } catch (ClientProtocolException e) { System.out.println("====服务器端无法连接异常===="); e.printStackTrace(); } catch (IOException e) { System.out.println("====服务器端无法连接异常===="); e.printStackTrace(); } finally { try { httpclient.close(); } catch (IOException e) { e.printStackTrace(); } } } 9、服务端Contoller层处理客户端调用处理
@RestController
public class FileUploadController {
@Resource
private UrlConfig config;
@PostMapping("uploadFile")
public Object uploadFile(@RequestParam(value = "file")MultipartFile file,@RequestParam(value = "token")String token,@RequestParam(value = "content",required = false)String content){
Map<String,Object> resMap = new HashMap<>(8);
System.out.println("{服务端接受内容}===>>>"+content);
if(token.equals(config.getToken())){
System.out.println("{上传的文件名为}===>>>"+file.getOriginalFilename());
resMap.put("status",200);
resMap.put("message","服务端返回=上传成功,返回文件"+file.getOriginalFilename());
}else{
resMap.put("status",400);
resMap.put("message","服务端返回=上传失败,TOKEN校验失败!");
}
return JSON.toJSONString(resMap);
}
}
10、读取配置文件中的参数可以使用@ConfigurationProperties 和 @PropertySource 读取配置文件,将参数加载成实例属性。
@Component
@ConfigurationProperties(prefix = UrlConfig.PREFIX)
@PropertySource("classpath:baseConfig.properties")
public class UrlConfig {
public static final String PREFIX = "config";
private String serverUrl;
private String getFileDir;
private String token;
public void setToken(String token) {
this.token = token;
}
public String getToken() {
return token;
}
public void setServerUrl(String serverUrl) {
this.serverUrl = serverUrl;
}
public String getServerUrl() {
return serverUrl;
}
public void setGetFileDir(String getFileDir) {
this.getFileDir = getFileDir;
}
public String getGetFileDir() {
return getFileDir;
}
自此一个简单的demo就轻松实现了客户端向服务端定时发送文件的定时任务功能。不得不感慨SpringBoot的强大之处。
