首先新建springboot项目

新建webapp目录

springboot没有webapp目录——手动添加

web.xml

 <?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<display-name>Archetype Created Web Application</display-name>
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<listener>
<listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
</listener>
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>/index</welcome-file>
</welcome-file-list>
</web-app>

spring-mvc.xml

 <?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd"> <!-- 把Controller交给spring管理 -->
<context:component-scan base-package="com.xiaostudy"/> <!-- 配置注解处理器映射器 功能:寻找执行类Controller -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/> <!-- 配置注解处理器适配器 功能:调用controller方法,执行controller -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> <!-- 不用了 -->
<!-- 配置sprigmvc视图解析器:解析逻辑试图
后台返回逻辑试图:index
视图解析器解析出真正物理视图:前缀+逻辑试图+后缀====/WEB-INF/index.jsp -->
<!--<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/"/>
<property name="suffix" value=".jsp"/>
</bean>-->
</beans>

application.yml

 spring:
application:
name: solr
data:
solr:
host: http://127.0.0.1:8983/solr/test # test是core的名字,一定需要
server:
port: 8081 # springboot项目启动的端口号

base:User.java

 package com.xiaostudy.solr_test1.base;

 import org.apache.solr.client.solrj.beans.Field;

 import java.io.Serializable;

 /**
* Created with IntelliJ IDEA.
* User: Administrator
* Date: 2019/6/2
* Time: 11:10
* Description: No Description
*/
public class User implements Serializable {
//必须实现可序列化接口,要在网络上传输
@Field("user_id")//使用这个注释,里面的名字是根据你在solr数据库中配置的来决定
private String id;
@Field("user_name")
private String name;
@Field("user_sex")
private String sex;
@Field("user_address")
private String address; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getSex() {
return sex;
} public void setSex(String sex) {
this.sex = sex;
} public String getAddress() {
return address;
} public void setAddress(String address) {
this.address = address;
}
}

controller:SolrController.java

package com.xiaostudy.solr_test1.web.controller;

