使用IntelliJ IDEA新建Java Web後端resfulAPI模板

初始化項目

打開IntelliJ IDEA,個人版本是Version 2018.1.4。點擊Create New Project。在左側的列表中選擇Maven。而後在右側勾選Create from archetype。javascript

而後在右側的列表中選擇org.apache.maven.archetypes:maven-archetype-webapp。點擊next。java

填寫GroupId和ArtifactId。GroupId定義了項目屬於哪一個組織,例如,咱們須要使用一個包,名字叫作fastjson,用戶在項目中返回json數據的,是阿里的開源框架,被很多企業使用,是一個極其優秀的Json框架。它的groupId是com.alibaba,artifactId是fastjson。git

簡單理解一下,拿Github舉個例子。GroupId就至關因而你的用戶名,而ArtifactId就至關因而你的具體某個項目的名稱,也是咱們當前的項目的根目錄名稱。例子以下。github

GroupId: com.detectivehlh.test
ArtifactId: testDemo
複製代碼

點擊next,下兩頁不用設置,直接點擊next。此時新建項目成功,右下角會彈出一個提示框,上面寫着Maven projects need to be imported.此時選擇Enable Auto-Import。就能夠看到項目開始自動的去加載依賴包了。加載完成以後,項目會多出一個src目錄。web

引入jersey和servlet

打開根目錄下pom.xml文件,在dependencies標籤中添加以下代碼,引入servlet。apache

<dependency>
    <groupId>org.glassfish.jersey.containers</groupId>
    <artifactId>jersey-container-servlet</artifactId>
    <version>2.22.2</version>
</dependency>
複製代碼

打開/src/main/webapp/WEB_INF/web.xml。在web-app標籤之間添加以下代碼。json

<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.detectivehlh.test</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>
複製代碼

新建項目目錄和文件

在/src/main目錄下新建java、resources目錄,java放項目java源代碼,resources放項目的靜態資源文件。api

打開File中的Project Structure,或者使用快捷鍵,command + ;就能夠快捷打開了。將剛剛建立的名爲java目錄設置爲Sources,resources設置爲Resources。而後Apply。而後在java目錄下依次新建com.detectivehlh.test三個包,就是咱們的GroupId.瀏覽器

而後在com.detectivehlh.test中新建Hello類。代碼以下。app

package com.detectivehlh.test;

import com.alibaba.fastjson.JSONObject;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import java.util.ArrayList;
import java.util.List;

@Path("/hello")
public class Hello {
    @Path("get")
    @GET
    @Produces(MediaType.APPLICATION_JSON)
    public Response getStudent() {
        List<Student> lists = new ArrayList<Student>();
        lists.add(new Student("1","mayun",23));
        lists.add(new Student("2","mahuateng",24));
        lists.add(new Student("3","zhouhongyi",25));
        JSONObject json = new JSONObject();
        return Response.status(Response.Status.OK).entity(json.toJSONString(lists)).build();
    }
}

複製代碼

一樣的地方新建Student類。代碼以下。

package com.detectivehlh.test;

public class Student {
    private String id;
    private String name;
    private int age;

    public Student(String id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }

    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

}
複製代碼

引入fastjson

這個時候能夠看到,Hello的class中有報錯。是由於沒有在pom.xml中沒有引入對fastjson的依賴。在根目錄下的pom.xml中添加以下依賴。

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.21</version>
</dependency>
複製代碼

再回到Hello中就能夠看到沒有錯誤信息了。

配置Tomcat

選擇頂部菜單欄中的Run->Edit Configurations。點擊左側的+,選擇Tomcat Server->local。配置好Tomcat後,選擇Server旁邊的Deployment標籤,點擊下方的+,選擇Artifact,選擇testDemo:war exploded。點擊Apply。而後點擊右上角的長得像播放鍵的按鈕,啓動項目。 就能夠看到會新建一個瀏覽器標籤頁。顯示"Hello World!",而後改變瀏覽器中的路由爲咱們寫的接口的路由,/api/hello/get。就能夠看到返回的json數據了。

歡迎光臨 我的博客

相關文章
相關標籤/搜索