Flowchart에 따른 순서도를 구체화
1. 파이참으로 세팅
- 폴더세팅 - flask를 이용할 것이므로, static, templates 폴더 준비
- Interpreter세팅 - flask, pymongo, dnspython
2. HTML, CSS로 Client 페이지 작업
3. Flask로 Get(페이지시작될때), Post(검색버튼누를때) 연결
4. API Key로 데이터 잘 받아오는지 체크
5. 검색버튼구현 - 3,4번을 할때 같이 해버렸다..
6. POST - 3,4번을 할때 같이 해버렸다..
- Client: 도시이름 서버로 보내기
- Server: 도시이름 DB로 보내기
7. Get - 3,4번을 할때 같이 해버렸다..
- Server: 도시이름 DB에서 받아오기
- Client: 도시이름 Server에서 받아오기
- 내가 flowchart에 익숙하지 않은 탓인지, 이 기능들을 3,4번을 하면서 진행해 버렸다.
8. Test
- DB에 도시이름이 잘 들어가는지,
- 웹에 잘 표현되는지 (온도, 시간등의 계산)
9. 되돌아보는 시간
여기서 발견한 문제점
1. ajax() 함수 안에 ajax()를 사용해서 코드의 가독성이 최악이다..
말 그대로 구현만 해냈지, 이렇게 코딩하는건 옳지 않다고 생각된다.. (사수가 필요해..)
// 날씨를 보여주는 코드.
function show_weather() {
// DB에서 가져오는 ajax이다.
$.ajax({
type: "GET",
url: "/search",
data: {},
success: function (response) {
// 도시이름을 가져와서 그 도시이름을 url에 넣어준다.
let rows = response['msg']
// city name을 가져와서 url 중앙에 넣어준다
for (let i = 0; i < rows.length; ++i) {
let cityName = rows[i]['cityName'];
url = "https://api.openweathermap.org/data/2.5/weather?q=" + cityName + "&appid=3de474db76b0433d7c350250d3e62508"
// 그 url을 가지고 api를 가져온다
$.ajax({
type: "GET",
url: url,
data: {},
success: function (response) {
// api response를 가지고 필요한 정보를 뽑아낸다
let aboutTemp = response['main'];
let cityName = response['name'];
let currentTemp = aboutTemp['temp'];
let feelTemp = aboutTemp['temp_max'];
let humidityTemp = aboutTemp['humidity'];
let windSpeed = response['wind']['speed'];
let icon = response['weather']
// Time Calculator
let timezone = response['timezone']
let d = new Date((new Date().getTime()) + timezone * 1000)
// logic
let weatherURL = [""
, "https://mblogthumb-phinf.pstatic.net/20160223_280/ksy4378953_1456190111690DAFhF_JPEG/PicsArt_1456021923813.jpg?type=w2"
, "https://mblogthumb-phinf.pstatic.net/20151201_144/ksy4378953_1448965542395D4ynK_JPEG/PicsArt_1448623475225.jpg?type=w420"
]
let temp_html = `<div class="card">
<div class="card-body">
<blockquote class="blockquote mb-0">
<div class="weather-header">
<img width=32px src="http://openweathermap.org/img/w/${icon[0].icon}.png"/>
<h5 id="city-name">${cityName}</h5>
</div>
<div class="weather-main">
<div id="curTime">Current Time: ${d.toISOString().replace("T", " ").replace(/\..*/, "")}</div>
<div id="curTemp">Current Temperature: ${Math.floor(currentTemp - 273.15)}°</div>
<div id="feelTemp">Feel Temperature: ${Math.floor(feelTemp - 273.15)}</div>
<div id="wind">Wind: ${windSpeed} m/s</div>
<div id="humidity">humidity: ${humidityTemp} %</div>
</div>
</blockquote>
</div>
</div>`
$('#main-weather').append(temp_html);
}
})
}
}
});
}
10. EC2 실행하고 git bash, 파일질라로 서버 열고 실행해보기
AWS에서 중단했던 인스턴스를 시작해주고
- 중단했다 재 시작하면 퍼블릭주소가 변경된다!
- 인바운드 규칙도 재설정 해줘야한다.
GIT BASH 에서 접속을 해준다.
- 키페어 뭐라뭐라하면서 계속할지 물어보는데, yes해주면 된다.
파일질라에 이미 등록되있는 퍼블릭주소 역시 새 주소로 변경해 주어야한다
그러고 필요한 데이터를 드래그해서 폴더에 넣어준다.
python app.py로 실행해주고, 퍼블릭주소를 주소창에 치고 들어가서 확인해본다.
토이프로젝트 1 은 여기서 마무리를 지으려고 한다.총 3시간 정도 걸린 작업이었고
aws 그리고 ajax() 두개 겹치기 외에는 크게 막혔던 곳은 없었던거 같다.
'Sparta > 항해99' 카테고리의 다른 글
항해 사전준비 5일차 - 입학시험/ 웹개발플러스 1/토이프로젝트2 - 나의 작은 여행기 (0) | 2022.05.04 |
---|---|
항해 사전준비 4일차 - React (0) | 2022.05.02 |
항해 사전준비 2일차 - 종합반2~5주차,토이프로젝트 기획, React, Redux (0) | 2022.04.30 |
항해 사전준비 1일차 - JS, Python, Ajax, 종합반1주차 정리 (0) | 2022.04.29 |
항해99 사전준비 0일차 (0) | 2022.04.29 |