<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <!-- 设置编码 -->
<filter>
<filter-name>charset</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>
</filter>
<filter-mapping>
<filter-name>charset</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <!-- springmvc核心配置 -->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置springmvc核心文件的路径 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet> <servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.test</url-pattern>
</servlet-mapping> </web-app>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 包扫描 -->
<context:component-scan base-package="zr.com"/>
<!-- 开启SpringMVC的相关注解 -->
<mvc:annotation-driven/> <!-- 视图解析器 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean> </beans>
package zr.com.pojo;

public class Info {

    private String id;

    private String courseID;

    private String courseName;

    private String courseContent;

    private String schoolName;

    private String schoolShortName;

    private String classID;

    private String className;

    private String courseprice;

    private String courseAreaID;

    private String areaName;

    private String OrderNum;

    private String HotScoreAvg;

    public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} public String getCourseID() {
return courseID;
} public void setCourseID(String courseID) {
this.courseID = courseID;
} public String getCourseName() {
return courseName;
} public void setCourseName(String courseName) {
this.courseName = courseName;
} public String getCourseContent() {
return courseContent;
} public void setCourseContent(String courseContent) {
this.courseContent = courseContent;
} public String getSchoolName() {
return schoolName;
} public void setSchoolName(String schoolName) {
this.schoolName = schoolName;
} public String getSchoolShortName() {
return schoolShortName;
} public void setSchoolShortName(String schoolShortName) {
this.schoolShortName = schoolShortName;
} public String getClassID() {
return classID;
} public void setClassID(String classID) {
this.classID = classID;
} public String getClassName() {
return className;
} public void setClassName(String className) {
this.className = className;
} public String getCourseprice() {
return courseprice;
} public void setCourseprice(String courseprice) {
this.courseprice = courseprice;
} public String getCourseAreaID() {
return courseAreaID;
} public void setCourseAreaID(String courseAreaID) {
this.courseAreaID = courseAreaID;
} public String getAreaName() {
return areaName;
} public void setAreaName(String areaName) {
this.areaName = areaName;
} public String getOrderNum() {
return OrderNum;
} public void setOrderNum(String orderNum) {
OrderNum = orderNum;
} public String getHotScoreAvg() {
return HotScoreAvg;
} public void setHotScoreAvg(String hotScoreAvg) {
HotScoreAvg = hotScoreAvg;
} public Info() {
super();
} public Info(String id, String courseID, String courseName,
String courseContent, String schoolName, String schoolShortName,
String classID, String className, String courseprice,
String courseAreaID, String areaName, String orderNum,
String hotScoreAvg) {
super();
this.id = id;
this.courseID = courseID;
this.courseName = courseName;
this.courseContent = courseContent;
this.schoolName = schoolName;
this.schoolShortName = schoolShortName;
this.classID = classID;
this.className = className;
this.courseprice = courseprice;
this.courseAreaID = courseAreaID;
this.areaName = areaName;
OrderNum = orderNum;
HotScoreAvg = hotScoreAvg;
} @Override
public String toString() {
return "Info [id=" + id + ", courseID=" + courseID + ", courseName="
+ courseName + ", courseContent=" + courseContent
+ ", schoolName=" + schoolName + ", schoolShortName="
+ schoolShortName + ", classID=" + classID + ", className="
+ className + ", courseprice=" + courseprice
+ ", courseAreaID=" + courseAreaID + ", areaName=" + areaName
+ ", OrderNum=" + OrderNum + ", HotScoreAvg=" + HotScoreAvg
+ "]";
} }
package zr.com.util;

