728x90

(1) 강의내용

  • AWS
    • AWS 서버 구매하기
    • 서버 세팅하기
    • flask 서버 실행해보기
    • AWS에서 포트 열어주기
    • Robo3T에서 DB연동
    • 포트 포워딩
    • nohup 설정하기
  • 도메인 구입
  • og 태그 만들기
  • 5주차 숙제
    • 도메인 올리기

(2) AWS

  • EC2 서버 구매하기
    1. aws.amazon.com/ko/ <- aws링크에서 회원가입 및 로그인
    2. EC2를 사용하여 클릭
    3. Ubuntu Server 18.04 LTS(HVM), SSD Volume Type - 64비트(x86) 선택
    4. 검토 및 시작
    5. Key Pair를 저장 후 런치
  • EC2 서버에 접속하기
    • git bash로 입력
    • ssh -i 받은키페어를끌어다놓기 ubuntu@AWS에적힌내아이피

 

 

  • 서버 세팅하기
    1. Filezilla 실행
    2. Connect 버튼 클릭
    3. New Site 버튼 클릭
    4. Protocol : SFTP, Host : AWS에 적힌 아이피, Port : 22, Logon Type : Key File, User : ubuntu,                                     Key File : Key pair 위치
    5. Filezilla에 아래 initial_ec2.sh 다운
    6. sudo chmod 755 initial_ec2.sh 로 환경 세팅
  • AWS에서 포트 열어주기
    1. EC2 관리 콘솔로 이동
    2. 해당 인스턴스 클릭
    3. 보안 클릭
    4. 보안 그룹 클릭
    5. 인바운드 규칙 편집
      • HTTP / TCP / 80 / 사용자 지정 / 0.0.0.0/0
      • HTTP / TCP / 80 / 사용자 지정 / ::/0
      • SSH / TCP / 22 / 사용자 지정 / 0.0.0.0/0
      • 사용자 지정 TCP / TCP / 5000 / 사용자지정 / 0.0.0.0/0
      • 사용자 지정 TCP / TCP / 5000 / 사용자지정 / ::/0
      • 사용자 지정 TCP / TCP / 27017 / 사용자지정 / 0.0.0.0/0
      • 사용자 지정 TCP / TCP / 27017 / 사용자지정 / ::/0
  • Robo3T DB 연동
    1. Connect 클릭
    2. Create 클릭
    3. Connection Settings
      • Connection
        • Type : Direct Connection
        • Name : dbName
        • Address : AWS에 적힌 아이피 : 27017
      • Authentication
        • Perform authentication 체크
        • Database : admin
        • User Name : test
        • Password : test
    4. Test 후 저장
    5. Python Code 변경
client = MongoClient('mongodb://test:test@localhost', 27017)
  • nohup 설정하기
    • nohup이란? SSH 접속을 끊어도 서버가 계속 동작하고 있음
# 아래의 명령어로 실행하면 된다
nohup python app.py &

# 아래 명령어로 미리 pid 값(프로세스 번호)을 본다
ps -ef | grep 'app.py'

# 아래 명령어로 특정 프로세스를 죽인다
kill -9 [pid값]

 

initial_ec2.sh
0.00MB


(2) 도메인 구입하기

  • 도메인 구입/연결
    1. www.gabia.com/ <- 가비아링크에서 회원가입 및 로그인
    2. 도메인 구입
    3. DNS 관리 툴 클릭
    4. 해당 도메인 설정 클릭
    5. 값/위치 에 IP 작성 후 저장

(3) og 태그

  • Code
<meta property="og:title" content="내 사이트의 제목" />
<meta property="og:description" content="보고 있는 페이지의 내용 요약" />
<meta property="og:image" content="{{ url_for('static', filename='ogimage.png') }}" />
 

카카오계정 로그인

여기를 눌러 링크를 확인하세요.

accounts.kakao.com

 

공유 디버거 - Facebook for Developers

