네트워크상에서 데이터가 줄지어서 흘러 들어가는 것
대역폭이 크면 넓게 들어갈 수 있고
대역폭이 작으면 좁게, 차선에 맞춰서 줄지어서 간다.
ex_) 저장장치에있는걸 화면으로 불러오는것
네트워크상에서 데이터가 줄지어서 흘러나오는 것
ex)화면에있는걸 저장장치에 저장
주기억장치⇒화면에보이게해주는것
import java.io.File;
- .exists()
- 존재하는지 확인하는 메서드
메서드 | 의미 | |
---|---|---|
파일 변수. | getName() | 파일의 이름 |
getAbsolutePath() | 파일의 경로 | |
canWrite() | 파일이 쓰기 가능한가? | |
canRead() | 파일이 읽기 가능한가? | |
length() | 파일의 크기 | |
createNewFile() | 새로운 파일 생성 | |
close() | 입출력 관련 클래스의 리소스를 해제하고 버퍼를 비우는 역할. (예외처리의 역할도 한다.) | |
package ex12;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
public class Example02 {
public static void main(String[] args) {
String str = "Hello! Java Programming";
File f;
FileOutputStream fos = null; // null을하는 이유는, 클로즈 해주기 위해 생성해주는 작업임.
try {
f = new File("src\\ex12\\example02.txt");
if (!f.exists()) { // 없으면 참이 됨.
f.createNewFile();
}
// 스트림 방식의 출력 파일 생성 그래서 출력도 바이트 스트림을 출력
fos = new FileOutputStream(f);
// str은 문자열이고, 그것을 바이트 형태로 가져오기.
byte[] b = str.getBytes();
fos.write(b);
System.out.println("파일쓰기 성공");
} catch (IOException e) {
System.out.println(e.getMessage());
} finally {
try {
if (fos != null) {
fos.close();
}
} catch (IOException e) {
System.out.println(e.getMessage());
}
}
}
}
package ex12;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
public class Example03 {
public static void main(String[] args) {
FileWriter myWr = null;
try {
File f = new File("src\\ex12\\example03.txt");
if(!f.exists()) {
f.createNewFile();
}
myWr = new FileWriter(f);
myWr.write("Hello!!\n");
myWr.write("Java Programing");
System.out.println("파일 쓰기 성공");
}
catch(Exception e) {
System.out.println(e.getMessage());
}
finally {
if(myWr != null) {
try {
myWr.close();
}
catch(IOException e) {}
}
}
}
}
package ex12;
import java.io.File;
import java.io.FileWriter;
import java.util.Scanner;
import java.io.IOException;
public class Filehandling03 {
public static void main(String[] args) {
File file = new File("src\\ex12\\member.txt");
FileWriter fw = null;
try {
if (!file.exists()) {
file.createNewFile();
}
fw = new FileWriter(file);
Scanner s = new Scanner(System.in);
boolean quit = false;
while(!quit) {
System.out.println("아이디 : ");
String userID = s.next();
fw.write("아이디 : "+ userID+"\n");
System.out.println("이름 : ");
String userName = s.next();
fw.write("이름 : "+ userName+"\n");
System.out.println("계속 진행? Y | N");
//왜 다시 스캐너를 생성하지?
s = new Scanner(System.in);
String str = s.nextLine();
if (str.toUpperCase().equals("N")) {
quit = true;
}
}
System.out.println("파일 쓰기 성공");
}
catch(Exception e) {
System.out.println(e.getMessage());
}
finally {
if (fw!=null) {
try{fw.close();
}
catch(IOException e) {}
}
}
}
}
package ex12;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
// FileOutputStream , FileInputStream, FileWriter, FileReader는 파일 읽기쓰기에 관여함.
// Stream은 바이너리타입(외부적 활용. 예를 들면 통신), 이외는 텍스트타입(내부적 활용)에 쓰임.
// ★★★ 위 4가지를 작성 함에 있어 공통점이 있다. ★★★(아래 예시는 FileOutputStream으로 진행.)
// 1. File 파일의객체이름 = new File("파일이름.파일형식"); => '파일타입 객체'를 생성해줌.(파일의 생성과 관련된 조건문에 관여함.)
// 2. FileOutputStream 클래스변수 = null; => try문 시작부에서 클래스변수로 FileOutputStream 선언 (이 객체는 직접적인 쓰기에 관여함.)
// 3. if(!파일객체이름.exists()){ 파일객체이름.createNewFile} => try문 시작부에서 '파일타입 객체'는 if문을 활용해서 파일존재를 검증하고, 새로운파일 생성.
// 4. 클래스변수 = new FileOutputStream; => try문 내부에서 FileOutputStream과 관련해서 초기화시켜줌.(선언 했으면 초기화 해야하기 때문)
// 5. 쓰고싶은 것, 읽고 싶은 것을 작성함. => try문 내부에서 원하는 문구를 작성함.
// 6. catch(Exception e) {System.out.println(e.getMessage()); => catch로 오류잡기. 오류와 관련된 메세지를 출력.
// 7. finally{try{ 클래스변수.close(); } catch(IOException e){} } => close()함수는 반드시 실행해야됨. 만약 오류라면 입출력 관련오류(IOException)를 catch 해줘야한다.
public class Example04 {
public static void main(String[] args) {
FileInputStream fis = null;
try {
File file = new File("example03.txt");
if(!file.exists()) {
file.createNewFile();
}
//file을 입력용으로 생성해라(오픈해라)
fis = new FileInputStream(file);
int i = 0;
while((i=fis.read())!=-1) { //파일의 끝이면 fis.read()=-1 이 출력됨.
System.out.println((char)i);
}
}
catch(Exception e) {
System.out.println(e.getMessage());
}
finally{
try {
fis.close();
}
catch(IOException e) {}
}
}
}
💡 FileWriter는 텍스트타입(내부) 작성, FileOutputStream은 바이너라타입(외부통신) 작성에 쓰이는구나!
get
- 데이터를 서버로 전송하기 위해 URL의 쿼리 문자열(query string)에 데이터를 첨부하여 전송합니다.
- 전송한 데이터가 URL에 노출되므로 보안에 취약할 수 있습니다.
- 데이터의 길이 제한이 있으며, 대부분의 브라우저는 약 2,048자로 제한합니다.
- 브라우저에서 캐싱할 수 있으므로, 같은 요청을 반복할 경우 캐시된 결과를 가져올 수 있습니다.
- 주로 데이터 조회 등의 요청에 사용됩니다.
post
- 데이터를 HTTP 요청의 본문(body)에 담아 서버로 전송합니다.
- URL에 데이터가 노출되지 않으므로 GET보다 보안적으로 우수합니다.
- 데이터의 길이 제한은 없지만, 서버와 클라이언트 간에 약속된 최대 크기가 있을 수 있습니다.
- 브라우저에서 캐싱할 수 없으므로, 같은 요청을 반복할 때마다 새로운 결과를 가져옵니다.
- 주로 데이터 생성, 수정, 삭제 등의 요청에 사용됩니다.
포스트는어디?
웹 - Web - WAS - DB
web은 어플리케이션 보호하려고 분리되어있다.
HTML, CSS, JavaScript 등 클라이언트 요청에 따라 변하지 않음.
PHP, Java, Python 등 클라이언트 요청에 따라 동적으로 생성됨.
- 클라이언트가 웹페이지 요청
- 웹서버가 요청을 분석하여 처리
- 결과를 html문서로 생성
- 요청에 맞게 정제된 html문서를 전달
- 웹브라우저가 html을 보여줌.
스크립트태그 | 형식 | 설명 |
---|---|---|
선언문(declaration) | <%! %> | 전역 범위 선언, 서블릿 클래스 멤버 선언, 초기화 |
스크립트릿(scriptlet) | <% %> | Java코드를 작성할 수 있고, 서버 측 로직을 처리하거나 변수를 선언할 때 사용 |
표현문(expression) | <%= %> | 변수나 결과값 출력. 한 번에 하나의 변수(혹은 메서드)를 출력하며 세미콜론’;’을 쓰지 않는다. |
jspService()
메서드는 JSP 컨테이너에 의해 자동으로 생성되고 호출되는 메서드
jspService()
메서드는HttpServlet
클래스의service()
메서드를 오버라이드하여 JSP 페이지의 동작을 정의
형식 | ||
---|---|---|
page | <%@ page %> | 설명페이지에 대한 정보 설정 |
include | <%@ include %> | 페이지 특정 영역에 다른 문서를 포함 |
taglib | <%@ taglib %> | 사용할 태그 라이브러리 설정 |
속성 | 설명 | 기본 값 |
---|---|---|
language | 현재 JSP페이지가 사용할 프로그램이 언어를 설정 | |
contentType | 현재 JSP페이지가 생성할 문서의 콘텐츠 유형을 설정 | |
pageEncoding | 현재 JSP페이지의 문자 인코딩을 설정 | |
import | 현재 JSP페이지가 사용할 자바 클래스 설정 | |
session | 현재 JSP페이지의 세션 사용 여부를 설정 | |
buffer | 현재 JSP페이지의 출력 버퍼 크기를 설정 | |
autoFlush | 출력 버퍼의 동작 제어를 설정 | |
isThreadSafe | 현재 JSP페이지의 멀티스레드 허용 …. | |
info | … | |
errorPage | ||
isErrorPage | ||
isELIgnored | ||
isScriptingEnabled |
isELIgnored
ex_) var now = new Date("2020-10-15");
window객체의 프로퍼티 | |
---|---|
document | 브라우저 창에 표시된 웹 문서에 접근할 수 있다. |
frameElement | 현재 창이 다른 요소 안에 포함되어 있을 경우 그 요소를 반환. 반대로 포함되어 있지 않으면 null값을 반환. |
innerHeight | 내용 영역의 높이를 나타낸다. |
innerWidth | 내용 영역의 너비를 나타낸다. |
localStorage | |
location | |
name | |
outerHeight | |
outerWidth | |
pageXOffset | |
pageYOffset | |
parent | |
screenX | |
screenY | |
scrollX | |
scrollY | |
sessionStorage | |
종류 | 설명 |
---|---|
alert() | 알림 창을 표시한다. |
blur() | 현재 창에서 포커스를 제거한다. |
close() | 현재 창을 닫는다. |
confirm() | 확인,취소 버튼이 있는 확인 창을 만든다. |
focus() | 현재 창에 포커스를 부여한다. |
moveBy() | 현재 창을 지정한 크기만큼 이동한다. |
moveTo() | 현재 창을 지정한 크기만큼 이동한다. |
open() | 새로운 창을 연다. |
postMessage() | 메시지를 다른 창으로 전달. |
jprint() | 현재 문서를 인쇄. |
prompt() | 프롬프트 창에 입력한 텍스트를 반환. |
resizeBy() | 지정한 크기만큼 현재 창의 크기를 조절한다. |
resizeTo() | 동적으로 브라우저 창의 크기를 조절한다. |
scroll() | 문서에서 특정 위치로 스크롤한다. |
scrollBy() | 지정한 크기만큼 스크롤한다. |
scrollTo() | 지정한 위치까지 스크롤한다. |
sizeToContent() | 내용에 맞게 창의 크기를 맞춘다. |
stop() | 로딩을 중지한다. |
//css
#button1{
width:100px;
height:100px;
background-color: red;
color:white;
border-radius:50%;
border: 10px solid gray;
}
// js
function pupupw(){
window.open("파일이름.jsp","","width=500, height=400");
}
// html
<button id="button1" onclick="javascript:pupupw();">팝업 열기</button>
팝업위치 설정하기
웹브라우저의 버전을 비롯해 플러그인 설치 정보나 온,오프라인 등의 여러 정보가 담겨있다.
정보를 보는 것.
<button class="button1" onclick="location.replace('http://www.easyspub.com')">이지스퍼블리싱 홈페이지</button>
새로운 브라우저 창 또는 탭을 열기 위해 사용
_blank
_self
_parent
_top
이를 열게 된 원래 창(부모 창)을 가르킨다.
객체를 통해 부모 창의 속성에 접근하거나 부모 창으로 데이터를 전달할 수 있다.
팝업 코드
1
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>팝업창 열기</title>
<script type="text/javascript">
let popWin = window.open("doitEvent.jsp","popup","width=750, height=600, left=100,top=100");
popWin.opener = self; // popWin 객체를 만든 부모가 자신(self)이라고 알려줌.
</script>
</head>
<body>
<p>문서를 열면 팝업창이 표시됩니다.</p>
</body>
</html>
2
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>이벤트 공지</title>
</head>
<style>
body{
display:flex;
justify-content:center;
align-items:center;
flex-direction:column;
width:100vw;
height:100vh;
background-color:yellow;
}
.image{
width:200px;
height:auto;
border-radius:12%;
border: 3px double black;
}
</style>
<script>
function loadURL(){
//alert(url);
window.opener.location=url;
window.close();
}
</script>
<body>
<div id="container">
<img class="image" alt="" src="">
<p><a href="doitMain.jsp"
onclick="javascript:loadURL(this.href; return false;)">자세히보기</a>
</div>
</body>
</html>
3
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Do it!!</title>
<style>
#container{
width:750px;
margin: 0 auto;
text-align:center;
}
</style>
<script>
</script>
</head>
<body>
<div id="container">
<img src="http://www.easyspub.co.kr/upload/smarteditor/BOOK/2016/20160418190258778248.jpg">
</div>
</body>
</html>