RESTful 웹 서비스-첫 번째 애플리케이션

Jersey Framework로 실제 RESTful 웹 서비스 작성을 시작하겠습니다. Jersey Framework를 사용하여 첫 번째 예제를 작성하기 전에 RESTful 웹 서비스-환경 설정 장에 설명 된대로 Jersey 환경을 올바르게 설정했는지 확인해야합니다 . 여기에서는 Eclipse IDE에 대한 약간의 작업 지식이 있다고 가정합니다.

따라서 사용자 목록을 표시하는 웹 서비스 메서드를 노출하는 간단한 Jersey 애플리케이션을 작성해 보겠습니다.

자바 프로젝트 생성

첫 번째 단계는 Eclipse IDE를 사용하여 동적 웹 프로젝트를 만드는 것입니다. 옵션을 따르십시오File → New → Project 마지막으로 Dynamic Web Project마법사 목록에서 마법사. 이제 프로젝트 이름을UserManagement 다음 스크린 샷과 같이 마법사 창을 사용하여-

프로젝트가 성공적으로 생성되면 다음 콘텐츠가 Project Explorer

필요한 라이브러리 추가

두 번째 단계로 Jersey Framework와 해당 종속성 (라이브러리)을 프로젝트에 추가하겠습니다. 프로젝트의 WEB-INF / lib 디렉토리에있는 download jersey zip 폴더의 다음 디렉토리에서 모든 jar를 복사합니다.

  • \jaxrs-ri-2.17\jaxrs-ri\api
  • \jaxrs-ri-2.17\jaxrs-ri\ext
  • \jaxrs-ri-2.17\jaxrs-ri\lib

이제 프로젝트 이름을 마우스 오른쪽 버튼으로 클릭하십시오. UserManagement 그런 다음 컨텍스트 메뉴에서 사용 가능한 옵션을 따르십시오- Build Path → Configure Build Path Java 빌드 경로 창을 표시합니다.

이제 사용 Add JARs 아래에서 사용할 수있는 버튼 Libraries 탭을 클릭하여 WEBINF / lib 디렉토리에있는 JAR을 추가합니다.

소스 파일 만들기

이제 실제 소스 파일을 UserManagement계획. 먼저 다음과 같은 패키지를 만들어야합니다.com.tutorialspoint. 이렇게하려면 패키지 탐색기 섹션에서 src를 마우스 오른쪽 버튼으로 클릭하고 옵션을 따르십시오.New → Package.

다음으로 우리는 UserService.java, User.java,UserDao.java com.tutorialspoint 패키지 아래의 파일.

User.java

package com.tutorialspoint;  

import java.io.Serializable;  
import javax.xml.bind.annotation.XmlElement; 
import javax.xml.bind.annotation.XmlRootElement; 
@XmlRootElement(name = "user") 

public class User implements Serializable {  
   private static final long serialVersionUID = 1L; 
   private int id; 
   private String name; 
   private String profession;  
   public User(){} 
    
   public User(int id, String name, String profession){  
      this.id = id; 
      this.name = name; 
      this.profession = profession; 
   }  
   public int getId() { 
      return id; 
   }  
   @XmlElement 
   public void setId(int id) { 
      this.id = id; 
   } 
   public String getName() { 
      return name; 
   } 
   @XmlElement
   public void setName(String name) { 
      this.name = name; 
   } 
   public String getProfession() { 
      return profession; 
   } 
   @XmlElement 
   public void setProfession(String profession) { 
      this.profession = profession; 
   }   
}

UserDao.java

package com.tutorialspoint;  

import java.io.File; 
import java.io.FileInputStream; 
import java.io.FileNotFoundException;  
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.ObjectInputStream; 
import java.io.ObjectOutputStream; 
import java.util.ArrayList; 
import java.util.List;  