공유 디버거를 사용하면 Facebook에 공유될 때 콘텐츠가 표시되는 모습을 미리 보거나 오픈 그래프 태그를 사용하여 문제를 디버깅할 수 있습니다. 이 도구를 사용하려면 Facebook에 로그인하세요.

developers.facebook.com


(4) 5주차 숙제


(5) 느낀점

드디어 마지막 5주차가 끝났습니다. 현재 취준생인 저로써는 하루에 1주차씩 5일정도를 소모하여 5주차를 완료할 수 있었습니다.

웹개발 종합반을 들으면서 대단한건 아니지만 처음부터 끝(도메인)까지 개발한 경험을 얻을 수 있어 의미있는 시간이였고, 학생들이 흥미를 느낄 수 있도록 수업 커리큘럼이 잘 짜여진 것 같습니다. 하지만 짧은 시간을 들여서 경험한 전체적인 틀을 조금조금씩 다루는 정도 여서 깊이는 조금 아쉬웠습니다. 


반응형
728x90

(1) 원인

  • CSS, JS, img 파일들을 변경시킨 후 적용이 안되는경우가 많다 그 이유는 캐시메모리에 저장되어있어 파일들을 다시 불러오지 않기 때문인다. 그렇기에 캐시메모리를 지워줄 필요가 있다.

(2) 방법

  • 캐시메모리를 지우는 방법 중 하나는 개발자도구(F12) -> NetWork -> Disable cache를 아래와 같이 check 해주면 매번 통신을 새로 불러오게된다.

  • Ctrl + Shift + r 단축키를 통해서도 매번 업데이트 할 수 있다.

 

반응형
728x90

(1) JWT(Json Web Token)란?

  • Json Web Token의 약자입니다.
  • 서버와 클라이언트 간 정보를 주고 받을 경우 별다른 인증과정 없이 Http Request 헤더에 포함되어 있는 토큰을 통해 인증합니다.
  • 토큰은 비공개 Secret 키 또는 공개/비공개 키를 사용하여 서명합니다.
  • 장점
    • 다수의 도메인 - 쿠키는 발행한 서버에서만 유효하지만 JWT는 토큰만 유효하다면 상관없습니다.
    • 선택적인 권한 부여 - 아마존에 구글 계정으로 로그인 할 수 있어도 아마존이 로그인한 구글 계정의 메일을 읽을 수 없습니다.
    • 다양한 디바이스 지원 - 웹 앱 간의 상이한 쿠키 세션을 처리할 수 있습니다.
  • 단점
    • 토큰은 데이터베이스를 조작하더라도 토큰에 적용할 수 없습니다.
    • 데이터 트래픽 크기에 영향을 미칠 수 있습니다.

(2) JWT(Json Web Token) 구조

JWT 구조
JWT Encoded, Decode 예제

  • HEADER
    • alg - 알고리즘 방식을 지정합니다
      • HS256
      • RSA
    • typ - 토큰의 타입을 지정
      • JWT
  • PAYLOAD
    • iss(issuer) - 토큰 발급자
    • sub(subject) - 토큰 제목
    • aud(audience) - 토큰 대상자
    • exp(expiration) - 토큰 만료시간 (항상 현재시간보다 늦어야 함)
    • nbf(not before) - 토큰 활성 날짜
    • iat(issued at) - 토큰 발급시간
    • jti(JWT ID) - 토큰 식별자
  • SIGNATURE

(3) Code (Python)

  • 토큰 발행
SECRET_KEY = 'secret_key'

@app.route('/api/login', methods=['POST'])
def login_post():
	payload = {
         'email': username_receive,
         'exp': datetime.utcnow() + timedelta(seconds=60 * 60 * 24)  # 로그인 24시간 유지
        }
        token = jwt.encode(payload, SECRET_KEY, algorithm='HS256').decode('utf-8')
        
	return jsonify({'result': 'success', 'token': token})
  • 토큰 확인
SECRET_KEY = 'secret_key'

payload = jwt.decode(token, SECRET_KEY, algorithms=['HS256'])

