코드 리뷰

  • required :  선택 안 하면 요청할 수가 없음
  • response.setContentType("text/html; charset=UTF-8");
    • 응답 시 형식이 뭔지 알리는 것
    • 브라우저마다 문자코드 해석하는 default가 다르기 때문,
  • request.setCharacterEncoding("UTF-8");
    • post 방식으로 보내는 값이 한글 안 깨지게
      • GET 방식은 톰캣이 기본적으로 자동으로 한글처리해주기 때문에 한글이 안 깨짐
    • 쿼리 문자 추출 시, 한글이 추출 잘 되게
  • LocalDate.parse() (LocalDate, LocalDateTime 스터디할 필요!
 

LocalDate parse() method in Java with Examples - GeeksforGeeks

A Computer Science portal for geeks. It contains well written, well thought and well explained computer science and programming articles, quizzes and practice/competitive programming/company interview Questions.

www.geeksforgeeks.org

  • LocalDate date = LocalDate.parse(request.getParameter("date"));
    out.printf("<li>예약 날짜 : %1$tY년 %1$tm월 %1$td일</ul>", date);
    • 1$ : 첫번째 아규먼트를 여기에 반영하겠다. 
    • %ty : java.util.Date를 입력받으면서 년도 제공

 


  • post
    • form 태그있어야함
    • 요청 바디안에 담겨서 전달함
    • 전달되는 name-value쌍 외부에 안 보임
  • get
    • 하이퍼링크, 이미지, form 태그 메소드 속성 생략될 때,,
    • 길이의 제한있음
    • 외부에 공개됨
    • 요청 header만 있음

 

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		request.setCharacterEncoding("UTF-8");
		doGet(request, response);
	}
  • doGet호출
    • 직접 호출 할 수 있다. 

 

protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html; charset=UTF-8");
		PrintWriter out = response.getWriter();
		String method = request.getMethod();
		if(method.equals("POST"))
			request.setCharacterEncoding("utf-8");
		out.print("<h2>요청 방식 : "+method+"</h2>");
		out.print("<h2>Query 문자열 : "+
		                  request.getParameter("name")+"</h2>");
		out.close();
		System.out.println(method+" 방식 수행");
	}
  • service에 넣어줘도 된다. 

 


  • '/'시작하면 절대 uri
    • 젤 첫번째에 프로젝트 명이 나와야한다. 
    • 최상위 폴더 wepapp까지 자동으로 찾아감 (webapp부터 시작)
  • 상대 uri : 현재 디렉토리 기준으로
    • '..'부터 주던지
    • 폴더명부터 줘야함 
  • getHeader("referer")
    • 요청한 대상 (html)에 대한 주소 추출

상태정보 유지 기술

package base;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet({ "/getHTML", "/getXML", "/getJSON", "/getImage" })
public class ResponseServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String uri = request.getRequestURI();
		System.out.println(uri);
		String filename = "";
		String contentType = "";
		if (uri.endsWith("getHTML")) {
			filename = "c:/Temp/sample.html";	
			contentType = "text/html; charset=utf-8";
		} else if (uri.endsWith("getXML")) {
			filename = "c:/Temp/sample.xml";	
			contentType = "application/xml; charset=utf-8";
		} else if (uri.endsWith("getJSON")) {
			filename = "c:/Temp/sample.json";	
			contentType = "text/json; charset=utf-8";
		} else {
			filename = "c:/Temp/trans_duke.png";	
			contentType = "image/png";
		}
		File f = new File(filename);
		FileInputStream fis = new FileInputStream(f);
		response.setContentType(contentType);
		if(contentType.startsWith("image")) {
			byte[] content = new byte[(int)f.length()];
			ServletOutputStream sos = response.getOutputStream();
			fis.read(content);
			sos.write(content);			
			sos.close();
		} else {
			InputStreamReader isr = new InputStreamReader(fis, "utf-8");
			BufferedReader br = new BufferedReader(isr);
			PrintWriter out = response.getWriter();
			String line = null; 
			while((line = br.readLine()) != null) 
				out.println(line);
			out.close();
			br.close();
			isr.close();			
		}		
		fis.close();
	}
}
  • @WebServlet({ "/getHTML", "/getXML", "/getJSON", "/getImage" })
    • 맵핑 명 여러개
  • file io : 운영체제 알맞는 패스 정보
    • 드라이버 경로 넣어야함
  • 읽어서 클라이언트한테 write
  • io는 운영체제에 무관하게 만드는게 쉬운일이 아님
    • 운영체제에 무관하게 만들려고 : Stream객체를 써서 
      • 한 쪽 방향으로만 흐른다. (내보내든, 읽어오든)
      • txt파일 읽어온다 : textreader
      • 출력 : outputStream,,,
  • getOutputStream () : 이미지파일을 읽어와야해서, 통채로 읽어서 통채로 내보냄
  • FileInputStream : 바이너리 스트림을 이용해서 읽어오겠다. 
  • InputStreamReader isr = new InputStreamReader(fis, "utf-8");
    • 읽기모드로 동작하는 바이트 스트림을 문자 스트림으로 변환해주는 

 


  • servlet 
    • 객체 생성되면, 서버 죽을 때까지 아니면 리로드될때까지 살아있다.
    • 생성된 객체 계속 재활용함
    • 여러클라이언트  하나의 서비스 요청하면
      • 요청한 수만큼 스레드 만들어서
      • 하나의 서블릿객체 공유해서 사용함
      • 처리 효율 높일 수 있음
    • 맴버 변수로 하느냐, 지역변수로 하느냐 크게 달라져서 신경써야함
      package base;
      
      import java.io.IOException;
      import java.io.PrintWriter;
      
      import javax.servlet.ServletException;
      import javax.servlet.annotation.WebServlet;
      import javax.servlet.http.HttpServlet;
      import javax.servlet.http.HttpServletRequest;
      import javax.servlet.http.HttpServletResponse;
      
      @WebServlet("/memberlocal")
      public class MemberLocalServlet extends HttpServlet {
      	private static final long serialVersionUID = 1L;
      	int member_v=0;
      	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
      		int local_v=0;		
      		response.setContentType("text/html; charset=utf-8");
      		PrintWriter out = response.getWriter();
      		member_v += 10;
      		local_v += 10;
      		out.print("<ul>");
      		out.print("<li>멤버변수 : "+ member_v +"</li>");
      		out.print("<li>지역변수 : "+ local_v +"</li>");
      		out.print("</ul>");
      		out.close();		
      	}
      }​
      • 구동시키면
        • 멤버 10, 지역 10됨
      • 새로고침하면 
        • 멤버 20, 지역 10됨
    • 멤버 변수 : 객체 생성시에 메모리 할당 됨 (최초 요청 했을 때)
    • 지역 변수 : 호출 될 때마다 할당 됨
      • 개별 할당은 가능함
      • 메소드 수행이 끝나면 사라짐
      • 어떤 클라이언트가 요청하든, 재활용 된다. 
      • 모든 클라이언트가 공유함 (리로드, 서버 죽을 때까지)
    • 계좌번호, 개인정보는 멤버 변수에 넣으면 안됨.
      • 웬만하면 지역변수 
      • 다른 클라이언트가 멤버 변수가 바뀔 수가 있음
    • 개별할당하면서 다음 요청시에도 그대로 쓸 수 있게 하려면(ex 쇼핑카트)
      • 세션객체 (httpsession)