import java.util.ArrayList;
import java.util.List;
import java.util.Map; import org.apache.solr.client.solrj.SolrQuery;
import org.apache.solr.client.solrj.SolrServer;
import org.apache.solr.client.solrj.SolrServerException;
import org.apache.solr.client.solrj.SolrQuery.ORDER;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.client.solrj.response.QueryResponse;
import org.apache.solr.common.SolrDocument;
import org.apache.solr.common.SolrDocumentList;
import org.junit.Test; import zr.com.pojo.Info; public class SearchUtil { private static SolrServer server; static{
server = new HttpSolrServer("http://192.168.10.105:18080");
}
/**
* 查询
* @throws SolrServerException
*/
public static List<Info> queryTest(String queryString,int star,int size) throws SolrServerException{ List<Info> infos = new ArrayList<Info>(); // 建立请求
// SolrServer server = new HttpSolrServer("http://192.168.10.105:18080");
// 创建查询对象
SolrQuery query = new SolrQuery();
// 查询语句的处理(模糊查询,添加双引号即可)
String queryStr = queryString; // 设置高亮显示
// 是否设置高亮
query.setHighlight(true);
// 前缀
query.setHighlightSimplePre("<em>");
// 后缀
query.setHighlightSimplePost("</em>");
// 设置高亮文本的长度
query.setHighlightFragsize(8);
query.setHighlightRequireFieldMatch(true);
// 设置高亮的字段
query.addHighlightField("courseName"); query.setQuery(queryStr); // 分页(起始位置)
query.setStart(star);
// 分页(每一页显示的条数)
query.setRows(size);
// // 排序(降序)
// query.setSort("courseName", ORDER.desc); //执行查询
QueryResponse response = server.query(query);
// 获取高亮的信息
Map<String, Map<String, List<String>>> map = response.getHighlighting(); System.out.println(map); //执行查询
// QueryResponse response = server.query(query);
// 获取响应后的结果集
SolrDocumentList list = response.getResults();
for (SolrDocument solrDocument : list) {
// 获取ID
String id = SearchUtil.dealNull(solrDocument, "id");
String courseID = SearchUtil.dealNull(solrDocument, "courseID");
String courseName = SearchUtil.dealNull(solrDocument, "courseName");
String courseContent = SearchUtil.dealNull(solrDocument, "courseContent");
String schoolName = SearchUtil.dealNull(solrDocument, "schoolName");
String schoolShortName = SearchUtil.dealNull(solrDocument, "schoolShortName");
String classID = SearchUtil.dealNull(solrDocument, "classID");
String className = SearchUtil.dealNull(solrDocument, "className");
String courseprice = SearchUtil.dealNull(solrDocument, "courseprice");
String courseAreaID = SearchUtil.dealNull(solrDocument, "courseAreaID");
String areaName = SearchUtil.dealNull(solrDocument, "areaName");
String OrderNum = SearchUtil.dealNull(solrDocument, "OrderNum");
String HotScoreAvg = SearchUtil.dealNull(solrDocument, "HotScoreAvg");
// 高亮替换
Map<String, List<String>> hlisMap = map.get(id);
if (hlisMap!=null) {
// System.out.println(hlisMap);
Object cName = hlisMap.get("courseName");
if (cName!=null) {
// 替换
courseName = cName.toString();
}
}
Info info = new Info(id, courseID, courseName, courseContent, schoolName, schoolShortName, classID, className, courseprice, courseAreaID, areaName, OrderNum, HotScoreAvg);
infos.add(info);
// System.out.println("id:"+id+",courseName:"+courseName+",schoolShortName:"+schoolShortName);
}
return infos;
} /**
* 处理空异常
* @return
*/
private static String dealNull(SolrDocument solrDocument,String field){
String fieldValue = null;
if (solrDocument.getFieldValue(field) != null) {
fieldValue = solrDocument.getFieldValue(field).toString();
}
return fieldValue;
}
}
package zr.com.controller;