참조 - www.opennaru.com/opennaru-blog/jwt-json-web-token/, covenant.tistory.com/201, jwt.io/

반응형

'Study > python' 카테고리의 다른 글

[Python] Deque 자료형 (Collections)  (0) 2021.03.16
[Python] Cookie Session에 저장 및 불러오기 (Flask)  (0) 2021.03.01
728x90

(1) Cookie Session에 저장하기

  • 패키지 설치
    • Flask
    • session
    • escape
  • app -> config 설정
    • app.config["SECRET_KEY"] = 'ABCD'
    • app.config["SESSION_COOKIE_NAME"] = 'name'
  • Cookie session에 저장
session['user_id'] = username_receive
  • Cookie session에서 불러오기
escape(session['user_id'])

 

 

반응형

'Study > python' 카테고리의 다른 글

[Python] Deque 자료형 (Collections)  (0) 2021.03.16
[Python] JWT(Json Web Token) 사용하기 (Flask)  (0) 2021.03.02
728x90

(1) 강의내용

  • Flask
    • Flaks 패키지 설치
    • html 파일 불러오기
    • Get / Set
  • 미니프로젝트1
  • 미니프로젝트2
  • 4주차 숙제

(2) Flask

  • Flask 란?
    • 파이썬으로 작성된 웹 프레임워크 중 하나로, Werkzeug툴킷과 Jinja2 템플릿 엔진에 기반을 둔다.
  • Flask 패키지 설치
    • New Project를 통하여 Virtualenv(가상환경)을 같이 만들어 준 후 3주차 Python과 동일하게 Flask 패키지를 다운받는다.
    • 이미 프로젝트가 있을경우 Terminal에서 명령어 python3 -m venv .venv를 입력해준 후 패키지를 다운받는다.
  • html 기본코드
from flask import Flask, render_template
app = Flask(__name__)

## URL 별로 함수명이 같거나,
## route('/') 등의 주소가 같으면 안됩니다.

@app.route('/')
def home():
   return render_template('index.html')

if __name__ == '__main__':
   app.run('0.0.0.0', port=5000, debug=True)
  • html 파일 불러오기
@app.route('/login')
def home():
   return render_template('login.html')
  • Get / Set
@app.route('/login', methods=['GET']) //안쓸경우 GET
def login_get():
   return render_template('login.html')

@app.route('/login', methods=['POST'])
def test_post():
   id_receive = request.form['id_give']
   print(id_receive)
   return jsonify({'result':'success', 'msg': '이 요청은 POST!'})

(3) 미니프로젝트1 ,미니프로젝트2

  • 모두의 책 리뷰
  • 나홀로메모장

1~3주차동안 배운 내용을 통해 프로젝트를 만들고 Flask 서버로 실행시켜보기


(4) 4주차 숙제

  • app.py
from flask import Flask, render_template, jsonify, request

app = Flask(__name__)

from pymongo import MongoClient

client = MongoClient('localhost', 27017)
db = client.dbhomework


## HTML 화면 보여주기
@app.route('/')
def homework():
    return render_template('index.html')


# 주문하기(POST) API
@app.route('/order', methods=['POST'])
def save_order():
    userName_receive = request.form['userName_give']
    count_receive = request.form['count_give']
    userAddress_receive = request.form['userAddress_give']
    userPhoneNumber_receive = request.form['userPhoneNumber_give']

    doc = {'userName': userName_receive,
           'count': count_receive,
           'userAddress': userAddress_receive,
           'userPhoneNumber': userPhoneNumber_receive,
           }
    db.orders.insert_one(doc)

    return jsonify({'msg': 'good'})


# 주문 목록보기(Read) API
@app.route('/order', methods=['GET'])
def view_orders():
    orders = list(db.orders.find({}, {'_id': False}))
    return jsonify({'all_orders':orders})


if __name__ == '__main__':
    app.run('0.0.0.0', port=5000, debug=True)
  • index.html
