@IT·互联网程序员

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

2017-04-16  本文已影响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

上一篇下一篇

猜你喜欢

热点阅读