zoukankan      html  css  js  c++  java
  • java 利用JAX-RS快速开发RESTful 服务实例

      首先看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_3_1.xsd"
             version="3.1">
        <servlet>
            <servlet-name>solr_service</servlet-name>
            <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    
            <init-param>
                <param-name>jersey.config.server.provider.packages</param-name>
                <param-value>com.solr.service</param-value>
            </init-param>
            <load-on-startup>1</load-on-startup>
        </servlet>
    
        <servlet-mapping>
            <servlet-name>solr_service</servlet-name>
            <url-pattern>/api/*</url-pattern>
        </servlet-mapping>
    </web-app>

      

      1、无参数

    package com.solr.service;
    import javax.ws.rs.*;
    
    import javax.ws.rs.core.MediaType;
    import javax.xml.bind.JAXBElement;
    import javax.xml.namespace.QName;
    import java.util.List;
    
    
    @Path("/solr_Data")
    public class solrData {
    
        @GET
        @Path("/getMessage")
        //api/solr_Data/getMessage
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage() {
            return "Hello world!";
        }
    
    }

      运行结果:

      

      2、一个@PathParam参数

      
       @GET
        @Path("/getMessage/{msg}")
        //http://localhost:8080/api/solr_Data/getMessage/Restful-Webservice
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage(@PathParam("msg") String msg) {
    
            return String.format("Hello %s !",msg);
    
        }

      运行结果

      

      3、两个@PathParam参数

        @GET
        @Path("/getMessage/{start}-{end}")
        //http://localhost:8080/api/solr_Data/getMessage/0-10
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage(@PathParam("start") int start,@PathParam("end") int end) {
            return String.format("From %d to %d",start,end);
        }

      

      4、一个@QueryParam参数

      

     @GET
        @Path("/getMessage")
        //api/solr_Data/getMessage?msg=Restful-Webservice
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage(@QueryParam("msg") String msg) {
    
            return String.format("Hello %s !",msg);
    
        }

      http://localhost:8080/api/solr_Data/getMessage?msg=Restful-Webservice

      

      5、两个@QueryParam参数

     @GET
        @Path("/getMessage")
        //http://localhost:8080/api/solr_Data/getMessage?msg=Restful-Webservice&start=10
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage(@QueryParam("msg") String msg,@QueryParam("start") int start) {
    
            return String.format("Hello %s: %d !",msg,start);
    
        }

      

      6、一个PathParam参数,一个QueryParam参数

     @GET
        @Path("/getMessage/{start}")
        //http://localhost:8080/api/solr_Data/getMessage/0?end=10
        @Produces(MediaType.TEXT_PLAIN)
        public String getMessage(@PathParam("start") int start,@QueryParam("end") int end) {
            return String.format("From %d to %d",start,end);
        }

      

      7、多个QueryParam参数参,返回xml数据

        solrEntity实体类

    package com.solr.service;
    
    /**
     * @Author:sks
     * @Description:
     * @Date:Created in 16:04 2018/3/1
     * @Modified by:
     **/
    import javax.xml.bind.annotation.XmlAttribute;
    import javax.xml.bind.annotation.XmlElement;
    import javax.xml.bind.annotation.XmlRootElement;
    
    @XmlRootElement(name = "solrEntity")
    public class solrEntity {
    
        String id;
        @XmlElement
        public String getId() {
            return id;
        }
    
        public void setid(String id) {
            this.id = id;
        }
    
        //fileloadDate,keyword,category,fileType,summary
        String fileDate;
        @XmlElement
        public String getFileDate() {
            return fileDate;
        }
    
        public void setFileDate(String fileDate) {
            this.fileDate = fileDate;
        }
    
        String category;
        @XmlElement
        public String getCategory() {
            return category;
        }
    
        public void setCategory(String category) {
            this.category = category;
        }
    
        String keyword;
        @XmlElement
        public String getKeyword() {
            return keyword;
        }
    
        public void setKeyword(String keyword) {
            this.keyword = keyword;
        }
    
        String fileType;
        @XmlElement
        public String getFileType() {
            return fileType;
        }
    
        public void setFileType(String fileType) {
            this.fileType = fileType;
        }
    
        String summary;
        @XmlElement
        public String getSummary() {
            return summary;
        }
    
        public void setSummary(String summary) {
            this.summary = summary;
        }
    
        String title;
        @XmlElement
        public String getTitle() {
            return title;
        }
    
        public void setTitle(String title) {
            this.title = title;
        }
    
        String text;
        @XmlElement
        public String getText() {
            return text;
        }
    
        public void setText(String text) {
            this.text = text;
        }
    
    }
    View Code

        getQueryData 方法

    package com.solr.service;
    
    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.impl.HttpSolrClient;
    import org.apache.solr.client.solrj.response.Cluster;
    import org.apache.solr.client.solrj.response.QueryResponse;
    import org.apache.solr.client.solrj.response.ClusteringResponse;
    
    import org.apache.solr.common.SolrDocument;
    import org.apache.solr.common.SolrDocumentList;
    
    import java.io.IOException;
    import java.util.ArrayList;
    import java.util.List;
    /**
     * @Author:sks
     * @Description:
     * @Date:Created in 9:56 2018/2/26
     * @Modified by:
     **/
    public class SolrService {
    
        private SolrClient solr;
    
        public SolrService() {
            String urlString = "http://localhost:8983/solr/test";
            solr = new HttpSolrClient.Builder(urlString).build();
        }
    
        /**
         * @Author:sks
         * @Description:获取文档总数
         * @Date:
         */
        private long getDocTotalCount() {
            long num = 0;
            try {
                SolrQuery params = new SolrQuery();
                params.set("q", "*:*");
                //params.setQuery("*:*");
                QueryResponse rsp = solr.query(params);
                SolrDocumentList docs = rsp.getResults();
                num = docs.getNumFound();
            } catch (SolrServerException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return num;
        }
    
    
        /**
         * @Author:sks
         * @Description:获取普通查询数据
         * @Date:
         * @queryWhere:查询条件
         * @showField:显示的字段
         * @sortField: 排序字段
         */
        public List<solrEntity> getQueryData(String queryWhere, String showField, String sortField) {
            SolrQuery params = new SolrQuery();
    
            //例如:fileloadDate:[2018-02-25 TO 2018-03-1]  AND category:广告营销
            //查询日期在2018-02-25 TO 2018-03-1之间,这里TO 必须是大写,并且category:广告营销的所有数据,
            //多个与条件用AND连接,多个或条件用OR连接,必须是大写
            params.setQuery(queryWhere);
    
            //id,fileloadDate,keyword,category,fileType,summary 多个字段中间用逗号隔开
            params.setFields(showField);
            //从0页开始
            params.setStart(0);
            params.setRows((int) getDocTotalCount());
    
            //排序字段  fileloadDate:desc; category:asc
            //字段和排序类型中间用冒号隔开,多个字段中间用分号隔开
            if (sortField != null && sortField.length() != 0) {
                String[] sortFields = sortField.split(";");
                List<SolrQuery.SortClause> sortlist = new ArrayList<SolrQuery.SortClause>();
                SolrQuery.ORDER order;
                for (String sf : sortFields) {
                    order = sf.split(":")[1] == "asc" ? SolrQuery.ORDER.asc : SolrQuery.ORDER.desc;
                    SolrQuery.SortClause sc = new SolrQuery.SortClause(sf.split(":")[0], order);
                    sortlist.add(sc);
                }
                params.setSorts(sortlist);
            }
            List<solrEntity> list = new ArrayList<solrEntity>();
            try {
                QueryResponse queryResponse = solr.query(params);
                SolrDocumentList clr = queryResponse.getResults();
                System.out.println(clr.getNumFound());
                String[] fields = showField.split(",");
                for (SolrDocument sd : clr) {
                    solrEntity se = new solrEntity();
                    se.setid(sd.get("id").toString());
                    se.setCategory(sd.get("category").toString());
                    se.setKeyword(sd.get("keyword").toString());
                    se.setFileType(sd.get("fileType").toString());
                    list.add(se);
                }
    
            } catch (SolrServerException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return list;
        }
    
    }
    View Code

        调用方法

    @GET
        @Path("/getSolrData")
        //@Produces(MediaType.APPLICATION_JSON)
        @Produces(MediaType.APPLICATION_XML)
        //api/solr_Data/getSolrData?queryWhere=fileloadDate:[2018-02-25 TO 2018-03-1]  AND category:广告营销&showField=id,fileloadDate,keyword,category,fileType&sortField=fileloadDate:desc; category:asc
        public List<solrEntity> getSolrData(@QueryParam("queryWhere") String queryWhere,
                                            @QueryParam("showField") String showField,
                                            @QueryParam("sortField") String sortField) {
            SolrService service = new SolrService();
            //"fileloadDate:[2018-02-25 TO 2018-03-1]  AND category:广告营销"
            //id,fileloadDate,keyword,category,fileType
            //fileloadDate:desc; category:asc
            List<solrEntity> list  = service.getQueryData(queryWhere,showField,sortField);
            return list;
        }
    View Code

      浏览器查询:

    http://localhost:8080/api/solr_Data/getSolrData?queryWhere=fileloadDate:[2018-02-25 TO 2018-03-1]  AND category:广告营销&showField=id,fileloadDate,keyword,category,fileType&sortField=fileloadDate:desc; category:asc
    查询结果:

    
    
  • 相关阅读:
    python 协程
    python 打印乘法表
    python 线程池
    python 队列
    开发react 应用最好用的脚手架 create-react-app
    React面试题
    修改了背景透明度
    低门槛彻底理解JavaScript中的深拷贝和浅拷贝
    Web Worker 使用教程
    Vue2 实现时空穿梭框功能模块
  • 原文地址:https://www.cnblogs.com/shaosks/p/8491865.html
Copyright © 2011-2022 走看看