<!doctype html>
<html lang="en">

<head>
    <!-- font   -->
    <link href="https://fonts.googleapis.com/css2?family=Play&display=swap" rel="stylesheet">

    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"
          integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">

    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"
            integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
            crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"
            integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
            crossorigin="anonymous"></script>

    <title>스파르타코딩클럽 | 부트스트랩 연습하기</title>

    <style>
        * {
            font-family: 'Play', sans-serif;
        }

        .TextGroup {
            text-align: left;
            margin-bottom: 30px;
        }

        .TextGroup_span {
            font-size: 20px;
        }

        .Exchange_Rate {
            text-align: left;
            color: blue;
            padding-bottom: 30px;
        }

        .InputGroup {
            margin-bottom: 20px;
        }

        .col-auto {
            margin-bottom: 15px;
        }

        .wrap {
            width: 600px;
            margin: auto;
            text-align: center;
        }

        .table {
            margin-top: 30px;
        }

    </style>

    <script>
        $(document).ready(function () {
            $.ajax({
                type: "GET",
                url: "https://api.manana.kr/exchange/rate.json",
                data: {},
                success: function (response) {
                    let Exchange_Rate = response[1]['rate'];
                    $('#Id_Exchange_Rate').text('달러-원 환율 : ' + Exchange_Rate);
                }
            })
            getOrder();
        });

        function postOrder() {
            let userName = $('#inlineFormInputGroup').val();
            let count = $('#inlineFormInputGroup2').val();
            let userAddress = $('#inlineFormInputGroup3').val();
            let userPhoneNumber = $('#inlineFormInputGroup4').val();

            $.ajax({
                type: "POST",
                url: "/order",
                data: {
                    userName_give: userName,
                    count_give: count,
                    userAddress_give: userAddress,
                    userPhoneNumber_give: userPhoneNumber
                },
                success: function (response) { // 성공하면
                    alert(response["msg"]);
                    window.location.reload();
                }
            })
        }

        function getOrder() {
            $.ajax({
                type: "Get",
                url: "/order",
                data: {},
                success: function (response) { // 성공하면
                    let orders = response['all_orders']

                    for (let i = 0; i < orders.length; i++) {
                        let userName = orders[i]['userName'];
                        let count = orders[i]['count'];
                        let userAddress = orders[i]['userAddress'];
                        let userPhoneNumber = orders[i]['userPhoneNumber'];

                        let temp_html = `<tr>
                                            <td>${userName}</td>
                                            <td>${count}</td>
                                            <td>${userAddress}</td>
                                            <td>${userPhoneNumber}</td>
                                        </tr>`

                        $('#order_table').append(temp_html)
                    }
                }
            })
        }

        function btn_OnClick() {
            alert('주문이 완료되었습니다');
            postOrder();
        }
    </script>


</head>

<body>
<form>
    <div class="wrap">
        <img src=""
             class="img-fluid" alt="Responsive image">
        <div class="TextGroup">
            <h1>KF-94 마스크 팝니다 <span class="TextGroup_span">가격: 1,500원/개</span></h1>
            <h6>KF94 인증은 평균 0.4μm 크기의 입자를 94% 이상, KF99 인증은 평균 0.4μm 크기의 입자를 99% 이상 걸러낼 수 있는 마스크에 주어진다.</h6>
        </div>
        <div class="Exchange_Rate" id="Id_Exchange_Rate">
            달러-원 환율 : 000.00
        </div>
        <div class="InputGroup">
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup">Username</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주문자 이름</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup2">Count</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">수량</div>
                    </div>
                    <select class="custom-select" id="inlineFormInputGroup2">
                        <option selected> -- 수량을 선택하세요 --</option>
                        <option value="1">1</option>
                        <option value="2">2</option>
                        <option value="3">3</option>
                    </select>
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup3">UserAddress</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주소</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup3" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup4">UserPhoneNumber</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">전화번호</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup4" placeholder="">
                </div>
            </div>
        </div>

        <button onclick="btn_OnClick()" type="button" class="btn btn-primary">주문하기</button>

        <table class="table" id="order_table">
            <thead>
            <tr>
                <th scope="col">이름</th>
                <th scope="col">수량</th>
                <th scope="col">주소</th>
                <th scope="col">전화번호</th>
            </tr>
            </thead>
            <tbody>

            </tbody>
        </table>
    </div>