HttpSession

  • 클라이언트 별로 개별적으로 만들어짐
    • (클라이언트별로 하나씩만들어짐) - 두개를 안 만들어줌 
    • 이름을 부여해서 name-value쌍으로 
    • 원하는 시간까지 유지
    • 갯수 제한 없음
    • WAS가 알아서 관리해줌 - 안 만들어져 있으면 새로 만들어줌
    • 일정 시간동안 요청을 안 하면
      • 세션객체는 자동 삭제된다 - WAS가
      • 일정 시간 = 기본 값 : 30분 (api로 바꿀 수 있다)
        • Inactive Interval
      • 직접 삭제도 가능
  • 클라이언트 별로 객체로 만들어서 넣어주면 됨 (기본형은 못 넣음)
    • setAttribute
  • 유지할 필요가 없으면 지우면 된다. 
    • removeAttribute
  • 꺼내는 것 
    • getAttribute

  1. 상태 정보 유지
    • 목적의 데이터들 (로그인 했다, 로그인을 성공했다. 어떤 상품을 몇 개 구매하고 싶다라는 장바구니)
    • 현재 어떤 상태다 (이 클라이언트는)
    • 클라이언트별로 유지하는 기술
  2. 어떤 클라이언트것인지 구별하는 것
    • 회원가입 안 해도 장바구니에 상품 담을 수 있다. 
    • 세션 id가 하나씩 부여됨
      • id는 고유 식별자 (짧지 않음)
      1. cookie를 이용한 방법
        • 클라이언트 별로 상태 정보를 각각 들고 있음 
      2. HttpSession객체 이용 
        • 서버에 클라이언트 별 상태 정보가 저장되어 있음
        • 방문했던 적이 있는 클라이언트 안에 보관되어있는 데이터
        • name-value쌍의 데이터
        • 서블릿, 자바스크립트로 구현 가능 (서블릿만의 구현 기술이 아님)
        • 서버가 클라이언트한테 응답 헤더에 set-cookie해서 줌
          1. 주기전에 id에 해당하는 session객체가 있는지 본다.
            • 있으면 그대로 주고, 없으면 만듦 
          2. 응답 헤더에 전달된 쿠키 정보를 저장
          3. 브라우저가 보관함
          4. 다시 요청할 때 요청 헤더에 저장된거 담아서 줌
        • 브라우저 유효 서버가 누구인지 다 앎
          • 다른 서버한테 갈 일은 없음
        • 앞으로 24시간 팝업창 띄우지 않기, 로그인 시 계정 보관
          • 없어지더래도 크게 문제가 되지 않는 것
        • 중요한 상태 정보는 서버에 저장
        • 세션객체의 아이디만 클라이언트에 저장
        • API
          • getSession( true or false)
            • HttpSession 리턴함 
            • 기본 값 true
              • 이미만들어져있는 얘 찾아서 리턴
              • 안 만들어져 있으면 새로 만들어서 리턴함
            • false
              • 안 만들어져 있으면 null리턴
          • setAttribute(이름, 객체)
            • 똑같은 이름의 객체 여러개 등록 X
            • 마지막에 등록된 얘가 저장되어 있음
            • 강제 형변환 필수 - 리턴 값이 object라서 
            • 필요없으면 removeAttribute( )
          • invalidate( )
            • 생성되어있는 세션 객체 강제로 삭제

 

package base;

import java.io.IOException;
import java.io.PrintWriter;

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 javax.servlet.http.HttpSession;

@WebServlet("/sessiontest1")
public class SessionTestServlet1 extends HttpServlet {
	private static final long serialVersionUID = 1L;
	int member_v=0;
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		int local_v=0;		
		response.setContentType("text/html; charset=utf-8");
		PrintWriter out = response.getWriter();
		HttpSession session = request.getSession();
		if(session.getAttribute("cnt") == null)
			session.setAttribute("cnt", new int[1]); // 데이터를 저장할 방을 등록
		int[] session_v = (int[])session.getAttribute("cnt");
		session_v[0] += 10;
		member_v += 10;
		local_v += 10;
		out.print("<ul>");
		out.print("<li>멤버변수 : "+ member_v +"</li>");
		out.print("<li>지역변수 : "+ local_v +"</li>");
		out.print("<li>세션객체에저장된배열원소 : "+ session_v[0] +"</li>");
		out.print("</ul>");
		out.close();		
	}
}
    1. - int[] session_v = (int[])session.getAttribute("cnt");
      1. - cnt로 저장되어 있는 객체 꺼내오기
        - session객체 id가 전달 됨
      2. - 유호 path : /edu

      3. - 새로 고침하면, 요청 해더에는 id없음.
      4. - 응답 헤더에 id가 있다. 
      5. - 계속 서버에 id 보냄

      6. - 엣지로 열면 개별적으로 증가함
      7. - 크롬용, 엣지용 개별적으로 만들어져 있음
      8. - 크롬을 여러개 열어도 자원을 공유함 : 두개 만들어지진 않음
      9. - 다른 브라우저만, 크롬을 띄울 때 시크리티 모드면 별개의 객체 만들어짐 
      10.  

      11. - 유효 도메인 판단된 경우에만 세션 id가 보내진다.
      12. - 브라우저 죽을 때 까지 유효함

 