public class UserDao { 
   public List<User> getAllUsers(){ 
      
      List<User> userList = null; 
      try { 
         File file = new File("Users.dat"); 
         if (!file.exists()) { 
            User user = new User(1, "Mahesh", "Teacher"); 
            userList = new ArrayList<User>(); 
            userList.add(user); 
            saveUserList(userList); 
         } 
         else{ 
            FileInputStream fis = new FileInputStream(file); 
            ObjectInputStream ois = new ObjectInputStream(fis); 
            userList = (List<User>) ois.readObject(); 
            ois.close(); 
         } 
      } catch (IOException e) { 
         e.printStackTrace(); 
      } catch (ClassNotFoundException e) { 
         e.printStackTrace(); 
      }   
      return userList; 
   } 
   private void saveUserList(List<User> userList){ 
      try { 
         File file = new File("Users.dat"); 
         FileOutputStream fos;  
         fos = new FileOutputStream(file); 
         ObjectOutputStream oos = new ObjectOutputStream(fos); 
         oos.writeObject(userList); 
         oos.close(); 
      } catch (FileNotFoundException e) { 
         e.printStackTrace(); 
      } catch (IOException e) { 
         e.printStackTrace(); 
      } 
   }    
}

UserService.java

package com.tutorialspoint;  

import java.util.List; 
import javax.ws.rs.GET; 
import javax.ws.rs.Path; 
import javax.ws.rs.Produces; 
import javax.ws.rs.core.MediaType;  
@Path("/UserService") 

public class UserService {  
   UserDao userDao = new UserDao();  
   @GET 
   @Path("/users") 
   @Produces(MediaType.APPLICATION_XML) 
   public List<User> getUsers(){ 
      return userDao.getAllUsers(); 
   }  
}

메인 프로그램에 대해 주목해야 할 두 가지 중요한 사항이 있습니다.

UserService.java

  • 첫 번째 단계는 UserService에 대한 @Path 주석을 사용하여 웹 서비스의 경로를 지정하는 것입니다.

  • 두 번째 단계는 UserService의 메소드에 @Path 주석을 사용하여 특정 웹 서비스 메소드에 대한 경로를 지정하는 것입니다.

Web.xml 구성 파일 만들기

XML 파일이며 애플리케이션에 대한 Jersey 프레임 워크 서블릿을 지정하는 데 사용되는 Web xml 구성 파일을 만들어야합니다.

web.xml

<?xml version = "1.0" encoding = "UTF-8"?> 
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"  
   xmlns = "http://java.sun.com/xml/ns/javaee"  
   xsi:schemaLocation="http://java.sun.com/xml/ns/javaee  
   http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"  
   id = "WebApp_ID" version = "3.0"> 
   <display-name>User Management</display-name> 
   <servlet> 
      <servlet-name>Jersey RESTful Application</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.tutorialspoint</param-value> 
      </init-param> 
   </servlet> 
   <servlet-mapping> 
      <servlet-name>Jersey RESTful Application</servlet-name> 
      <url-pattern>/rest/*</url-pattern> 
   </servlet-mapping>   
</web-app>

프로그램 배포

소스 및 웹 구성 파일 작성이 완료되면 프로그램을 컴파일하고 실행하는이 단계를 수행 할 준비가 된 것입니다. 이를 위해 Eclipse를 사용하여 애플리케이션을 war 파일로 내보내고 tomcat에 배포합니다.

Eclipse를 사용하여 WAR 파일을 작성하려면 다음 옵션을 따르십시오. File → export → Web → War File마지막으로 프로젝트 UserManagement 및 대상 폴더를 선택하십시오. Tomcat에 war 파일을 배포하려면 UserManagement.war를Tomcat Installation Directory → webapps directory Tomcat을 시작하십시오.

프로그램 실행

웹 서비스를 테스트하기 위해 Chrome 확장 프로그램 인 Postman 을 사용 하고 있습니다.

UserManagement에 요청하여 모든 사용자 목록을 가져옵니다. GET 요청과 함께 http : // localhost : 8080 / UserManagement / rest / UserService / users를 POSTMAN에 넣고 다음 결과를 확인하십시오.

축하합니다. 첫 번째 RESTful 애플리케이션을 성공적으로 만들었습니다.