</form>
</body>

</html>


(5) 느낀점

Flask프레워크를 처음알았지만 여러번의 반복학습으로 익숙해질수있었고, 이전 여러 프로젝트를 시작하는 경험은 많았지만 여러 이유로 포기한 적이 많았습니다. 이에 반해 스파르타 웹개발 종합반 1~4주차동안 하나 이상의 프로젝트를 완료한 것이 무척 만족스러웠습니다.


반응형
728x90

(1) 강의내용

  • OpenAPI 붙여보기
  • Python
    • 파이썬 기초공부
    • 파이썬 패키지 설치
    • 파이썬 사용하기
    • 크롤링 기초
    • 크롤링 연습하기
  • MongoDB
    • DB 설치 확인
    • DB 종류
    • pymongo 사용법
    • 크롤링 값 저장하기
  • 3주차 숙제

(2) Python

  • 파이썬 패키지 설치(bs4, requests, pymongo)
    • window의 경우 Pycharm 내부에서 File -> Settings -> Project: Project_Name -> Python Interpreter -> +버튼 ->원하는 Package입력 ->Install Package -> OK

+버튼

  • requests
#requests 라이브러리 설치 필요
import requests 

r = requests.get('open_api 주소')
rjson = r.json()
  • bs4 (BeautifulSoup)
import requests
from bs4 import BeautifulSoup

# 타겟 URL을 읽어서 HTML를 받아오고,
headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}

# url = 크롤링하고 싶은 사이트의 url
data = requests.get('url',headers=headers)

# soup이라는 변수에 "파싱 용이해진 html"이 담긴 상태가 됨
soup = BeautifulSoup(data.text, 'html.parser')


# 선택자를 사용하는 방법 (copy selector)
soup.select('태그명')
soup.select('.클래스명')
soup.select('#아이디명')

# 개발자도구(F12)를 열어 원하는 부분을 copy -> copy_selector를 통해 확인 가능
soup.select('상위태그명 > 하위태그명 > 하위태그명')
soup.select('상위태그명.클래스명 > 하위태그명.클래스명')

# 태그와 속성값으로 찾는 방법
soup.select('태그명[속성="값"]')

# 한 개만 가져오고 싶은 경우
soup.select_one('위와 동일')

(3) MongoDB

  • DB 설치 및 확인 - 크롬창에 localhost:27017을 입력 후 아래화면이 나오면 정상

MongoDB정상작동

 

  • DB 종류
    • SQL - 데이터가 정형화 되어있어 분석에 용이하나, 중간에 열을 추가하는 행동이 어려울 수 있다.
    • No-SQL - 데이터가 딕셔너리 형태로 저장되어 일관성이 부족하지만, 중간에 열을 추가하는것에 문제가 없다.
  • pymongo 사용법
from pymongo import MongoClient
client = MongoClient('localhost', 27017)

#dbname = 원하는 db이름
db = client.dbname

#collection_name = 원하는 collection 이름
#collection_name의 모든 값 검색
list(db.collection_name.find({},'_id':False))

#collection_name의 name열에서 Kim 검색
db.collection_name.find_one({'name':'Kim'},'_id':False)

#collection_name의 name열에있는 Kim을 나이 20세로 수정
db.collection_name.update_one({'name':'Kim'},{'$set':{'age':20}})

#collection_name의 name열에있는 Kim을 삭제
db.collection_name.delete_one({'name':'Kim'})

#collection_name의 데이터를 모두 삭제
db.collection_name.remove()

(4) 3주차 숙제

import requests
from bs4 import BeautifulSoup