package base;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;

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 javax.servlet.http.HttpSession;
@WebServlet("/sessiontest2")
public class SessionTestServlet2 extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {		
		HttpSession session = request.getSession();
		response.setContentType("text/html; charset=utf-8");
		PrintWriter out = response.getWriter();	
		out.print("생성된 세션객체의 ID : "+session.getId());
		out.print("<br>세션 객체가 생성된 시간 : "
				      + new Date(session.getCreationTime()));
		out.print("<br>현재 시간 : " + new Date());
		out.close();
	}
}
  • 유효 시간 안 주면 브라우저가 죽기 전까지 있음

 

    • 현재 시간은 바뀌어도 세션 객체 만들어지는 시간은 안 바뀜
      • getCreationTime() 세션 객체 만들어진 시간
  • 클라이언트 별로 개별적으로 만들어진다. 

 


package base;
import java.io.IOException;
import java.io.PrintWriter;

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 javax.servlet.http.HttpSession;
@WebServlet("/sessiontest3")
public class SessionTestServlet3 extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {	
		response.setContentType("text/html; charset=utf-8");
		PrintWriter out = response.getWriter();	
	    String action = request.getParameter("action");
	    HttpSession session = null;
	    String msg = "action=create 또는 action=destroy를 전달하시오."; 
	    if(action != null && action.equals("create")) {
	    	session = request.getSession();// getSession(true)와 동일
	    	if(session.isNew())
	    		msg = "세션 객체가 생성됨";
	    	else 
	    		msg = "세션 객체는 이미 생성되어 있었음";    	
	    } else if (action != null && action.equals("destroy")) {
	    	session = request.getSession(false);
	    	if(session != null) {
	    		session.invalidate();
	    		msg = "세션 객체가 삭제됨";
	    	} else 
	    		msg = "삭제할 세션 객체가 없음";    	
	    }
		 
		out.print("<h2>"+msg+"</h2>");
		out.close();
	}
}
  • session = request.getSession(false);
    • 없으면 다시 만들진 않고 null리턴

 


 

'study > JAVA 전문가' 카테고리의 다른 글

[fileIUpload,jsp] 서블릿 구현  (0) 2021.12.30
[servlet]요청 재지정  (0) 2021.12.29
[Servlet] Get방식  (0) 2021.12.28
[HTML] 연습  (0) 2021.12.28
[Servlet & JSP] 1  (0) 2021.12.27

https://www.kaggle.com/dgawlik/house-prices-eda/notebook

 

House Prices EDA

Explore and run machine learning code with Kaggle Notebooks | Using data from House Prices - Advanced Regression Techniques

www.kaggle.com

 

  • Ally (건물 접근 유형)
    • 평균이 FV 가 젤 높다. / 젤 작은 값과 젤 큰 값의 차이가 큼
    • 그렇지만 RL의 가격 분포가 넓다.
  • lotShape 
    • 건물 모양이 작을 수록 가격이 낮음
    • Pave - 분포가 넓고, 가격 차이가 많이 남
  • LandContour (건물의 평탄함 정도)
    • pave가 평균이 젤 높다. 
    • 그렇지만 missing이 더 많고 가격 분포도 넓다.
  • utilities (유틸리티 유형)
    • IR2가 평균이 젤 높음
  • LotConfig (로트 구성)
    • HLS가 평균이 제일 높다
    • HLS가 젤 큰 값과 작은 값의 차이가 많이 난다 -> 평균에 영향있음
    • LV1의 이상치가 많다. 
  • LandSlope (건물의 경사)
    • NoSeWa : 가격이 한개인가봐
    • AlllPub : 이상치 많음, 평균이 낮음
  • Exterior1st
    • Shed 가 평균이 젤 높고, 넓게 안 퍼짐
  • Exterior2st  (집 외부 덮는것)
    • WdShngl 이 평균이 제일 높다.
    • 낮은 가격에서도 가격 변동이 크다. 
  • MasVnrType  (돌쌓기 공사 veneer유형)
    • CemntBd :  높은 가격중에서도 가격 변동이 큼
    • Stone , ImStucc: 평균이 젤 높음
  • ExterQual (외부 재료 품질)
    • CmentBd 가 젤 평균 가격이 높음 
      • 그렇지만, 높은 가격 중에서도 가격 폭이 넓음
    • AsbShng이 젤 평균 가격 낮음
  • BsmtFinType이 Gd가 높음
  • GarageFinish, MiscFeature 는 Ex가 높음

 

 

'study > Kaggle' 카테고리의 다른 글

[House Prices] 정규화된 선형 회귀 모델  (0) 2021.12.28
[House Prices] 데이터 필드 분석  (0) 2021.12.27
  • 서버상에서 실행되는 프로그램
  • RAM 상주 프로그램이였는데 servlet 컨테이너가 커버해준다. 
  • 수행 속도가 빠르고, 구현도 쉬웠다. 

 

등록과 매핑해줘야한다. 

  • xml
  • annotaion
  • 애플릿때문에 생김
    • 클라이언트가 html, js, image인지 웹 서버가 뭘 보고 판단 ? 
      • 요청된 파일의 확장자보고 판단함
  • servlet확장자 .class
    • 애플릿이라는 얘가 web에서 널리 사용하고 있었음
      • .class이면 다 애플릿으로 인식함
      • 애플릿 브라우저에서 실행돼서 java실행 환경을 다 들고있었슴
    • servlet은 확장자로는 판단하지 못했음 
      • 매핑이 만들어짐 

 

  1. 서블릿마다 태그 넣어주는지 (xml)
  2. 앞에 @쓰는 것 (annotation)