import com.xiaostudy.solr_test1.base.User;
import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.client.solrj.response.UpdateResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.apache.solr.common.util.NamedList;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map; /**
* Created with IntelliJ IDEA.
* User: Administrator
* Date: 2019/6/2
* Time: 11:14
* Description: No Description
*/
@RestController
public class SolrController { @Autowired
private SolrClient solrClient; //批量增加
@RequestMapping("/addUsers")
public void addUsers() throws IOException, SolrServerException {
List<User> users = new ArrayList<>();
for(int i = 0; i < 3; i++) {
User user = new User();
user.setId("123456_" + i);
user.setName("xiaostudy_" + i);
user.setAddress("广州_" + i);
user.setSex("男_" + i);
users.add(user);
} solrClient.addBeans(users);
solrClient.commit();
}
//单个增加
@RequestMapping("/addUser")
public void addUser() throws IOException, SolrServerException {
User user = new User();
user.setId("45678");
user.setName("张三");
user.setAddress("北京市");
user.setSex("女");
solrClient.addBean(user);
solrClient.commit();
}
//根据id查询
@RequestMapping("/getByIdFromSolr/{id}")
public void getByIdFromSolr(@PathVariable("id") String id) throws IOException, SolrServerException { //根据id查询内容
SolrDocument solrDocument = solrClient.getById(id);
//获取filedName
Collection<String> fieldNames = solrDocument.getFieldNames();
//获取file名和内容
Map<String, Object> fieldValueMap = solrDocument.getFieldValueMap(); // int childDocumentCount = solrDocument.getChildDocumentCount(); List<SolrDocument> childDocuments = solrDocument.getChildDocuments(); System.out.println("byId=================="+solrDocument);
System.out.println("fieldNames=================="+fieldNames);
System.out.println("fieldValueMap=================="+fieldValueMap);
// System.out.println("childDocumentCount=================="+childDocumentCount);
System.out.println("childDocuments=================="+childDocuments); }
//根据di删除
@RequestMapping("/delById/{id}")
public void delById(@PathVariable("id") String id) throws IOException, SolrServerException {
//根据id删除信息
UpdateResponse updateResponse = solrClient.deleteById(id);
//执行的时间
long elapsedTime = updateResponse.getElapsedTime(); int qTime = updateResponse.getQTime();
//请求地址
String requestUrl = updateResponse.getRequestUrl();
//请求的结果{responseHeader={status=0,QTime=2}}
NamedList<Object> response = updateResponse.getResponse();
//请求结果的头{status=0,QTime=2}
NamedList responseHeader = updateResponse.getResponseHeader();
//请求的状态 0
int status = updateResponse.getStatus(); System.out.println("elapsedTime==========="+elapsedTime);
System.out.println("qTime==========="+qTime);
System.out.println("requestUrl==========="+requestUrl);
System.out.println("response==========="+response);
System.out.println("responseHeader==========="+responseHeader);
System.out.println("status==========="+status);
} @RequestMapping("/queryFromSolr")
public Object queryFromSolr() throws IOException, SolrServerException {
//第一种方式
// Map<String, String> queryParamMap = new HashMap<String, String>();
// queryParamMap.put("q", "*:*");
// queryParamMap.put("f1","id,name");
// queryParamMap.put("sort","id asc");
// MapSolrParams mapSolrParams = new MapSolrParams(queryParamMap);
// solrClient.query(mapSolrParams); //第二种方式
SolrQuery solrQuery = new SolrQuery();
solrQuery.setQuery("*:*");
// solrQuery.addField("*");
solrQuery.add("q","id:4567"); solrQuery.setSort("id", SolrQuery.ORDER.asc);
//设置查询的条数
solrQuery.setRows(50);
//设置查询的开始
solrQuery.setStart(0);
//设置高亮
solrQuery.setHighlight(true);
//设置高亮的字段
solrQuery.addHighlightField("item_name");
//设置高亮的样式
solrQuery.setHighlightSimplePre("<font color='red'>");
solrQuery.setHighlightSimplePost("</font>");
System.out.println(solrQuery);
QueryResponse response = solrClient.query(solrQuery);
//返回高亮显示结果
Map<String, Map<String, List<String>>> highlighting = response.getHighlighting();
//response.getResults();查询返回的结果
SolrDocumentList documentList = response.getResults();
for (SolrDocument solrDocument : documentList) {
System.out.println("solrDocument==============" +solrDocument);
}
return documentList;
}
}

测试能不能访问springboot项目,这个可以不要

IndexController.java

package com.xiaostudy.solr_test1.web.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; /**
* Created with IntelliJ IDEA.
* User: Administrator
* Date: 2019/6/2
* Time: 11:15
* Description: No Description
*/
@Controller
public class IndexController { @RequestMapping("/index")
public String index() {
return "index";
}
}

测试

所以这里提示:除了查询,增删改都要提交事务

solrClient.commit();

solrClient.addBean(new User());// 添加一个对象
solrClient.addBeans(users);// 添加多个对象
solrClient.deleteByQuery("*:*");// 删除所有索引
solrClient.deleteById("1234");// 删除id为1234的索引
solrClient.getById("1234");// 查询id为1234的索引

参考文章:https://blog.csdn.net/weixin_42129558/article/details/82682265