from pymongo import MongoClient
client = MongoClient('localhost', 27017)
db = client.dbsparta

headers = {'User-Agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64)AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36'}
data = requests.get('https://www.genie.co.kr/chart/top200?ditc=D&ymd=20200403&hh=23&rtm=N&pg=1',headers=headers)

soup = BeautifulSoup(data.text, 'html.parser')

trs = soup.select('#body-content > div.newest-list > div > table > tbody > tr')

for tr in trs:
    rank = tr.select_one('td.number')
    artist = tr.select_one('td.info > a.artist.ellipsis')
    title = tr.select_one('td.info > a.title.ellipsis')

    print(rank.text.split(' ')[0].strip(), title.text.strip(), artist.text.strip() )


(5) 느낀점

크롤링과 db에 대해 필요한 부분만 잘 정리되어있는 수업진행으로 기초 부분을 빠르고 쉽게 이해할 수 있었습니다. 

모든 수업마다 이전에 했던 내용을 복습하며, 금주에 배울 내용에 대해서도 여러 번 반복하여 새로운 Quiz, 숙제를 통하여 이해뿐만 아니라 조금이나마 익숙해 질 수 있었습니다.


 

반응형
728x90

(1) 강의내용

  • Javascript 복습
  • JQuery 
    • JQuery 란?
    • JQuery 사용하기
    • 자주쓰는 JQuery
    • JQuery 적용하기(나홀로 메모장)
    • Quiz_JQuery 연습하기
  • 서버-클라이언트 통신 이해하기
    • JSON을 통해 GET, POST
  • Ajax
    • Ajax 연습하기
    • Quiz_Ajax 연습하기(1)
    • Quiz_Ajax 연습하기(2)
  • 2주차 숙제

(2) JQuery

  • JQuery란 - HTML를 보다 더 쉽게 조작할 수 있는 라이브러리.
  • JQuery CDN
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
  • JQuery를 통해 id접근 방법
// html // <div id ="id_test"> </div>

$('#id_test')

//css접근 방법
$('#id_test').css('display')

(3) Ajax(Asynchronous Javascript And Xml)

  • Ajax란 - javascript를 통한 비동기식 통신으로 서버와 클라이언트의 데이터를 페이지를 새로고침 하지 않고 주고 받을 수 있는 라이브러리.
  • 기본적으로 JQuery가 임포트 되어있어야 동작
  • GET - POST (CRUD)
    • GET - 통상적으로 데이터 조회 (Read)
    • POST - 통상적으로 데이터 생성(Create), 변경(Update), 삭제(Delete)
  • Ajax 기본 골격
$.ajax({
  type: "GET" or "POST",
  url: "요청할 url",	//  "/main"
  data: {},
  success: function(response){
    console.log(response)
  }
})

(4) 숙제 코드 / 완성 이미지

<!doctype html>
<html lang="en">

<head>
    <!-- font   -->
    <link href="https://fonts.googleapis.com/css2?family=Play&display=swap" rel="stylesheet">

    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"
          integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">

    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"
            integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
            crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"
            integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
            crossorigin="anonymous"></script>

    <title>스파르타코딩클럽 | 부트스트랩 연습하기</title>

    <style>
        * {
            font-family: 'Play', sans-serif;
        }

        .TextGroup {
            text-align: left;
            margin-bottom: 30px;
        }

        .TextGroup_span {
            font-size: 20px;
        }
        .Exchange_Rate{
            text-align: left;
            color: blue;
            padding-bottom: 30px;
        }

        .InputGroup {
            margin-bottom: 20px;
        }

        .col-auto {
            margin-bottom: 15px;
        }

        .wrap {
            width: 600px;
            margin: auto;
            text-align: center;
        }
    </style>

    <script>
        $(document).ready(function () {
            $.ajax({
                type: "GET",
                url: "https://api.manana.kr/exchange/rate.json",
                data: {},
                success: function (response) {
                    let Exchange_Rate = response[1]['rate'];
                    $('#Id_Exchange_Rate').text('달러-원 환율 : ' + Exchange_Rate);
                }
            })
        });


        function btn_OnClick() {
            alert('주문이 완료되었습니다');
        }
    </script>