import java.io.IOException;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.util.List; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.apache.solr.client.solrj.SolrServerException;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod; import com.alibaba.fastjson.JSON; import zr.com.pojo.Info;
import zr.com.util.SearchUtil; /**
*
* @author lf
*
*/
@Controller
public class SolrController {
/**
* 进入search页面
* @return
*/
@RequestMapping("/lf")
public String comeInPage(){
return "search";
} /**
* 获取数据
* @param paramter
* @param request
* @param response
* @throws SolrServerException
* @throws IOException
*/
@RequestMapping(value="search",method=RequestMethod.GET)
public void getData(String paramter,HttpServletRequest request,HttpServletResponse response)
throws SolrServerException, IOException{
// 设置编码
// request.setCharacterEncoding("utf-8");
// response.setCharacterEncoding("utf-8");
System.out.println("准备获取相关数据...");
System.out.println("paramter:"+paramter);
String query = "courseName:"+paramter;
// 获取响应的数据数据
List<Info> infos = SearchUtil.queryTest(query,0,10);
// 遍历
// for (Info info : infos) {
// System.out.println(info);
// }
//设置文本类型的编码为UTF-8
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
String jsonString = JSON.toJSONString(infos); // 输出
out.print(jsonString);
out.flush();
out.close(); System.out.println(jsonString);
} }
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>搜索引擎</title>
</head>
<body>
<br><br><br>
<div>
<input id="search" placeholder="请输入你要搜索的内容" />
<button onclick="getData()">搜索</button>
<br>
<table id="table">
</table> </div>
<style type="text/css">
em {color:red;} </style>
<script type="text/javascript"> // 异步请求
function getData(){ var value = document.getElementById("search").value; // 创建请求对象
var request = new XMLHttpRequest();
// 请求方式
var method = "GET";
// 链接
var url = "search.test?paramter="+value;
/* alert(url); */
// 初始化参数
request.open(method, url, true);
// 发送请求
request.send(null);
request.onreadystatechange = function(){
// 如果响应请求
if(request.status==200 || request.status == 304){
var text = request.responseText;
var jsonData = eval("("+text+")");
// 获取table
var table = document.getElementById("table");
/* alert(jsonData); */
// 清除table的数据
var rowNum=table.rows.length;
for (var i=0;i<rowNum;i++)
{ table.deleteRow(i);
rowNum=rowNum-1;
i=i-1;
}
// 添加数据
for(var i = 0;i < jsonData.length;i++ ){
// 添加行
var row = table.insertRow();
// 添加单元格
var cell = row.insertCell();
// 设置内容
cell.innerHTML = jsonData[i]["areaName"]+jsonData[i]["className"]
+jsonData[i]["courseAreaID"]+jsonData[i]["courseContent"]
+jsonData[i]["courseID"]+jsonData[i]["courseName"]
+jsonData[i]["courseprice"]+jsonData[i]["hotScoreAvg"]
+jsonData[i]["id"]+jsonData[i]["orderNum"]
+jsonData[i]["schoolName"]+jsonData[i]["schoolShortName"]
+jsonData[i]["classID"]+jsonData[i]["className"]
+jsonData[i]["courseAreaID"]+jsonData[i]["HotScoreAvg"];
} }
}; } </script> </body>
</html>

