当前位置: 首页 > news >正文

大连seo建站网站的反爬一般怎样做

大连seo建站,网站的反爬一般怎样做,太仓网站建设有限公司,网站建设没有预付款RestAPI 初始化RestClient创建索引库Mapping映射 判断索引库是否存在删除索引库总结 ES官方提供了各种不同语言的客户端,用来操作ES。这些客户端的本质就是组装DSL语句,通过http请求发送给ES。 官方文档地址 由于ES目前最新版本是8.8,提供了全…

RestAPI

  • 初始化RestClient
  • 创建索引库
    • Mapping映射
  • 判断索引库是否存在
  • 删除索引库
  • 总结

ES官方提供了各种不同语言的客户端,用来操作ES。这些客户端的本质就是组装DSL语句,通过http请求发送给ES。
官方文档地址
由于ES目前最新版本是8.8,提供了全新版本的客户端,老版本的客户端已经被标记为过时。而我们采用的是7.12版本,因此只能使用老版本客户端:
在这里插入图片描述
然后选择7.12版本,HighLevelRestClient版本
在这里插入图片描述

初始化RestClient

在elasticsearch提供的API中,与elasticsearch一切交互都封装在一个名为RestHighLevelClient的类中,必须先完成这个对象的初始化,建立与elasticsearch的连接。
分为三步:
1)在item-service模块中引入es的RestHighLevelClient依赖:

<dependency><groupId>org.elasticsearch.client</groupId><artifactId>elasticsearch-rest-high-level-client</artifactId>
</dependency>

2)因为SpringBoot默认的ES版本是7.17.10,所以我们需要覆盖默认的ES版本:

  <properties><maven.compiler.source>11</maven.compiler.source><maven.compiler.target>11</maven.compiler.target><elasticsearch.version>7.12.1</elasticsearch.version></properties>

3)测试代码:

@Slf4j
@SpringBootTest
class EsClientTest {private RestHighLevelClient client;@Testvoid test() throws IOException {log.info("client = {}",client);}@BeforeEachvoid setUp() {client = new RestHighLevelClient(RestClient.builder(new HttpHost("49.233.155.186", 9200, "http")));}@AfterEachvoid tearDown() throws IOException {if (client != null) {client.close();}}
}

创建索引库

由于要实现对商品搜索,所以我们需要将商品添加到Elasticsearch中,不过需要根据搜索业务的需求来设定索引库结构,而不是一股脑的把MySQL数据写入Elasticsearch.

Mapping映射

搜索页面的效果如图所示:
实现搜索功能需要的字段包括三大部分:

  • 搜索过滤字段
    • 分类
    • 品牌
    • 价格
  • 排序字段
    • 默认:按照更新时间降序排序
    • 销量
    • 价格
  • 展示字段
    • 商品id:用于点击后跳转
    • 图片地址
    • 是否是广告推广商品
    • 名称
    • 价格
    • 评价数量
    • 销量
      对应的商品表结构如下,索引库无关字段已经划掉:
      在这里插入图片描述
      结合数据库表结构,以上字段对应的mapping映射属性如下:
字段名字段类型类型说明是否参与搜索是否参与分词分词器
idlong长整数[x][]
nametext字符串,参与分词搜索[x][x]IK
priceinteger以分为单位,所以是整数[x][]
stockinteger字符串,但需要分词[x][]
imagekeyword字符串,但是不分词[][]
categorykeyword字符串,但是不分词[x][]
brandkeyword字符串,但是不分词[x][]
soldinteger销量,整数[x][]
commentCountinteger评价,整数[][]
isADboolean布尔类型[x][]
updateTimeDate更新时间[x][]

因此,最终我们的索引库文档结构应该是这样:

PUT /items
{"mappings": {"properties": {"id": {"type": "keyword"},"name":{"type": "text","analyzer": "ik_max_word"},"price":{"type": "integer"},"stock":{"type": "integer"},"image":{"type": "keyword","index": false},"category":{"type": "keyword"},"brand":{"type": "keyword"},"sold":{"type": "integer"},"commentCount":{"type": "integer","index": false},"isAD":{"type": "boolean"},"updateTime":{"type": "date"}}}
}

创建索引
创建索引库的API如下:
在这里插入图片描述
代码分为三步:

  1. 创建Request对象。
    因为是创建索引库的操作,因此Request是CreateIndexRequest。
  2. 添加请求参数
    其实就是Json格式的Mapping映射参数。因为json字符串很长,这里是定义了静态字符串常量MAPPING_TEMPLATE,让代码看起来更加优雅。
  3. 发送请求
    client.indices()方法的返回值是IndicesClient类型,封装了所有与索引库操作有关的方法。例如创建索引、删除索引、判断索引是否存在等
    测试类中,具体代码如下:
@Test
void testCreateIndex() throws IOException {// 1.创建Request对象CreateIndexRequest request = new CreateIndexRequest("items");// 2.准备请求参数request.source(MAPPING_TEMPLATE, XContentType.JSON);// 3.发送请求client.indices().create(request, RequestOptions.DEFAULT);
}static final String MAPPING_TEMPLATE = "{\n" +"  \"mappings\": {\n" +"    \"properties\": {\n" +"      \"id\": {\n" +"        \"type\": \"keyword\"\n" +"      },\n" +"      \"name\":{\n" +"        \"type\": \"text\",\n" +"        \"analyzer\": \"ik_max_word\"\n" +"      },\n" +"      \"price\":{\n" +"        \"type\": \"integer\"\n" +"      },\n" +"      \"stock\":{\n" +"        \"type\": \"integer\"\n" +"      },\n" +"      \"image\":{\n" +"        \"type\": \"keyword\",\n" +"        \"index\": false\n" +"      },\n" +"      \"category\":{\n" +"        \"type\": \"keyword\"\n" +"      },\n" +"      \"brand\":{\n" +"        \"type\": \"keyword\"\n" +"      },\n" +"      \"sold\":{\n" +"        \"type\": \"integer\"\n" +"      },\n" +"      \"commentCount\":{\n" +"        \"type\": \"integer\"\n" +"      },\n" +"      \"isAD\":{\n" +"        \"type\": \"boolean\"\n" +"      },\n" +"      \"updateTime\":{\n" +"        \"type\": \"date\"\n" +"      }\n" +"    }\n" +"  }\n" +"}";

判断索引库是否存在

判断索引库是否存在,本质就是查询,对应的请求语句是:

GET /索引库

因此与,流程如下:

  • 1)创建Request对象。这次是GetIndexRequest对象
  • 2)准备参数。这里是无参,直接省略
  • 3)发送请求。改用exists方法
@Test
void testExistsIndex() throws IOException {// 1.创建Request对象GetIndexRequest request = new GetIndexRequest("items");// 2.发送请求boolean exists = client.indices().exists(request, RequestOptions.DEFAULT);// 3.输出System.err.println(exists ? "索引库已经存在!" : "索引库不存在!");
}

删除索引库

删除索引库的请求非常简单:

DELETE /索引库

与创建索引库相比:

  • 请求方式从PUT变为DELTE
  • 请求路径不变
  • 无请求参数

所以代码的差异,注意体现在Request对象上。流程如下:

  • 1)创建Request对象。这次是DeleteIndexRequest对象
  • 2)准备参数。这里是无参,因此省略
  • 3)发送请求。改用delete方法

编写单元测试,实现删除索引:

@Test
void testDeleteIndex() throws IOException {// 1.创建Request对象DeleteIndexRequest request = new DeleteIndexRequest("items");// 2.发送请求client.indices().delete(request, RequestOptions.DEFAULT);
}

总结

JavaRestClient操作elasticsearch的流程基本类似。核心是client.indices()方法来获取索引库的操作对象。
索引库操作的基本步骤:

  • 初始化RestHighLevelClient
  • 创建XxxIndexRequest。XXX是Create、Get、Delete
  • 准备请求参数( Create时需要,其它是无参,可以省略)
  • 发送请求。调用RestHighLevelClient#indices().xxx()方法,xxx是create、exists、delete
http://www.yayakq.cn/news/994781/

相关文章:

  • 清远做网站的公司wordpress 菜单添加图片
  • 网站其它方面seo情况佛山网站建设佛山网络推广
  • 中国网站排行榜商丘柘城做网站
  • 厦门网站设计排行电商网站建设策划书
  • 网站怎么被百度收录做炭化料的网站
  • 网站 概念设计企业网站设计公司
  • 阿里云建立网站备案黄金多少钱一克
  • 什么叫手机网站陕西金顶建设公司网站
  • 手机网站报名链接怎么做wordpress 文字
  • 网站推广过程网站开发学习路线
  • 贺州 网站建设公司有哪些搭建网站的步骤和顺序
  • 公司免费网站制作做网站开票是多少个点的票
  • 大连工商网站查询企业信息wordpress 防恶意注册
  • 制作团购网站嘉兴网站搜索排名
  • 电商网站开发公司哪家好网站设计的目的是什么
  • 网站模板制作与安装教程视频教程高端网站定制商
  • 如何将自己做的网站变成中文常州制作公司网站
  • 甘肃省住房和城乡建设厅注册中心网站首页wordpress文章存在哪里
  • 网站对联广告代码中国设计师联盟官网
  • 专业的网站建设广州上市网站建设的公司
  • 修改网站空间服务器密码杭州西湖区抖音seo哪里找
  • 建自己的网站用多少钱网络系统管理员在哪里
  • 寻模板网站源码可以建网站
  • 怎么跳转网站推动高质量发展的意义
  • 微信公众号对接网站做网站开发需要的学历
  • 做网站公司有哪些网页设计素材打不开
  • 通州网站制作百度网站安全在线检测
  • 一般可以建些什么种类的网站学做衣服上什么网站好
  • 保定建设工程信息网站关键词排名优化系统
  • 网站删除期查询企业在网站建设中需要做什么