站酷高高手,买了个网站后怎么做,建设好网站如何上传百度,株洲正规竞价优化推荐文章目录 一、概念1、什么是Solr2、与Lucene的比较区别1#xff09;Lucene2#xff09;Solr 二、Solr的安装与配置1、Solr的下载2、Solr的文件夹结构3、运行环境4、Solr整合tomcat1#xff09;Solr Home与SolrCore2#xff09;整合步骤 5、Solr管理后台1#xff09;Dashbo… 文章目录 一、概念1、什么是Solr2、与Lucene的比较区别1Lucene2Solr 二、Solr的安装与配置1、Solr的下载2、Solr的文件夹结构3、运行环境4、Solr整合tomcat1Solr Home与SolrCore2整合步骤 5、Solr管理后台1Dashboard2Logging3Cloud4Core Admin5 java properties6Tread Dump7Core selector8Analysis9Dataimport10Document11Query 6、配置中文分析器1Schema.xml1. FieldType域类型定义2. Field定义3. uniqueKey4. copyField复制域5. dynamicField动态字段 2安装使用IKAnalyzer中文分词器 三、Solr管理索引库不推荐1、添加/更新文档2、批量导入数据3、删除文档4、查询文档 四、使用SolrJ管理索引库1、什么是solrJ2、创建Java工程导入jar包3、添加文档4、删除文档5、修改文档6、查询文档 五、案例实现1、创建一个web工程导入jar包2、配置xml文件3、导入jsp页面和css4、具体代码实现 一、概念
1、什么是Solr
Solr 是Apache下的一个顶级开源项目采用Java开发它是基于Lucene的全文搜索服务器。Solr提供了比Lucene更为丰富的查询语言同时实现了可配置、可扩展并对索引、搜索性能进行了优化。
Solr可以独立运行运行在Jetty、Tomcat等这些Servlet容器中Solr 索引的实现方法很简单用 POST 方法向 Solr 服务器发送一个描述 Field 及其内容的 XML 文档Solr根据xml文档添加、删除、更新索引 。Solr 搜索只需要发送 HTTP GET 请求然后对 Solr 返回Xml、json等格式的查询结果进行解析组织页面布局。Solr不提供构建UI的功能Solr提供了一个管理界面通过管理界面可以查询Solr的配置和运行情况。
2、与Lucene的比较区别
1Lucene
Lucene是一个开放源代码的全文检索引擎工具包它不是一个完整的全文检索引擎Lucene提供了完整的查询引擎和索引引擎目的是为软件开发人员提供一个简单易用的工具包以方便的在目标系统中实现全文检索的功能或者以Lucene为基础构建全文检索引擎。
单独使用Lucene实现站内搜索需要开发的工作量较大主要表现在索引维护、索引性能优化、搜索性能优化等因此不建议采用。
2Solr
Solr的目标是打造一款企业级的搜索引擎系统它是一个搜索引擎服务可以独立运行通过Solr可以非常快速的构建企业的搜索引擎通过Solr也可以高效的完成站内搜索功能。
基于Solr实现站内搜索扩展性较好并且可以减少程序员的工作量因为Solr提供了较为完备的搜索引擎解决方案因此在门户、论坛等系统中常用此方案。
二、Solr的安装与配置
1、Solr的下载
从Solr官方网站http://lucene.apache.org/solr/ 下载Solr4.10.3根据Solr的运行环境Linux下需要下载lucene-4.10.3.tgzwindows下需要下载lucene-4.10.3.zip。
Solr使用指南可参考https://wiki.apache.org/solr/FrontPage。
2、Solr的文件夹结构
将solr-4.10.3.zip解压后目录如下
binsolr的运行脚本contribsolr的一些贡献软件/插件用于增强solr的功能。dist该目录包含build过程中产生的war和jar文件以及相关的依赖文件。docssolr的API文档examplesolr工程的例子目录 example/solr该目录是一个包含了默认配置信息的Solr的Core目录。 example/multicore该目录包含了在Solr的multicore中设置的多个Core目录。 example/webapps 该目录中包括一个solr.war该war可作为solr的运行实例工程。licensessolr相关的一些许可信息
3、运行环境
solr 需要运行在一个Servlet容器中Solr4.10.3要求jdk使用1.7以上Solr默认提供Jettyjava写的Servlet容器本教程使用Tocmat作为Servlet容器环境如下
SolrSolr4.10.3Jdkjdk1.8.0_72Tomcatapache-tomcat-7.0.53
4、Solr整合tomcat
1Solr Home与SolrCore
创建一个Solr home目录SolrHome是Solr运行的主目录目录中包括了运行Solr实例所有的配置文件和数据文件Solr实例就是SolrCore一个SolrHome可以包括多个SolrCoreSolr实例每个SolrCore提供单独的搜索和索引服务。
example\solr是一个solr home目录结构如下 上图中“collection1”是一个SolrCoreSolr实例目录 目录内容如下所示 说明 collection1是一个Solr运行实例SolrCoreSolrCore名称不固定一个solr运行实例对外单独提供索引和搜索接口。 solrHome中可以创建多个solr运行实例SolrCore。 一个solr的运行实例对应一个索引目录 conf是SolrCore的配置文件目录 。 data目录存放索引文件需要创建 2整合步骤
第一步安装tomcat。第二步把solr的war包复制到tomcat 的webapp目录下。第三步solr.war解压。第四步把\solr-4.10.3\example\lib\ext目录下的所有的jar包添加到solr工程中的WEB-INF\lib。第五步配置solrHome和solrCore。 1创建一个solrhome存放solr所有配置文件的一个文件夹。 2把\solr-4.10.3\example\solr文件夹复制到solrhome文件夹中文件夹名字没规定是这个是为了便于理解。第六步告诉solr服务器配置文件也就是solrHome的位置。修改solr工程中的web.xml。 Solr/home名称必须是固定的。 第七步启动tomcat第八步访问http://localhost:8090/solr/
5、Solr管理后台 1Dashboard
仪表盘显示了该Solr实例开始启动运行的时间、版本、系统资源、jvm等信息。
2Logging
Solr运行日志信息
3Cloud
Cloud即SolrCloud即Solr云集群当使用Solr Cloud模式运行时会显示此菜单。
4Core Admin
Solr Core的管理界面。Solr Core 是Solr的一个独立运行实例单位它可以对外提供索引和搜索服务一个Solr工程可以运行多个SolrCoreSolr实例一个Core对应一个索引目录。
添加solrcore
第一步复制collection1改名为collection2第二步修改core.properties。namecollection2第三步重启tomcat
5 java properties
Solr在JVM 运行环境中的属性信息包括类路径、文件编码、jvm内存设置等信息。
6Tread Dump
显示Solr Server中当前活跃线程信息同时也可以跟踪线程运行栈信息。
7Core selector
选择一个SolrCore进行详细操作如下
8Analysis 通过此界面可以测试索引分析器和搜索分析器的执行情况。
9Dataimport
可以定义数据导入处理器从关系数据库将数据导入 到Solr索引库中。
10Document
通过此菜单可以创建索引、更新索引、删除索引等操作界面如下 /update表示更新索引solr默认根据id唯一约束域来更新Document的内容如果根据id值搜索不到id域则会执行添加操作如果找到则更新。
11Query 通过/select执行搜索索引必须指定“q”查询条件方可搜索。
6、配置中文分析器
1Schema.xml
schema.xml在SolrCore的conf目录下它是Solr数据表配置文件它定义了加入索引的数据的数据类型的。主要包括FieldTypes、Fields和其他的一些缺省设置。
1. FieldType域类型定义
“text_general”是Solr默认提供的FieldType通过它说明FieldType定义的内容 FieldType子结点包括name,class,positionIncrementGap等一些参数
name是这个FieldType的名称class是Solr提供的包solr.TextFieldsolr.TextField 允许用户通过分析器来定制索引和查询分析器包括一个分词器tokenizer和多个过滤器filterpositionIncrementGap可选属性定义在同一个文档中此类型数据的空白间隔避免短语匹配错误此值相当于Lucene的短语查询设置slop值根据经验设置为100。
在FieldType定义的时候最重要的就是定义这个类型的数据在建立索引和进行查询的时候要使用的分析器analyzer包括分词和过滤
索引分析器使用solr.StandardTokenizerFactory标准分词器solr.StopFilterFactory停用词过滤器solr.LowerCaseFilterFactory小写过滤器。搜索分析器使用solr.StandardTokenizerFactory标准分词器solr.StopFilterFactory停用词过滤器这里还用到了solr.SynonymFilterFactory同义词过滤器。
2. Field定义
在fields结点内定义具体的Fieldfiled定义包括name,type为之前定义过的各种FieldType,indexed是否被索引,stored是否被储存multiValued是否存储多个值等属性如下
field namename typetext_general indexedtrue storedtrue/
field namefeatures typetext_general indexedtrue storedtrue multiValuedtrue/multiValued该Field如果要存储多个值时设置为truesolr允许一个Field存储多个值比如存储一个用户的好友id多个商品的图片多个大图和小图通过使用solr查询要看出返回给客户端是数组
3. uniqueKey
Solr中默认定义唯一主键key为id域如下 Solr在删除、更新索引时使用id域进行判断也可以自定义唯一主键。 注意在创建索引时必须指定唯一约束
4. copyField复制域
copyField复制域可以将多个Field复制到一个Field中以便进行统一的检索比如输入关键字搜索title标题内容content定义title、content、text的域 根据关键字只搜索text域的内容就相当于搜索title和content将title和content复制到text中如下
5. dynamicField动态字段
动态字段就是不用指定具体的名称只要定义字段名称的规则例如定义一个 dynamicFieldname 为*_i定义它的type为text那么在使用这个字段的时候任何以_i结尾的字段都被认为是符合这个定义的例如name_igender_ischool_i等。
a、自定义Field名为product_title_t“product_title_t”和scheam.xml中的dynamicField规则匹配成功如下“product_title_t”是以“_t”结尾。 b、创建索引 c、搜索索引
2安装使用IKAnalyzer中文分词器
第一步把IKAnalyzer2012FF_u1.jar添加到solr/WEB-INF/lib目录下。第二步复制IKAnalyzer的配置文件和自定义词典和停用词词典到solr的classpath在web-inf中自建的下。第三步在schema.xml中添加一个自定义的fieldType使用中文分析器。
!-- IKAnalyzer--
fieldType nametext_ik classsolr.TextFieldanalyzer classorg.wltea.analyzer.lucene.IKAnalyzer/
/fieldType第四步定义field指定field的type属性为text_ik
!--IKAnalyzer Field--
field nametitle_ik typetext_ik indexedtrue storedtrue /
field namecontent_ik typetext_ik indexedtrue storedfalse multiValuedtrue/第五步重启tomcat
测试效果
三、Solr管理索引库不推荐
1、添加/更新文档
添加或更新单个文档
2、批量导入数据
使用dataimport插件批量导入数据。
第一步把dataimport插件依赖的jar包以及mysql的数据库驱动包 添加到solrhome\collection1\lib中 第二步配置solrhome\collection1\conf路径下的solrconfig.xml文件添加一个requestHandler。
requestHandler name/dataimport
classorg.apache.solr.handler.dataimport.DataImportHandlerlst namedefaultsstr nameconfigdata-config.xml/str/lst/requestHandler第三步创建一个data-config.xml保存到collection1\conf\目录下
?xml version1.0 encodingUTF-8 ?
dataConfig
dataSource typeJdbcDataSource drivercom.mysql.jdbc.Driver urljdbc:mysql://localhost:3306/lucene userroot password123/
document entity nameproduct querySELECT pid,name,catalog_name,price,description,picture FROM products field columnpid nameid/ field columnname nameproduct_name/ field columncatalog_name nameproduct_catalog_name/ field columnprice nameproduct_price/ field columndescription nameproduct_description/ field columnpicture nameproduct_picture/ /entity
/document
/dataConfig第四步这里还没有lucene数据库创建一个然后导入sql文件。第五步data-config.xml里面的字段还没映射配置schema.xml
!--product--field nameproduct_name typetext_ik indexedtrue storedtrue/field nameproduct_price typefloat indexedtrue storedtrue/field nameproduct_description typetext_ik indexedtrue storedfalse /field nameproduct_picture typestring indexedfalse storedtrue /field nameproduct_catalog_name typestring indexedtrue storedtrue /field nameproduct_keywords typetext_ik indexedtrue storedfalse multiValuedtrue/copyField sourceproduct_name destproduct_keywords/copyField sourceproduct_description destproduct_keywords/第六步重启tomcat 第七步点击“execute”按钮导入数据 导入数据前会先清空索引库然后再导入。
3、删除文档
1 删除制定ID的索引
delete
id8/id
/delete
commit/2 删除查询到的索引数据
delete
queryproduct_catalog_name:幽默杂货/query
/delete3 删除所有索引数据 delete
query*:*/query
/delete4、查询文档
通过/select搜索索引Solr制定一些参数完成不同需求的搜索 1.q - 查询字符串必须的如果查询所有使用例如 2.fq-filter query过虑查询作用在q查询符合结果中同时是fq查询符合的例如 过滤查询价格从1到20的记录。 也可以在“q”查询条件中使用product_price:[1 TO 20]例如 也可以使用“*”表示无限例如
20以上product_price:[20 TO *]20以下product_price:[* TO 20]
3.sort - 排序格式sortdesc|asc[,desc|asc]… 。示例 4.start - 分页显示使用开始记录下标从0开始 5.rows - 指定返回结果最多有多少条记录配合start来实现分页 显示前10条
6.fl - 指定返回那些字段内容用逗号或空格分隔多个。 7.df-指定一个搜索Field 也可以在SolrCore目录 中conf/solrconfig.xml文件中指定默认搜索Field指定后就可以直接在“q”查询条件中输入关键字。 8.wt - (writer type)指定输出格式可以有 xml, json, php, phps, 后面 solr 1.3增加的要用通知我们因为默认没有打开。 9.hl 是否高亮 ,设置高亮Field设置格式前缀和后缀。
四、使用SolrJ管理索引库
1、什么是solrJ
solrj是访问Solr服务的java客户端提供索引和搜索的请求方法SolrJ通常在嵌入在业务系统中通过SolrJ的API接口操作Solr服务如下图
2、创建Java工程导入jar包
依赖的jar包 新建一个java文件SolrManager方便后续操作
import org.apache.solr.client.solrj.SolrServer;
import org.apache.solr.client.solrj.impl.HttpSolrServer;
import org.apache.solr.common.SolrInputDocument;
import org.junit.Test;public class SolrManager {}3、添加文档
Test
public void testadd() throws Exception{String baseURLhttp://localhost:8090/solr;SolrServer solrServernew HttpSolrServer(baseURL);SolrInputDocument doc new SolrInputDocument();doc.setField(id, 123);doc.setField(name, 林格);//添加solrServer.add(doc);solrServer.commit();
}
4、删除文档
根据id删除
//删除文档根据id删除
Test
public void deleteDocumentByid() throws Exception {//创建连接SolrServer solrServer new HttpSolrServer(http://localhost:8090/solr);//根据id删除文档solrServer.deleteById(123);//提交修改solrServer.commit();
}根据查询删除
//根据查询条件删除文档
Test
public void deleteDocumentByQuery() throws Exception {//创建连接SolrServer solrServer new HttpSolrServer(http://localhost:8090/solr);//根据查询条件删除文档solrServer.deleteByQuery(*:*);//提交修改solrServer.commit();
}5、修改文档
在solrJ中修改没有update方法只有add方法我们只需要添加一条新的文档和被修改的文档id一致就可以修改了。本质上就是先删除后添加。
6、查询文档
//简单查询
Test
public void queryIndex() throws Exception{//创建连接SolrServer solrServer new HttpSolrServer(http://localhost:8090/solr);//创建一个query对象SolrQuery query new SolrQuery();//设置查询条件query.setQuery(*:*);//执行查询QueryResponse queryResponse solrServer.query(query);//得到查询结果SolrDocumentList solrDocumentList queryResponse.getResults();//查询到的商品数量System.out.println(共查询到商品数量: solrDocumentList.getNumFound());for (SolrDocument solrDocument : solrDocumentList) {System.out.println(solrDocument.get(id));System.out.println(solrDocument.get(product_name));System.out.println(solrDocument.get(product_price));System.out.println(solrDocument.get(product_catalog_name));System.out.println(solrDocument.get(product_picture));}
}
复杂查询其中包含查询、过滤、分页、排序、高亮显示等处理。
//复杂查询
Test
public void queryIndex2() throws Exception{//创建连接SolrServer solrServer new HttpSolrServer(http://localhost:8090/solr);//创建一个query对象SolrQuery query new SolrQuery();//设置查询条件query.setQuery(台灯);//过滤条件query.set(fq,product_catalog_name:雅致灯饰);//排序query.addSort(product_price,ORDER.desc);//分页query.setStart(0);query.setRows(10);//指定返回那些字段内容query.setFields(id,product_name,product_price,product_catalog_name,product_picture);//指定一个搜索Fieldquery.set(df, product_name);//高亮显示query.setHighlight(true);//高亮显示的域query.addHighlightField(product_name);//高亮显示的前缀query.setHighlightSimplePre(em);//高亮显示的后缀query.setHighlightSimplePost(/em);//执行查询QueryResponse queryResponse solrServer.query(query);//得到查询结果SolrDocumentList solrDocumentList queryResponse.getResults();//查询到的商品数量System.out.println(共查询到商品数量: solrDocumentList.getNumFound()); for (SolrDocument solrDocument : solrDocumentList) {System.out.println(solrDocument.get(id));//取高亮显示String productName ;MapString, MapString, ListString highlighting queryResponse.getHighlighting();ListString list highlighting.get(solrDocument.get(id)).get(product_name);//判断是否有高亮内容if (null ! list) {productName list.get(0);} else {productName (String) solrDocument.get(product_name);}System.out.println(solrDocument.get(productName));System.out.println(solrDocument.get(product_price));System.out.println(solrDocument.get(product_catalog_name));System.out.println(solrDocument.get(product_picture));}}五、案例实现
原型分析 系统架构 具体工程搭建实现如下
1、创建一个web工程导入jar包
springmvc的相关jar包solrJ的jar包Example\lib\ext下的jar包
2、配置xml文件
配置web.xml
?xml version1.0 encodingUTF-8?
web-app xmlns:xsihttp://www.w3.org/2001/XMLSchema-instance xmlnshttp://java.sun.com/xml/ns/javaee xsi:schemaLocationhttp://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd idWebApp_ID version2.5display-namejd/display-namewelcome-file-listwelcome-fileindex.html/welcome-filewelcome-fileindex.htm/welcome-filewelcome-fileindex.jsp/welcome-filewelcome-filedefault.html/welcome-filewelcome-filedefault.htm/welcome-filewelcome-filedefault.jsp/welcome-file/welcome-file-list!-- 前端控制器 --servletservlet-namejd/servlet-nameservlet-classorg.springframework.web.servlet.DispatcherServlet/servlet-classinit-paramparam-namecontextConfigLocation/param-nameparam-valueclasspath:springmvc.xml/param-value/init-param/servletservlet-mappingservlet-namejd/servlet-nameurl-pattern*.action/url-pattern/servlet-mapping!-- 解决post乱码问题 --filterfilter-nameCharacterEncodingFilter/filter-namefilter-classorg.springframework.web.filter.CharacterEncodingFilter/filter-classinit-paramparam-nameencoding/param-nameparam-valueutf-8/param-value/init-param/filterfilter-mappingfilter-nameCharacterEncodingFilter/filter-nameurl-pattern/*/url-pattern/filter-mapping
/web-app配置springmvc.xml
?xml version1.0 encodingUTF-8?
beans xmlnshttp://www.springframework.org/schema/beansxmlns:xsihttp://www.w3.org/2001/XMLSchema-instance xmlns:phttp://www.springframework.org/schema/pxmlns:contexthttp://www.springframework.org/schema/contextxmlns:mvchttp://www.springframework.org/schema/mvcxsi:schemaLocationhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsdhttp://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsdcontext:component-scan base-packagecom.it.jd/!-- 配置注解驱动如果配置此标签可以不用配置处理器映射器和适配器 --mvc:annotation-driven/!-- 配置视图解析器 --bean classorg.springframework.web.servlet.view.InternalResourceViewResolverproperty nameprefix value/WEB-INF/jsp//property namesuffix value.jsp//bean!-- SolrServer的配置 --bean idhttpSolrServer classorg.apache.solr.client.solrj.impl.HttpSolrServerconstructor-arg index0 valuehttp://localhost:8090/solr//bean
/beans3、导入jsp页面和css
4、具体代码实现
pojo代码
package com.it.jd.pojo;public class ProductModel {// 商品编号private String pid;// 商品名称private String name;// 商品分类名称private String catalog_name;// 价格private float price;// 商品描述private String description;
// 图片名称private String picture;
public String getPid() { return pid; } public void setPid(String pid) { this.pid pid; } public String getName() { return name; } public void setName(String name) { this.name name; } public String getCatalog_name() { return catalog_name; } public void setCatalog_name(String catalog_name) { this.catalog_name catalog_name; } public float getPrice() { return price; } public void setPrice(float price) { this.price price; } public String getDescription() { return description; } public void setDescription(String description) { this.description description; } public String getPicture() { return picture; } public void setPicture(String picture) { this.picture picture; } }Dao代码
package com.it.jd.dao;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.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;import com.it.jd.pojo.ProductModel;Repository
public class jdDaoImpl implements jdDao {Autowiredprivate SolrServer solrServer;Overridepublic ListProductModel selectProductModelListByQuery(String queryString, String catalog_name, String price,String sort) throws Exception {//创建一个query对象SolrQuery query new SolrQuery();//设置查询条件query.setQuery(queryString);//过滤条件if(catalog_name!null!.equals(catalog_name))query.set(fq,product_catalog_name:catalog_name);if(null ! price !.equals(price)){//0-9 50-*String[] p price.split(-);query.set(fq, product_price:[ p[0] TO p[1] ]);}//排序if(1.equals(sort))query.addSort(product_price,ORDER.desc);elsequery.addSort(product_price,ORDER.asc);//分页query.setStart(0);query.setRows(10);//指定返回那些字段内容query.set(fl,id,product_name,product_price,product_picture);//指定一个搜索Fieldquery.set(df, product_name);//高亮显示query.setHighlight(true);//高亮显示的域query.addHighlightField(product_name);//高亮显示的前缀query.setHighlightSimplePre(span stylecolor:red);//高亮显示的后缀query.setHighlightSimplePost(/span);//执行查询QueryResponse queryResponse solrServer.query(query);//得到查询结果SolrDocumentList solrDocumentList queryResponse.getResults();//查询到的商品数量//System.out.println(共查询到商品数量: solrDocumentList.getNumFound()); MapString, MapString, ListString highlighting queryResponse.getHighlighting();ListProductModel productModels new ArrayListProductModel();for (SolrDocument doc : solrDocumentList) {ProductModel pmnew ProductModel();pm.setPid((String) doc.get(id));pm.setPrice((Float) doc.get(product_price));pm.setPicture((String) doc.get(product_picture));MapString, ListString map highlighting.get((String) doc.get(id));ListString list map.get(product_name);pm.setName(list.get(0));productModels.add(pm);}return productModels;}}Service代码
package com.it.jd.service;import java.util.List;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import com.it.jd.dao.jdDao;
import com.it.jd.pojo.ProductModel;Service
public class jdServiceImpl implements jdService {Autowiredprivate jdDao dao;Overridepublic ListProductModel selectProductModelListByQuery(String queryString, String catalog_name, String price,String sort) throws Exception {return dao.selectProductModelListByQuery(queryString, catalog_name, price, sort);}}Controller代码
package com.it.jd.controller;import java.util.List;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;import com.it.jd.pojo.ProductModel;
import com.it.jd.service.jdService;Controller
public class jdController {Autowiredprivate jdService jdService;RequestMapping(list.action)public String list(String queryString,String catalog_name,String price,String sort,Model model) throws Exception{ListProductModel productModels jdService.selectProductModelListByQuery(queryString, catalog_name, price, sort);model.addAttribute(productModels, productModels);model.addAttribute(queryString, queryString);model.addAttribute(catalog_name, catalog_name);model.addAttribute(price, price);model.addAttribute(sort, sort);return product_list;}
}