NatureCommunicatiosController.java
1.44 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
package com.canrd.webmagic.controller;
import com.canrd.webmagic.common.constant.ServerResult;
import com.canrd.webmagic.processor.NatureCommunicatiosPcoessor;
import com.canrd.webmagic.processor.NatureEnergyPagePcoessor;
import com.canrd.webmagic.processor.pipeline.ArticlePipeline;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.logging.log4j.core.util.UuidUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import us.codecraft.webmagic.Spider;
import us.codecraft.webmagic.scheduler.RedisScheduler;
import javax.annotation.Resource;
@RestController
@RequestMapping("/nature-communicatios/article")
@Api("Nature")
public class NatureCommunicatiosController {
@Resource
private NatureCommunicatiosPcoessor natureCommunicatiosPcoessor;
@Resource
private ArticlePipeline articlePipeline;
@GetMapping("/start")
@ApiOperation("start")
public ServerResult start() {
Spider.create(natureCommunicatiosPcoessor)
.addUrl("https://www.nature.com/ncomms/articles?type=editorial")
.setUUID(UuidUtil.getTimeBasedUuid().toString())
.addPipeline(articlePipeline)
// .setScheduler(new RedisScheduler("127.0.0.1"))
.thread(20).run();
return ServerResult.success();
}
}