요청 및 응답 객체 생성

  • 톰캣안에 코요태 : web서버
    • 매핑보고, 확장자보고 서버에서 실행되는지, 클라이언트에게 줘야하는지 판단
      • 서버에서 실행시키고, 결과를 줘야할 때는 카탈리나에게 넘김(서블릿 컨테이너) 
      • 이미지읽고, 간단한건 코요테 안에서 해결함
    • 카탈리나 (서블릿 컨테이너)
      1. servlet class 메모리에 로딩
      2. response, request 객체를 만듬
      3. client가 요청한 servlet이 객체 생성되어있는지 확인 -> 서비스 호출 (클라이언트 요청할 때마다 )
        • 자기가 만든 http reponse, http request(요청정보)를 매개변수로 서비스에게 전달
          • 서비스는 get인지 host인지 확인
          • get방식이면
            • doGet 오버라이딩, 호출 안 되어있으면 부모의 do get이 호출 됨
          • Post 방식이면
            • doPost 오버라이딩
      4. 객체 생성 안 되어 있으면
        • 젤 먼저 호출 init (최초의 한번만 )-> 서비스 
        • 서비스의 결과가 항상 
      5. 서블릿 객체가 메모리에 사라지는 시점에 destroy 호출

 

 

  • 정해진 메소드만 수행해야함. 
    • 구현해야하는 메소드 사양도 정해져있음 


  • 객체생성을 WAS(Web application Server)가 한다. 
    • 클라이언트가 보낸 쿼리문자열을 담아서 전달하면, 그걸 우린 쓴다 HttpRequest
  • response.getWriter();
    response.setContentType("text/html; charset=UTF-8");
    PrintWriter out = response.getWriter();​
    • response 
      • 클라이언트 응답과 관련된 일
    • io
      • readWriter
        • 문자 스트링(텍스트)
      • input/output
        • 바이너리 (이미지)

 


에러

500 : 실행하다 오류

  • getParameterValues
    • 리턴값이 문자열 배열
    • 하나의 value에 여러개
  • getParameter
    • 리턴값이 string
    • 하나의 value에 하나 올 때

 

 


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<h1>입력폼 학습</h1>
	<hr>
	
	<!--
		method 생략하면 get 
		localhost니깐, 서버주수랑 포트번호 생략
	-->
	
	<form method="get" action = "/edu/query">
		이름 <input type="text" name="p1" required>
		<br> 나이 <input type="number" name="p2"><br>
		
		
		<!-- HTML5 -->
		좋아하는 음식 
		<br> 햄버거 <input type="checkbox" name="p3" value="햄버거">
		비지찌게 <input type="checkbox" name="p3" value="비지찌게"> 
		회덮밥 <input type="checkbox" name="p3" value="회덮밥"> 
		돈까스 <input	type="checkbox" name="p3" value="돈까스"><br>
		
		<input type="submit" value="전송하기"> 
		<input type="reset" value="초기상태로">
	</form>
</body>
</html>
package base;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/query")
public class QueryServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html; charset=utf-8");
		PrintWriter out = response.getWriter();
		String p1 = request.getParameter("p1");
		int p2 = Integer.parseInt(request.getParameter("p2"));
		String p3[] = request.getParameterValues("p3");
		out.print("<ul>");
		out.print("<li>p1 : "+ p1 +"</li>");
		out.print("<li>p2 : "+ p2 +"</li>");
		for(int i=0; i < p3.length; i++)
			out.print("<li>p3["+i+"] : "+ p3[i] +"</li>");
		out.print("</ul>");
		out.close();		
	}
}

  • String p3[] = request.getParameterValues("p3");
    • 아무것도 전달 안 되면 비어있는 배열 리턴함
  • <form method="get" action = "/edu/query"> 
    • action에 url 다 주는 것 -> 절대 url 
    • /edu/query
      • 자동으로 html요청했던 서버 정보로 확장시킴
      • 서버를 여러 개에서 받으면 절대주소 줘야함
    • host방식으로 하면 405에러남

      • doGet 오버라이딩해서 
      • 부모의 있는 httpServlet에 있는 doPost 호출된 것
    • 메소드 속성이 아예 없으면 디폴트 get방식

 


out.print("<a href = '/edu/htmlexam/queryservlettest.html'>입력화면으로</a>");
  • 하이퍼링크 작성함 (.java)

querytest.html

더보기
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	    <form method="GET" 
	    action="http://localhost:8080/edu/querytest">
		이름 : <input name="stname" value="luster1031" required><br>
		암호 : <input type="password" name="pwd"><br>
		나이 : <input type="number" name="age"><br>
		성별 : <input type="radio" name="gender" value="남자">남자
		<input type="radio" name="gender" value="여자">여자
		<br>
		
		취미 : 
		피아노 <input type="checkbox" name="hobby" value="피아노">
		수영 <input type="checkbox" name="hobby" value="수영">
		독서 <input type="checkbox" name="hobby" value="독서">
		게임 <input type="checkbox" name="hobby" value="게임">
		<br>
	
		좋아하는 색 : 
		<select name="color">
		    <option value=""></option>
			<option value="빨강색">RED</option>
			<option value="파랑색">BLUE</option>
			<option value="노랑색">YELLOW</option>
		</select>
		<br>
		
		좋아하는 음식 :
		<br> 
		<select name="food" size="4" multiple>
			<!-- multipe : 원하는 만큼 선택 -->
			<option value="라면">라면</option>
			<option value="냉면">냉면</option>
			<option value="짜장면">짜장면</option>
			<option value="햄버거">햄버거</option>
			<option value="닭강정">닭강정</option>
			<option value="육회">육회</option>
		</select>
		<br>
		
		의견 : 
		<br>
		<textarea name="op" rows="10" cols="50"></textarea><br>
		
		<input type="hidden" name="h_1" value="hidden으로 보낸 첫 번째 내용">
		<input type="hidden" name="h_2" value="hidden으로 보낸 두 번째 내용"> 
		
		<input type="submit" value="보내기">
		<input type="reset" value="다시작성하기">
	</form>
</body>
</html>

QueryTestServlet.java

더보기

QueryTestServlet.java