springboot和solr结合测试使用的更多相关文章

  1. springboot区分开发、测试、生产多环境的应用配置(二)

    转:https://www.jb51.net/article/139119.htm springboot区分开发.测试.生产多环境的应用配置(二) 这篇文章主要给大家介绍了关于maven profil ...

  2. springboot区分开发、测试、生产多环境的应用配置

    转:https://blog.csdn.net/daguairen/article/details/79236885 springboot区分开发.测试.生产多环境的应用配置(一) Spring可使用 ...

  3. springboot整合solr

    上一篇博客中简要写了solr在windows的安装与配置,这一篇接上文写一下springboot整合solr,代码已经上传到github,传送门. 1.新建core并配置schema 上篇博客中已经有 ...

  4. SpringBoot项目构建、测试、热部署、配置原理、执行流程

    SpringBoot项目构建.测试.热部署.配置原理.执行流程 一.项目构建 二.测试和热部署 三.配置原理 四.执行流程

  5. solr8.0 springboot整合solr(四)

    引言: solr搭建起后,就该应用到java后台开发里了,接下来就用springboot整合应用solr 一:引入jar包 <!--solr--> <dependency> & ...

  6. SpringBoot Maven项目 Helloworld 测试

    SpringBoot 化繁为简,简化配置 SpringBoot官方:http://projects.spring.io/spring-boot/SpringBoot使用介绍:http://blog.c ...

  7. springBoot单元测试-模拟MVC测试

    1)模拟mvc测试,和基础测试是一样的, 都需要在pom文件中引入junit的支持. 略 2)编写测试类 Application1TestMVC 在类头上除啦加入之前的@RunWith(SpringR ...

  8. SpringBoot中使用 RabbitMQ -测试

    本章主要建立在已经安装好Erlang以及RabbitMQ的基础上,接下来,简单介绍一下使用 1.首先到RabbitMQ的管理界面新建一个队列(Direct模式) 2.测试项目的基础结构如下: 这里为了 ...

  9. SpringBoot整合MongoDB JPA,测试MongoRepository与MongoTemplate用法,简单增删改查+高级聚合

    源码 地址 -> https://github.com/TaoPanfeng/case/tree/master/04-mongo/springboot-mongo 一 引入依赖 <depe ...

随机推荐

  1. springboot启动时执行任务CommandLineRunner

    # SpringBoot中CommandLineRunner的作用> 平常开发中有可能需要实现在项目启动后执行的功能,SpringBoot提供的一种简单的实现方案就是添加一个model并实现Co ...

  2. Oracle 与 postgreSQL 事务处理区别(多版本与undo区别)

    2015年左右,因为工作需要用MongoDB.CouchBase这两种文档型数据库,时不时到这两个数据库官网上查资料.报BUG.时常可以在MongoDB官网上看到这样一些新闻,“某某企业成功将MySQ ...

  3. 081_使用 awk 编写的 wc 程序

    #!/bin/bash#自定义变量 chars 变量存储字符个数,自定义变量 words 变量存储单词个数#awk 内置变量 NR 存储行数#length()为 awk 内置函数,用来统计每行的字符数 ...

  4. 三十.数据库服务概述 构建MySQL服务器 、 数据库基本管理 MySQL数据类型

    mysql50:192.168.4.50 1.构建MySQL服务器 安装MySQL-server.MySQl-client软件包 修改数据库用户root的密码 确认MySQL服务程序运行.root可控 ...

  5. dashucoding记录2019.6.6

    div { display:flex; flex-direction:row-reverse; } -webkit-, - ms-或-moz- CSS语法 flex-direction: row|ro ...

  6. git 代码回滚与爬坑 -- reset and revert

    本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/git_code_roll_back_revert_and_res ...

  7. P1338 末日的传说,P1372 P1414 又是毕业季——贪心

    一个1到n序列,合理排序逆序对数要求是m,而且字典序要求最小: 这个题,因为数字只能用一次,所以我们可以知道什么位置放什么数逆序对的个数会增加或减少多少: 先求出最多能产生的数量,每次先输出最小的数, ...

  8. kde的配置文件

    主要是home目录下:/.kde4/share/config/ 如果实在是搞不定,还可以直接将.kde4目录全部删除或者替换即可.

  9. ElasticSearch 6 安装、下载

    1,安装配置JDK 8 参考:官方文档 #为什么是JDK1.8?在ElasticSearch6.2.4中提到:JDK版本必须为:1.8.0_131 以上 > 1,安装JDK1.8-161 #解压 ...

  10. MacOS系统降级

    从MacOS 10.14 降级到 10.12,下载好系统镜像文件.打开,复制到Application. 准备一个至少8G的U盘,,打开磁盘工具,『抹掉』(格式化)成Mac OS扩展(日志式),名称可随 ...