</head>

<body>
<form>
    <div class="wrap">
        <img src=""
             class="img-fluid" alt="Responsive image">
        <div class="TextGroup">
            <h1>KF-94 마스크 팝니다 <span class="TextGroup_span">가격: 1,500원/개</span></h1>
            <h6>KF94 인증은 평균 0.4μm 크기의 입자를 94% 이상, KF99 인증은 평균 0.4μm 크기의 입자를 99% 이상 걸러낼 수 있는 마스크에 주어진다.</h6>
        </div>
        <div class="Exchange_Rate" id="Id_Exchange_Rate">
            달러-원 환율 : 000.00
        </div>
        <div class="InputGroup">
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup">Username</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주문자 이름</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup2">Count</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">수량</div>
                    </div>
                    <select class="custom-select" id="inlineFormInputGroup2">
                        <option selected> -- 수량을 선택하세요 --</option>
                        <option value="1">One</option>
                        <option value="2">Two</option>
                        <option value="3">Three</option>
                    </select>
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup3">UserAddress</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주소</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup3" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup4">UserPhoneNumber</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">전화번호</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup4" placeholder="">
                </div>
            </div>
        </div>
        <button onclick="btn_OnClick()" type="button" class="btn btn-primary">주문하기</button>
    </div>
</form>
</body>

</html>


(5) 느낀점

많이 들어본 용어였지만 사용해보지 않았던 JQuery, Ajax를 배울 수 있는것만으로도 만족스러웠습니다. 여기에 더해 학생들이 조금 더 JQuery, Ajax에만 집중 할 수 있도록 여러 연습하기문제, Quiz 등 에 JQuery, Ajax 만을 제외한 코드들이 준비되어있었으며 짧은 시간에 반복 학습할 수 있어 확실히 익히고 넘어가는데 도움이 되었습니다.

 


 

반응형
728x90

(1) DIV 보이기, 감추기

  • 자바스크립트
let temp = document.getElementById("Id")
temp.style.display = "none" // 감추기
temp.style.display = "block" // 보이기
  • jquery
<script>
	$("#id").show() //보이기
	$("#id").hide() //감추기
</script>

 

반응형

'Study > JavaScript' 카테고리의 다른 글

[JavaScript] Local Storage 와 Session Storage  (0) 2021.02.18
[JavaScript] 논리 연산자  (0) 2021.01.18
[JavaScript] var, let, const 차이점  (0) 2021.01.17
728x90

(1) 카카오맵 불러오기

  • 카카오맵에서 원하는 곳을 검색합니다.

  • 원하는 위치의 html태그를 복사합니다.
  • 원하는 html 파일에 붙여넣습니다.
<!-- * 카카오맵 - 지도퍼가기 -->
<!-- 1. 지도 노드 -->
<div id="daumRoughmapContainer1613788870358" class="root_daum_roughmap root_daum_roughmap_landing"></div>

<!--
	2. 설치 스크립트
	* 지도 퍼가기 서비스를 2개 이상 넣을 경우, 설치 스크립트는 하나만 삽입합니다.
-->
<script charset="UTF-8" class="daum_roughmap_loader_script" src="https://ssl.daumcdn.net/dmaps/map_js_init/roughmapLoader.js"></script>

<!-- 3. 실행 스크립트 -->
<script charset="UTF-8">
	new daum.roughmap.Lander({
		"timestamp" : "1613788870358",
		"key" : "24iif",
		"mapWidth" : "640",
		"mapHeight" : "360"
	}).render();
</script>

(2) 카카오맵 가운데 정렬

카카오맵을 가져오는건 쉽게 해결했는데 어떤 이유에선가 <style>로 가운데 정렬 하는 코드가 적용이 안되었습니다.