package base;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/querytest")
public class QueryTestServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		
		String name = request.getParameter("stname");
		String pwd = request.getParameter("pwd");
		int age = Integer.parseInt(request.getParameter("age"));
		
		String gender = request.getParameter("gender");
		
		String[] hobby = request.getParameterValues("hobby");
		String[] food = request.getParameterValues("food");
		
		String color = request.getParameter("color");
		String op = request.getParameter("op");
		
		response.setContentType("text/html; charset=utf-8");
		PrintWriter out = response.getWriter();
		
		out.print("<h2> 전달된 내용 </h2>"); out.print("<hr>");
		
		
		out.print("<ul>");
		out.print("<li> 이름 : " +name+ "</li>");
		out.print("<li> 암호 : " +pwd+ "</li>");
		out.print("<li> 나이 : " +age+ "</li>");
		
		out.print("<li> 성별 : ");
			if (gender == null) {
				out.print("선택 제대로 하세요 -ㅅ-");	
			}
			else {
				out.print(gender);
			}
		out.print("</li>");
		
		out.print("<li> 취미 : ");
			if (hobby == null) {
				out.print("선택 제대로 하세요 -ㅅ-");	
			}
			else {
				for (int i=0 ; i<hobby.length ; ++i) {
					if (i == hobby.length -1) {
						out.print(hobby[i]);
						break;
					}
					out.print(hobby[i] +",");
				}
			}
		out.print("</li>");
		
		out.print("<li> 좋아하는 색 :" +(color == ""?"없음":color) +"</li>");
		out.print("<li> 좋아하는 음식 : ");
		if (food == null) {
			out.print("선택 제대로 하세요 -ㅅ-");	
		}
		else {
			for (int i = 0; i < food.length; ++i) {
				if (i == food.length - 1) {
					out.print(food[i]);
					break;
				}
				out.print(food[i] +",");
			}
		}
		out.print("</li>");
		
		
		out.print("<li> 의견 : " + op + "</li>");
		out.print("<li> 비밀1 : " + request.getParameter("h_1") + "</li>");
		out.print("<li> 비밀2 : " + request.getParameter("h_2") + "</li>");
		
		
		out.print("</ul>"); out.print("<hr>");
		out.print("<a href='/edu/htmlexam/querytest.html'>"
				+ "입력화면으로</a>");
		
		out.close();
	}

}
  • hidden 태그
    • 사용자에 관계없이 자동으로 전달하는 name, value로 작성할 수 있는 tag
    • hidden은 화면에 아무것도 안 나타남
  • 이름 : <input name="stname" value="luster1031" required><br> 
    • 디폴트로 이름이 적혀져 있음
    • type은 text

http://localhost:8080/edu/querytest?
	stname=luster1031&
    pwd=12341&
    age=111&
    gender=%EB%82%A8%EC%9E%90&
    hobby=%ED%94%BC%EC%95%84%EB%85%B8&
    hobby=%EB%8F%85%EC%84%9C&
    hobby=%EA%B2%8C%EC%9E%84&
    color=%ED%8C%8C%EB%9E%91%EC%83%89&
    food=%EB%9D%BC%EB%A9%B4&
    food=%EB%83%89%EB%A9%B4&
    food=%EC%A7%9C%EC%9E%A5%EB%A9%B4&
    food=%ED%96%84%EB%B2%84%EA%B1%B0&
    food=%EB%8B%AD%EA%B0%95%EC%A0%95&
    food=%EC%9C%A1%ED%9A%8C&
    op=2021.12.28+%EC%98%A4%EB%8A%98%EC%9D%80+%EC%88%98%EC%9A%94%EC%9D%BC&
    h_1=hidden%EC%9C%BC%EB%A1%9C+%EB%B3%B4%EB%82%B8+%EC%B2%AB+%EB%B2%88%EC%A7%B8+%EB%82%B4%EC%9A%A9&
    h_2=hidden%EC%9C%BC%EB%A1%9C+%EB%B3%B4%EB%82%B8+%EB%91%90+%EB%B2%88%EC%A7%B8+%EB%82%B4%EC%9A%A9
  • '%'기호와 함께 16진수 코드 값으로 
  • 공백은 '+'문자로 간다. 

getpost.html

더보기

getpost.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<h1>서블릿을 요청하는 다양한 방법</h1>
	<hr>
	<a href="/edu/getpost?name=듀크">하이퍼링크로 요청</a>
	<hr>
	<form method="get" action="/edu/getpost">
		<input type="text" placeholder="이름을입력하세요" name="name"> <input
			type="submit" value="GET방식요청">
	</form>
	<hr>
	<form method="post" action="/edu/getpost">
		<input type="text" placeholder="이름을입력하세요" name="name"> <input
			type="submit" value="POST방식요청">
	</form>
</body>
</html>
  • a 태그로 요청할 수 있는 대상은 제한이 없다.  
    • get 방식
      • form 작성 안 해도, 물음표 뒤에 추가로 전달 가능 
        • 사용자가 직접 이름을 요청할 기회가 없음
      • form 사용시
        • 사용자가 직접 이름 넣기 가능
      • 전달되는 쿼리의 길이의 제한이 있다. (서버마다 다름)
      • 보안이 안 좋음
    • post
      • 전달되는 필드가 주소 필드에 표시가 안 남
      • form 태그를 써야만, 가능
      • 나머지는 get 방식
      • 쿼리가 외부로 안 보임
      • 쿼리 문자열의 길이 제한이 없음
        • 파일 업로드

GetPostServlet.java

더보기

GetPostServlet.java

package base;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/getpost")
public class GetPostServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html; charset=UTF-8");
		PrintWriter out = response.getWriter();
		out.print("<h2>요청 방식 : " + request.getMethod() + "</h2>");
		out.print("<h2>Query 문자열 : " + request.getParameter("name") + "</h2>");
		out.close();
		System.out.println("GET 방식 수행");
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html; charset=UTF-8");
		PrintWriter out = response.getWriter();
		// request.setCharacterEncoding("UTF-8");
		out.print("<h2>요청 방식 : " + request.getMethod() + "</h2>");
		out.print("<h2>Query 문자열 : " + request.getParameter("name") + "</h2>");
		out.close();
		System.out.println("POST 방식 수행");
	}
}
  • servlet 컨테이너가 get이든 post이든 요청하는 api는 똑같다. 
  • get방식

 

  • host 방식

  • 요청 바디에 입력 값 파라미터 담아서 전달
    • 주소창에 입력 값 안 보임
  • 한글 깨짐
    • 전달되는 방법의 차이
    • 요청하기 전에 request.setCharacterEncoding해줘야 함

 


  • 사용자 편의성을 얼만큼 제공하는 사이트인가?

 

 

'study > JAVA 전문가' 카테고리의 다른 글

[servlet]요청 재지정  (0) 2021.12.29
[servlet] 상태정보 유지 기술  (0) 2021.12.29
[HTML] 연습  (0) 2021.12.28
[Servlet & JSP] 1  (0) 2021.12.27
[tomcat] 실습 - html, servelt  (0) 2021.12.27
<tr><th colspan="3">이름,지역,나이</th></tr>

 

  • colspan : 세개의 열 하나로 묶음

 

<tr><td rowspan="2">luster1031</td><td>사랑시고백구행복동</td><td>50</td></tr>
<tr><td>핵복동</td><td>90</td></tr>
  • rowspan : 행 묶음
  • th, td는 그냥 굵게 

 

