美文网首页@IT·互联网程序员
JavaWeb小项目之综合搜索工具(三):创建RESTful服务

JavaWeb小项目之综合搜索工具(三):创建RESTful服务

作者: 竹杖芒鞋轻胜码 | 来源:发表于2017-04-16 15:20 被阅读0次

    JavaWeb小项目之综合搜索工具(一):前端篇
    JavaWeb小项目之综合搜索工具(二):爬虫篇
    JavaWeb小项目之综合搜索工具(三):创建RESTful服务篇

    这里说一下总的思路:

    1. 使用前端的JQuery框架,发起Ajax 请求一个API,然后获得JSON数据,在前端处解析处理。(具体代码可以去 <a href="http://www.jianshu.com/p/2cc6acf04386">JavaWeb小项目之综合搜索工具(一):前端篇</a> 文章底部查看。)

    2. 这篇文章的目的就是构建一个API,此API的目的就是获得爬虫爬到的信息。

    3. 找了许多框架,根据综合分析之后呢,为了降低构建难度,还是选择了Jersey框架。


    什么是RESTful

    <i>相关阅读:</i>
    网上说的较好的有这两篇,看完大概就差不多了
    <a href="https://sanwen8.cn/p/2ddcbVD.html">深入浅出RESTful API设计,小白也能看懂</a>
    <a href="http://www.ruanyifeng.com/blog/2014/05/restful_api.html">这里有一篇阮大写的 RESTful API 设计指南</a>

    我说下简单的见解,也就是服务器给出一个目标地址(以一个url链接充当的API),当你发送 GET/POST/...之类的请求到此链接(即API)时,服务器会监听此链接所接受到的任何请求,然后执行你所写的逻辑代码。其实也就是java Servlet的知识内容。

    来自知乎的回答.png

    快速构建RESTful

    相关阅读
    读完这三篇基本思路就清楚了
    用Jersey构建RESTful服务1--HelloWorld
    使用Jersey创建RESTful服务 - 推酷
    IntelliJ 创建Tomcat + Jersey Restful 工程

    我使用IntelliJ 来构建的,其中碰到了一些坑,坑了一两天。差点吐血。

    第一个坑:IntelliJ 默认的RESTful工程模板创建后一旦修改就会报错

    使用IntelliJ直接创建的RESTful Web Service跑起来没问题,但是一旦使用了爬虫的方法就报错!!哪怕是把爬虫的相关代码全部删除之后,还原到之前能跑状态的代码,依旧报错啊,卧槽了。硬生生是Debug不知多少个小时,感谢下面这篇文章解决了我的问题。

    IntelliJ 创建Tomcat + Jersey Restful 工程

    第二个坑:导入爬虫模块后,找不到该模块

    那是因为没有在Artifacts中把把项目依赖的lib发布到WEB-INFO/lib下


    Artifacts_WEB-INF

    本项目的依赖

    使用maven来解决项目依赖:

    pom.xml文件

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>com.hjg.test</groupId>
        <artifactId>search_back_end</artifactId>
        <version>1.0-SNAPSHOT</version>
    
        <dependencies>
            <dependency>
                <groupId>org.glassfish.jersey.containers</groupId>
                <artifactId>jersey-container-servlet</artifactId>
                <version>2.22.2</version>
            </dependency>
    
            <dependency>
                <groupId>com.sun.jersey</groupId>
                <artifactId>jersey-json</artifactId>
                <version>1.18</version>
            </dependency>
        </dependencies>
        
    </project>
    

    为Servlet程序注册入口

    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>JAX-RS Servlet</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.hjg.test</param-value>-->
    
                <param-name>javax.ws.rs.Application</param-name>
                <param-value>com.hjg.test.RestApplication</param-value>
            </init-param>
            <load-on-startup>1</load-on-startup>
        </servlet>
        <servlet-mapping>
            <servlet-name>JAX-RS Servlet</servlet-name>
            <url-pattern>/api/*</url-pattern>
        </servlet-mapping>
    </web-app>
    

    com.hjg.test下的RestApplication.java

    package com.hjg.test;
    
    
    import org.codehaus.jackson.jaxrs.JacksonJsonProvider;
    import org.glassfish.jersey.server.ResourceConfig;
    
    /**
     * Created by thinkerer on 2017/3/29.
     */
    public class RestApplication extends ResourceConfig{
        public RestApplication(){
            //服务类所在的包路径
            packages("com.hjg.test.resources");
            
            //注册JSON转换器
            register(JacksonJsonProvider.class);
        }
    }
    

    通过在package: "com.hjg.test.resources"下的UserResource.java来处理接收请求后的逻辑

    处理的逻辑代码如下:

        @GET
        @Path("/getArticle/{search_param}")
        @Produces(MediaType.APPLICATION_JSON)
        public Link_Items getArticle(@PathParam("search_param") String search_param){
            Link_Items re=null;
            if (search_param==null||search_param==""){
            //todo
            }else {
                testSplider a = new testSplider();
                 re= a.getDatasByClass(search_param);
        }
            return re;
            //此处框架会把此对象直接转为JSON对象传回前端
        }
    

    到这一步大致就已经解决了基本问题,我所做的API是:
    http://localhost:8080/api/search/getArticle/+参数(搜索的内容)

    运行Tomcat,注意端口号是否被占用。

    项目完整代码:
    https://coding.net/u/thinker_er/p/JavaWebDemo_Search_DEMO/git

    相关文章

      网友评论

        本文标题:JavaWeb小项目之综合搜索工具(三):创建RESTful服务

        本文链接:https://www.haomeiwen.com/subject/jwwdattx.html