solr开发 小案例的更多相关文章

  1. Cloudera5.8.3:Flume+Morphline+Solr开发小技巧

    1.Flume和Morphline添加日志打印 log4j.logger.org.apache.flume.sink.solr=DEBUG log4j.logger.org.kitesdk.morph ...

  2. WinFrom开发小案例

    C# 开发环境: VisualStudio2015 数据库: SQLserver2008 程序主界面: 注释: lbl标签: 程序中的lbl标签:编号.人数.姓名.性别.请输入要查询的信息,这里他们只 ...

  3. 20160410javaweb 开发小案例 --客户管理系统

    客户管理系统---体验基于数据库javaweb的增删改查 添加客户 查询客户列表 修改客户信息 删除客户 条件查询客户信息 分页查询客户 javaee的经典三层架构--工厂类实现解耦 jsp+serv ...

  4. (24/24) webpack小案例--自己动手用webpack构建一个React的开发环境

    通过前面的学习,对webpack有了更深的认识,故此节我们就利用前面相关知识自己动手用webpack构建一个React的开发环境,就算是一个小案例吧. 注:此处使用的开发工具是Webstorm. 1. ...

  5. Vue3教程:用 Vue3 开发小程序,这里有一份实际的代码案例!

    前言 寻寻觅觅冷冷清清,凄凄惨惨戚戚. Vue 3 发布以后,最近也在学习和写一些 Vue3 的 demo 和项目,我也一直想着什么时候能在小程序里使用新特性? 于是我翻遍了市面上的小程序框架,如 u ...

  6. 广播小案例-监听系统网络状态 --Android开发

    本例通过广播实现简单的监听系统网络状态改变的小案例. 1.案例效果演示 当手机连网后,系统提示“已连接网络”, 当手机断网后,系统提示“当前网络不可用”. 2.案例实现 在主活动中动态注册广播,然后写 ...

  7. Session小案例------完成用户登录

    Session小案例------完成用户登录     在项目开发中,用户登陆功能再平常只是啦,当用户完毕username和password校验后.进入主界面,须要在主界面中显示用户的信息,此时用ses ...

  8. MVC 小案例 -- 信息管理

    前几次更新博客都是每次周日晚上到周一,这次是周一晚上开始写,肯定也是有原因的!那就是我的 Tomact 忽然报错,无法启动,错误信息如下!同时我的 win10 也崩了,重启之后连 WIFI 的标志也不 ...

  9. Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例

    Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例 继上篇json解析,我用了原生的json解析,但是在有些情况下我们不得不承认,一些优秀的json解析框架确实十分的 ...

随机推荐

  1. [QT][转载]Qt:使用C++还是QML

    From: http://blog.csdn.net/rl529014/article/details/51378734 本质上,Qt 是一个C++类库.在引入 QML 以前,所有的开发都是基于 C+ ...

  2. Python之contextlib库及源码分析

    Utilities for with-statement contexts __all__ = ["contextmanager", "closing", &q ...

  3. 【JQuery】学习

    JavaScript参考 JQuery 学习总结及实例 1.JQuery概念 A.Jquery是一个优秀的Javascript框架.它是轻量级的js库 ,它兼容CSS3,还兼容各种浏览器,jQuery ...

  4. hadoop文件IO

    InputStreamReader 是字节流通向字符流的桥梁:它使用指定的 charset 读取字节并将其解码为字符.它使用的字符集可以由名称指定或显式给定,或者可以接受平台默认的字符集. Input ...

  5. SharePoint 创建列表并使用Windows Presentation Foundation应用程序管理列表

    SharePoint创建列表并使用程序管理列表         列表是SharePoint开发者输入数据的方式之中的一个.使用Web界面创建一个列表并加入一些数据.过程例如以下: 1. 打开站点. 2 ...

  6. ZenCoding[Emmet]語法簡介【轉】

    快速指南 下面是一些常用的Zen Coding功能,目前VS2013的Web Essentials插件已经支持. '#' 创建一个id特性 '.' 创建一个类特性 '[]' 创建一个自定义特性 '&g ...

  7. ELK之kibana的web报错[request] Data too large, data for [<agg [2]>] would be larger than limit of

    http://blog.51cto.com/11819159/1926411 ELK架构:elasticsearch+kibana+filebeat 版本信息: elasticsearch 5.2.1 ...

  8. unidac使用演示

    unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...

  9. 【转】Jenkins+Ant+Jmeter搭建持续集成的接口测试平台

    一.什么是接口测试? 接口测试是测试系统组件间接口的一种测试.接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点.测试的重点是要检查数据的交换,传递和控制管理过程,以及系统间的相互逻 ...

  10. 2016女生赛 HDU 5710 Digit-Sum(数学,思维题)

    Digit-Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total S ...