form 태그

http://localhost:8080/edu/htmlexam/exam2.html?
stname=luster1031&
stpwd=1234&
stage=11111&
stcolor=%23064110&
stfood=f1&stfood=f3&stfood=f4&
gender=female
  • 전송하기 누르면 이렇게 나옴
  • 웹 서버에게 뭔가를 요청하면서 함께 전달하는 name = value형식의 문자열
    • Query String (GET)
    • Request Parameter (POST) 라고 함

 

https://search.naver.com/search.naver?where=nexearch&sm=top_hty&fbm=0&ie=utf8&query=Java
  • naver.com에 java라고 입력시 나타나는 주소
  • GET방식
    • query 정보 외부에 공개
    • 간단함

 

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<h1>입력폼 학습</h1>
	<hr>
	<form>
		이름 <input type="text" name="stname" required>
		<br> 암호 <input type="password" name="stpwd">
		<br> 나이 <input type="number" name="stage"><br>
		
		<!-- HTML5 -->
		좋아하는 칼라 <input type="color" name="stcolor"><br>
		
		<!-- HTML5 -->
		좋아하는 음식 
		<br> 햄버거 <input type="checkbox" name="stfood" value="f1">
		비지찌게 <input type="checkbox" name="stfood" value="f2"> 
		회덮밥 <input type="checkbox" name="stfood" value="f3"> 
		돈까스 <input	type="checkbox" name="stfood" value="f4">
		
		<br> 성별 <br>
		남성 <input type="radio" name="gender" value="male"> 
		여성 <input type="radio" name="gender" value="female"><br> 
		
		<input type="submit" value="전송하기"> 
		<input type="reset" value="초기상태로">
	</form>
</body>
</html>
  • name속성이 없으면, server한테 전달 X
    • name value쌍으로 전달하기 때문
  • name속성은 유니크 해야한다. 
  • checkbox는 이름이 다 똑같아야 한다. 
    • value속성을 써서, name value가 전달하도록해야한다. 
    • value안 쓰면 뭔가 선택된지 모른다. 
  • submit (기본 내장 핸들러가 내장되어 있음)
    • 모든 내용을 쿼리문자로 바꿔서 서버에 전달
    • value : 버튼의 라벨
    • 꼭 있어야 함
  • reset 
    • 처음 랜더링 한 상태로 바꿔줌

 

 

 

  • placeholder : 희미하게 보여줌
    • 힌트 문자열 표현해줌
    • 입력하면 자동으로 사라짐

 

<li><label for=phone>연락처</label> 
	<input id=phone name=phone type=tel 
		placeholder="00*-000*-0000" pattern="[0-9]{2,3}-[0-9]{3,4}-[0-9]{4}"></li>
  • pattern, placholder사용

 

<li>
	<label for=date_of_birth>생일</label> 
	<input id=date_of_birth name=date_of_birth type=date min="1950-01-01" max="2000-01-01">
</li>
  • max : 2000.01.01 이후에는 안 나옴
  • min : 1950.01.01

 

<li>
	<label for=gender>성별</label> 
	<input id=gender name=gender type=text list=gender_list> 
	<datalist id=gender_list>
		<option value=male label=남>
		<option value=female label=여>
	</datalist></li>

  • 입력상자인데
    • 많이입력되는 항목 먼저 리스트에 보여줌

 

  • testarea 
    • 큰 입력상자 사용자에게 제공
    • 여러 행 입력할 수 있게 해줌

 

  • select
    • mutipul : 체크박스와 비슷 (여러개 선택 가능)

 

  1. file

 

  • 개행
    • 개행 여러개 줘도 블랭크 하나로 인식하게 된다. 
    • html에서 개행을 br 태그로 함
      • 싱글 사이드 태그 : 닫는게 없음
    • <p> 
      • 하나의 단락으로 묶을 수 있음
      • 중간에 빈 행도 적당하게 들어감 (조금 줄 간의 간격 뛰어줌)

'study > JAVA 전문가' 카테고리의 다른 글

[servlet] 상태정보 유지 기술  (0) 2021.12.29
[Servlet] Get방식  (0) 2021.12.28
[Servlet & JSP] 1  (0) 2021.12.27
[tomcat] 실습 - html, servelt  (0) 2021.12.27
[Web programming]  (0) 2021.12.27

Regularized Linear Models

https://www.kaggle.com/apapiu/regularized-linear-models

 

 

Regularized Linear Models

Explore and run machine learning code with Kaggle Notebooks | Using data from House Prices - Advanced Regression Techniques

www.kaggle.com

  • 숫자를 log_transform 하는게 핵심!

matplotlib.rcParams['figure.figsize'] = (12.0, 6.0)
prices = pd.DataFrame({"price":train["SalePrice"], "log(price + 1)":np.log1p(train["SalePrice"])})
prices.hist()
  • rcParmas
    • 그래프를 그리기 위해서 사용
    • 딕셔너리 값을 이용해서 그림
  • log(price + 1)을 이용하여 치우친 숫자를 좀 완화시킴
  • 정규화 됨

skewed_feats = train[numeric_feats].apply(lambda x: skew(x.dropna())) #compute skewness
skewed_feats
  • skew : 왜도
 

[Scipy.stats] 왜도(Skew) / 첨도 (Kurtosis)

from scipy.stats import skew, kurtosis # 왜도 skew(data) # 첨도 kurtosis(data, fisher=True) 왜도 (Skewness) - 분포의 비대칭도. - 정규분포 = 왜도 0 - 왼쪽으로 치우침 = 왜도 > 0 - 오른쪽으로 치우침 =..

mizykk.tistory.com

 


all_data = pd.get_dummies(all_data)
  • get_dummies를 이용하여 결측값 제외하고 0과 1로 구성된 더미값이 만들어짐
    • object값들
  • dummy_na = True를 이용하면, 결측값도 인코딩하여 처리해줌

 


def rmse_cv(model):
    rmse= np.sqrt(-cross_val_score(model, X_train, y, scoring="neg_mean_squared_error", cv = 5))
    return(rmse)
  • rmse
    • cross_val_score를 사용해서 rmse를 알아본다. 
    • rmse는 낮을 수록 정확도가 높다고 보면 된다. 

 

matplotlib.rcParams['figure.figsize'] = (6.0, 6.0)

