1. Web API 실습 - SELECT *
# 실행환경 설정 (Maven 프로젝트 생성 및 Tomcat 연동)
[Servlet] Maven 프로젝트 Tomcat 연동 Servlet 실행하기 (Intellij)
0. 배경 - Intellij에서 Maven 프로젝트를 생성한 후, Tomcat을 연동해서 웹 개발 환경 구축하기 - JDBC와 MySQL 연동한 후, 콘솔에 레코드 출력해서 잘 연동되었는지 확인하기 - Servlet 생성해서 MySQL에서 레
ssoyeong.tistory.com
# RolesServlet.java
package webapiexam.api;
import com.fasterxml.jackson.databind.ObjectMapper;
import jdbcexam.dao.RoleDao;
import jdbcexam.dto.Role;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;
import static java.lang.System.out;
@WebServlet("/roles")
public class RolesServlet extends HttpServlet {
public RolesServlet() {
super();
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setCharacterEncoding("utf-8");
response.setContentType("application/type");
RoleDao dao = new RoleDao();
List<Role> list = dao.getRoles();
// JSON 사용하려고 추가했던 라이브러리, 그 라이브러리가 제공해주는 객체 ObjectMapper
// JSON 문자열 <-> 객체
ObjectMapper objectMapper = new ObjectMapper();
String json = objectMapper.writeValueAsString(list); // 해당 list가 JSON으로 바뀜
out.println(json);
out.close();
}
}
GET 방식으로 요청하면, 그에 대한 응답으로 Role 테이블의 모든 레코드를 JSON 형태로 화면에 출력하기
2. WEB API 실습 - SELECT by ID
package webapiexam.api;
import com.fasterxml.jackson.databind.ObjectMapper;
import jakarta.servlet.ServletException;
import jakarta.servlet.annotation.WebServlet;
import jakarta.servlet.http.HttpServlet;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jdbcexam.dao.RoleDao;
import jdbcexam.dto.Role;
import java.io.IOException;
import java.io.PrintWriter;
@WebServlet("/roles/*")
public class RoleByIdServlet extends HttpServlet {
public RoleByIdServlet() {
super();
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setCharacterEncoding("utf-8");
response.setContentType("application/json");
String pathInfo = request.getPathInfo(); // 읽어온 패스 정보 /roles/{roleId}
String[] pathParts = pathInfo.split("/");
String idStr = pathParts[1];
int id = Integer.parseInt(idStr);
RoleDao dao = new RoleDao();
Role role = dao.getRole(id);
ObjectMapper objectMapper = new ObjectMapper();
String json = objectMapper.writeValueAsString(role);
PrintWriter out = response.getWriter();
out.println(json);
out.close();
}
}
GET 방식으로 요청하면, 그에 대한 응답으로 Role 테이블의 해당 id에 해당하는 레코드를 JSON 형태로 화면에 출력하기
'강의 노트 > 웹 프로그래밍(풀스택)' 카테고리의 다른 글
[boostcourse] 3.8. Spring JDBC - BE (0) | 2023.06.25 |
---|---|
[boostcourse] 3.7. Spring Core - BE (0) | 2023.06.24 |
[boostcourse] 2.10. JDBC - BE (0) | 2023.06.20 |
[boostcourse] 2.5. Scope - BE (0) | 2023.06.20 |
[boostcourse] 2.4. Redirect & Forward - BE (0) | 2023.06.20 |