현재 해결된 상태로 생각해 보면 내 html보다 카카오에서 지정한 style이 늦게 적용되어 기존 내가 작성한 html의 <style>이 덮어져 기능구현이 안되었습니다.

    .root_daum_roughmap {
        margin: auto !important;
    }

위와 같이 !important 명령어를 통해 언제 적용되는지와 관계없이 해당 코드를 실행하도록 하여 해결했습니다.


 

반응형
728x90

(1) 강의내용

  • 웹의 동작 개념
  • HTML, CSS 기본내용
    • HTML 기초
    • Quiz_간단한 로그인 페이지 만들어보기
    • CSS 기초
  • bootstrap 이란?
  • Quiz_나홀로 메모장 뼈대 잡기
  • Javascript 란?
    • Javascript 기초 문법
  • 1주차 숙제

(2) 숙제 코드 / 완성 이미지

<!doctype html>
<html lang="en">

<head>
    <!-- font   -->
    <link href="https://fonts.googleapis.com/css2?family=Play&display=swap" rel="stylesheet">

    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"
          integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">

    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"
            integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
            crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"
            integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
            crossorigin="anonymous"></script>

    <title>스파르타코딩클럽 | 부트스트랩 연습하기</title>

    <style>
        *{
            font-family: 'Play', sans-serif;
        }
        .TextGroup{
            text-align: left;
            margin-bottom: 30px;
        }
        .TextGroup_span{
            font-size: 20px;
        }

        .InputGroup {
            margin-bottom: 20px;
        }
        .col-auto {
            margin-bottom: 15px;
        }


        .wrap {
            width: 600px;
            margin: auto;
            text-align: center;
        }
    </style>

    <script>
        function btn_OnClick() {
            alert('주문이 완료되었습니다');
        }
    </script>


</head>

<body>
<form>
    <div class="wrap">
        <img src="" class="img-fluid" alt="Responsive image">
        <div class="TextGroup">
            <h1>KF-94 마스크 팝니다 <span class="TextGroup_span">가격: 1,500원/개</span></h1>
            <h6>KF94 인증은 평균 0.4μm 크기의 입자를 94% 이상, KF99 인증은 평균 0.4μm 크기의 입자를 99% 이상 걸러낼 수 있는 마스크에 주어진다.</h6>
        </div>
        <div class="InputGroup">
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup">Username</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주문자 이름</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup2">Count</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">수량</div>
                    </div>
                    <select class="custom-select" id="inlineFormInputGroup2">
                        <option selected> -- 수량을 선택하세요 --</option>
                        <option value="1">One</option>
                        <option value="2">Two</option>
                        <option value="3">Three</option>
                    </select>
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup3">UserAddress</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">주소</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup3" placeholder="">
                </div>
            </div>
            <div class="col-auto">
                <label class="sr-only" for="inlineFormInputGroup4">UserPhoneNumber</label>
                <div class="input-group mb-2">
                    <div class="input-group-prepend">
                        <div class="input-group-text">전화번호</div>
                    </div>
                    <input type="text" class="form-control" id="inlineFormInputGroup4" placeholder="">
                </div>
            </div>
        </div>
        <button onclick="btn_OnClick()" type="button" class="btn btn-primary">주문하기</button>
    </div>
</form>
</body>

</html>

(3) 느낀점

웹개발 종합반의 앞 부분은 이전 무료강의로 들었던 크리스마스 특집과 비슷한 내용으로 진행 되었습니다. 

하지만 크리스마스 특집에서는 VS code를 사용한 것과 달리 pycharm을 사용하게 되어 새로운 툴 사용법에 대해 익숙 해 질 수 있었습니다. bootstrap을 이용하여 하나하나 html, css를 작성하지 않고 기본적인 틀을 가져올 수 있었으며 시간을 단축 할 수 있었습니다.

1주차의 내용중에서는 대부분 아는 내용이였지만 2~5주차 내용을 기대하며 마무리 하였습니다.

 

반응형

+ Recent posts