preds = pd.DataFrame({"preds":model_lasso.predict(X_train), "true":y})
preds["residuals"] = preds["true"] - preds["preds"]
preds.plot(x = "preds", y = "residuals",kind = "scatter")

  1. lasso 모델이 예측한 x_train값을 preds로 
  2. true 행을 실제 y값으로해서 

residuals를 [실제값 - 예측한 값]

 


 

xgboost

# DMatrix : 전용 데이터 셋
dtrain = xgb.DMatrix(X_train, label = y)
dtest = xgb.DMatrix(X_test)

params = {"max_depth":2, "eta":0.1}
model = xgb.cv(params, dtrain,  num_boost_round=500, early_stopping_rounds=100)​

 

  1. 파라미터
    • eta
      • 학습률과 같은 파라미터 
      • 0~1 사이 값
    • max_depth
      • 깊이라고 생각하면 됨
      • 높으면 특정 피쳐 조건에 특화 됨 -> 과적합 가능성 높음
      • 3~10 사이 값 적용
  2. CV()
    • 최적의 파라미터 구할 수 있는 api
  3. early_stopping_rounds
    • 조기중단,
    • 예측 오류가 더이상 개선 안 되면 반복 끝까지 수행하지 않고 중지
  4. num_boost_rounds 
    • 결정트리의 갯수 지정

https://velog.io/@sset2323/04-06.-XGBoosteXtra-Gradient-Boost

 

04-06. XGBoost(eXtra Gradient Boost)

위키북스의 파이썬 머신러닝 완벽 가이드 책을 토대로 공부한 내용입니다.

velog.io

 

model_xgb = xgb.XGBRegressor(n_estimators=360, max_depth=2, learning_rate=0.1)
model_xgb.fit(X_train, y)
  • 회귀를 위한 XGBRegressor
    • eta -> learning_rate
    • n_extimators : 생성될 트리의 개수

 

 

[결론]

  • tain, test합치고
  • 타입이 object아닌 값 중에서 비대칭도가 왼쪽으로 0.75 치우친 값만 log취함
  • ridge 모델, lasso모델 비교 -> rmse값이 lasso가 낮아서 선택함
  • xgboost 값 비교함 
  • xgboost 값 * 0.7 + lasso * 0.3 더했음 ( 왜 더했는지 모르겠다,,)

'study > Kaggle' 카테고리의 다른 글

[House Prices-2] House Prices EDA  (0) 2021.12.28
[House Prices] 데이터 필드 분석  (0) 2021.12.27

https://www.kaggle.com/c/house-prices-advanced-regression-techniques

 

House Prices - Advanced Regression Techniques | Kaggle

 

www.kaggle.com

 

  • 판매 가격(SalePrice) - 달러화 매매가격 (예측해야함)
  • MSSubClass - 빌딩 클래스
  • MSZoning - 일반 구역으로 분류하는 것
  • LotFrontage : 거리의 선형 피트?
  • LotArea : 로트 크기(제곱 피트)
  • Street : 도로 접근 유형
  • Alley : 골목 접근 유형
  • LotShape : 건물의 일반 모양
  • LandContour : 건물의 평탄함 정도
  • Utilities : 사용가능한 유틸리티 유형
  • LotConfig : 로트 구성
  • LandSlope : 건물의 경사
  • Neighborhood : Ames 시 경계 내의 물리적 위치
  • Condition1 : 도로 또는 철도와의 근접함
  • Condition2 : 도로 또는 철도와의 근접함 (만약 초가 있는 경우?)
  • BldgType : 주택 유형
  • HouseStyle : 주택 스타일
  • OverallQual : 전체적인 재료, 마감 품질
  • OverallCond : 전체적인 상태 순위
  • YearBuilt : 시공일자 (만든 일)
  • YearRemodAdd : 리모델링 일자
  • RoofStyle : 지붕 스타일
  • RoofMatl : 지붕 재료
  • Exterior1st : 집 외부 덮는 것
  • Exterior2nd : 집 외부 덮는 것 (만약 재료가 더 있으면)
  • MasVnrType : 석조(돌 쌓기 공사) veneer 유형
  • MasVnrArea : 석조 veneer 면접 (평방피트)
  • ExterQual: 외부 재료 품질
  • ExterCond: 외관의 자재 현황
  • Foundation: 기초 유형
  • BsmtQual: 지하실 높이
  • BsmtCond: 지하실의 일반 상태
  • BsmtExposure: Walkout 또는 정원 레벨 지하실 벽
  • BsmtFinType1: 지하실 마감 면적 품질
  • BsmtFinSF1: 타입 1 마감 평방 피트
  • BsmtFinType2: 있는 경우) 두 번째 마감 영역의 품질
  • BsmtFinSF2: 타입 2 마감 평방 피트
  • BsmtUnfSF: 미완성된 자하실의 평방피트
  • TotalBsmtSF: 지하실의 총 평방피트
  • Heating: 난방 유형
  • HeatingQC: 난방의 품질 및 상태
  • CentralAir: 중앙 에어컨
  • Electrical: 전기 시스템
  • 1stFlrSF: 1층 평방 피트
  • 2ndFlrSF: 2층 평방 피트
  • LowQualFinSF: 모든 층의 저품질 마감 평방 피트
  • GrLivArea: 지상 거주 지역 평방 피트
  • BsmtFullBath: 지하 전체 욕실
  • BsmtHalfBath: 지하 반쪽 욕실
  • FullBath: 지상 전체 욕실
  • HalfBath: 지상 반쪽 욕실
  • Bedroom: 지하 1층 이상의 침실 수
  • Kitchen: 주방 갯수
  • KitchenQual: 주방 품질
  • TotRmsAbvGrd: 총 지상 객실 수 (화장실 포함 안 함)
  • Functional: 집의 기능 등급
  • Fireplaces: 벽난로의 수
  • FireplaceQu: 벽난로 품질
  • GarageType: 차고 위치
  • GarageYrBlt: 차고가 지어진 년도
  • GarageFinish: 실내 내부 마감
  • GarageCars: 자동차 용량의 차고 크기
  • GarageArea: 평방피트 단위의 차고 크기
  • GarageQual: 차고 품질
  • GarageCond: 차고 상태
  • PavedDrive: 포장 도로
  • WoodDeckSF: 목재 데크 면적 (평방 피트)
  • OpenPorchSF: 열린 현관 영역(평방 피트)
  • EnclosedPorch: 닫힌 현관 영역(평방 피트)
  • 3SsnPorch: 3계절 현관 면적(평방 피트)
  • ScreenPorch: 스크린 현관 면적(평방 피트)
  • PoolArea: 수영장 면적(제곱 피트)
  • PoolQC: 수영장 품질
  • Fence: 울타리 품질
  • MiscFeature: 다른 범주에서는 다루지 않는 기타 기능
  • MiscVal: $기타 기능 값
  • MoSold: 판매된 달
  • YrSold: 판매된 년도
  • SaleType: 판매 종류
  • SaleCondition: 판매 상태

'study > Kaggle' 카테고리의 다른 글

[House Prices-2] House Prices EDA  (0) 2021.12.28
[House Prices] 정규화된 선형 회귀 모델  (0) 2021.12.28
  1. 웹 프로그래밍 기초
    • 서버는 서버대로, 클라이언트는 클라이언트대로 있어야 한다. 

http 

  1. 웹의 표준프로토콜 
    1. 요청
      • client가 요청함 
    2. 처리
      • web서버가 요청 받음
    3. 응답
      • html 문서 응답함
    4. 하나하나 읽어서 document로 랜더링함
      • 태그에 알맞게 보여줌 : 랜더링

 

  1. connection oriented
    • 접속이 되어야지 통신함 
    • 신뢰성있는 통신함 
    • 반드시 접속해야함
    • tcp 프로토콜 사용함
    • 접속상태 유지하면, 다른 client 유저가 server에 접속할 수 있는 기회 없어짐
      • 그 부분 염려하여 stateless만듦
  2. stateless
    • 접속상태 계속 유지하지는 않음
    • 클라이언트 요청오고 응답하면 끊어버림
    • 처리 호율 높임

 

  • 요청방식
    • GET
    • POST
      • 로그인 (정보 중요한 것)
      • 파일 업로드

 

Servlet jsp

  • servlet으로 구현할 수 있는건 jsp로 구현 가능
    • java가 주인공인 것
    • 출력형식을 html으로
    • 요청과 관련된 것
  • jsp로 구현할 수 있는 건 servlet으로 구현 가능
    • html이 주인공
    • 필요한 부분에 java 코드 끼워 넣는 것
    • 응답에 관련된 것

 

mvc모델

  • 각 분리해서 개발하는 모델

 

맵핑 모델

  • xml
    • web.xml에 넣는 것
  • annotaion
    • @Webservlet("/hello")
    • 두개 이상 등록도 가능함

 

  • WAS : Web Application Server
    • Web Server + Application Server
      • Application Server : Servlet Container + JSP Converter
      • Servlet Container에 main클래스 있음
    • 무조건 객체 생성 X
      • 생성 되어 있으면 생성 안 함
      • 생성 안되어 있으면 생성 함
      • servlet는 객체 하나만 있음
        • 하나로 모든 클라이언트와 공유함
      • in호출 
      • service 호출
        • doGet, doPost호출

'study > JAVA 전문가' 카테고리의 다른 글

[Servlet] Get방식  (0) 2021.12.28
[HTML] 연습  (0) 2021.12.28
[tomcat] 실습 - html, servelt  (0) 2021.12.27
[Web programming]  (0) 2021.12.27
[mongoDB] 날짜 데이터  (0) 2021.12.24
  • http://localhost:8080/edu/htmlexam/first.html (http url string)
  • url : uniform resource locator  
    1. protocol (http통신 기반)
    2. serveraddress
      • localhost == 127.0.0.1
    3. port number (8080)
    4. URI
      • uniform resource identity
      • 서버에 가는 것 (요청하는 것)
      • /edu/htmlexam/first.html
        1. /edu : context path 
          • 역할 : 어떠한 웹 프로젝의 자원을 요청할 것인가?
          • edu 폴더에 가서 자원을 찾는다. 
          • 한 덩어리의 context로 본다. 
        2. /htmlexam/first.html 등록된 얘가 있나 확인
          • 없으면 web app 폴더 찾아감
            • document root라고 보면 됨
            • 최상위 폴더 

  • status : 200 -> 성공적으로 받아왔다. 

 

  • get방식으로 들고옴
    • default 방식임

servlet 실습

  • 클래스 명이 아닌, mapping명과 연결
    • 특정 servlet 요청할 때, 전체 경로 대신 간단하게 경로 표현해주는 것
    • 맵핑 방법 
      • xml
      • annotaion
  • 클래스명과 mapping명 다르게 하는게 보안적으로 좋음

'/' 빼먹으면 안 된다.


import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/first")
public class FirstServelt extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		response.setContentType("text/html; charset=UTF-8");
		PrintWriter out = response.getWriter();
		out.print("<h1>First Servlet 수행 완료 <h1>");
		out.close();
		System.out.println("서블릿에서의 표준 출력은 어디로 나가나?");
	}

}
  1. /first 로 매핑
    • 톰캣 재 기동 걸어줘야함
    • 새로 추가한 파일은 인식해도 소스 내용은 인식 못 함
      • 자동으로 인식하지 못함 -> 자동으로 인식하면 서버성능 떨어뜨림
  2. 반 정도 프레임워크 기술
  3. 누구한테 내보낼 것인가 명시해줘야한다. 
  4. 개행문자를 개행문자로 인식 X
    • 여러 개 블랭크 하나로 인식함 -> println쓰는게 소용 없

 


MIME 타입

response.setContentType("text/plain; charset=UTF-8");​
  • 이렇게 하면 일반 텍스트로 
  • html으로 하면 랜더링 할 준비를 함
    • html에 알맞게
  • 절대로 오타 입력하면 안 된다.
  • 한글 깨질 가능성 있다.

 


PrintWriter out = response.getWriter();
		out.print("<h1>First Servlet 수행 완료 </h1>");
		out.close();
  • 출력객체 받아와서 출력해야한다. 

 


out.print("<h2>반가워요...: " + request.getParameter("name") + "님!!</h2>");

이렇게해서 주소창에 

http://localhost:8080/edu/first?name=myname

myname부분에 요청하면 된다. 

 


 

'study > JAVA 전문가' 카테고리의 다른 글

[HTML] 연습  (0) 2021.12.28
[Servlet & JSP] 1  (0) 2021.12.27
[Web programming]  (0) 2021.12.27
[mongoDB] 날짜 데이터  (0) 2021.12.24
[mongoDB] 2  (0) 2021.12.23

+ Recent posts