Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- DB
- 항해99
- Spring Security
- CentOS
- visualvm
- docker
- 스파르타코딩클럽
- 카프카
- 시큐리티
- emqx
- EC2
- 스프링의 정석
- AWS
- @jsonproperty
- JWT
- 남궁성과 끝까지 간다
- Spring
- 생성자 주입
- java
- 패스트캠퍼스
- 프로그래머스
- JavaScript
- WEB SOCKET
- 데이터베이스
- 쇼트유알엘
- 스웨거
- Kafka
- 웹개발
- 개인프로젝트
- MYSQL
Archives
- Today
- Total
Nellie's Blog
카카오 주소 검색 api 로 회원가입 시 주소 입력하기 & 에러 본문
728x90
http://postcode.map.daum.net/guide
카카오 공식문서에서 제공하는 api 예시 코드이다.
<script src="//t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
<script>
new daum.Postcode({
oncomplete: function(data) {
// 팝업에서 검색결과 항목을 클릭했을때 실행할 코드를 작성하는 부분입니다.
// 예제를 참고하여 다양한 활용법을 확인해 보세요.
}
}).open();
</script>
내가 작성한 register.jsp 코드
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>회원가입 화면 샘플 - Bootstrap</title>
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css"
integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<style>
body {
min-height: 100vh;
background: -webkit-gradient(linear, left bottom, right top, from(#92b5db), to(#1d466c));
background: -webkit-linear-gradient(bottom left, #92b5db 0%, #1d466c 100%);
background: -moz-linear-gradient(bottom left, #92b5db 0%, #1d466c 100%);
background: -o-linear-gradient(bottom left, #92b5db 0%, #1d466c 100%);
background: linear-gradient(to top right, #92b5db 0%, #1d466c 100%);
}
.input-form {
max-width: 680px;
margin-top: 80px;
padding: 32px;
background: #fff;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
-webkit-box-shadow: 0 8px 20px 0 rgba(0, 0, 0, 0.15);
-moz-box-shadow: 0 8px 20px 0 rgba(0, 0, 0, 0.15);
box-shadow: 0 8px 20px 0 rgba(0, 0, 0, 0.15)
}
</style>
</head>
<body>
<div class="container">
<div class="input-form-backgroud row">
<div class="input-form col-md-12 mx-auto">
<h4 class="mb-3">회원가입</h4>
<form method="post">
<div class="row">
<div class="col-md-6 mb-3">
<label for="username">이름</label>
<input type="text" class="form-control" id="username" placeholder="홍길동" value="" required>
<div class="invalid-feedback">
이름을 입력해주세요.
</div>
</div>
<div class="col-md-6 mb-3">
<label for="nickname">별명</label>
<input type="text" class="form-control" id="nickname" placeholder="별명" value="" required>
<div class="invalid-feedback">
별명을 입력해주세요.
</div>
</div>
</div>
<!-- 주소 입력 버튼 -->
<div class="mb-3">
<button class="btn btn-primary" type="button" id="findAddr" onclick="findAddr()">주소 입력</button>
</div>
<div class="form-group">
<label for="zipcode">우편번호</label>
<input type="text" name="zipcode" id="zipcode" class="form-control" placeholder="우편번호를 입력하세요" readonly onclick="findAddr()">
</div>
<div class="form-group">
<label for="streetAdr">도로명 주소</label>
<input type="text" name="streetAdr" id="streetAdr" class="form-control" placeholder="도로명 주소를 입력하세요" readonly>
</div>
<div class="form-group">
<label for="detailAdr">상세주소</label>
<input type="text" name="detailAdr" id="detailAdr" class="form-control" placeholder="상세주소를 입력하세요">
</div>
<div class="mb-3">
<label for="email">이메일</label>
<%-- 인증하기 버튼을 누르면 작성한 email이 사라지는 것을 방지하기 위해 readonly 추가 --%>
<input type="email" class="form-control" id="email" placeholder="weaver123@example.com" required >
<div class="invalid-feedback">
이메일을 입력해주세요.
</div>
</div>
<!-- 이메일 인증 버튼 추가 -->
<div class="mb-3">
<button class="btn btn-primary" type="button" id="emailVerificationButton" onclick="sendEmailVerification()">인증</button>
</div>
<!-- 인증번호 입력 칸 (숨겨진 상태로 시작) -->
<div class="mb-3" id="verificationCodeDiv" style="display: none;">
<label for="verificationCode">인증번호</label>
<input type="text" class="form-control" id="verificationCode" placeholder="인증번호를 입력하세요" required>
<div class="invalid-feedback">
인증번호를 입력해주세요.
</div>
</div>
<div class="mb-3">
<label for="password">비밀번호</label>
<input type="password" class="form-control" id="password" placeholder="비밀번호는 8~16자 영문, 숫자, 특수문자를 사용하세요" required>
<div class="invalid-feedback">
비밀번호를 입력해주세요.
</div>
</div>
<div class="mb-3">
<label for="passwordConfirm">비밀번호 확인</label>
<input type="password" class="form-control" id="passwordConfirm" placeholder="비밀번호를 다시 입력해주세요" required>
<div class="invalid-feedback">
비밀번호를 다시 입력해주세요.
</div>
</div>
<div class="mb-3">
<label for="phoneNumber">휴대폰 번호</label>
<input type="text" class="form-control" id="phoneNumber" placeholder="비밀번호를 다시 입력해주세요" required>
<div class="invalid-feedback">
휴대폰 번호를 입력해주세요.
</div>
</div>
<div class="mb-3">
<label for="profilePicture">프로필 사진</label>
<input type="file" class="form-control-file" id="profilePicture" accept="image/*">
<div class="invalid-feedback">
이미지 파일을 업로드해주세요.
</div>
</div>
<div class="mb-4"></div>
<button class="btn btn-primary btn-lg btn-block" type="button" id="registrationForm" onclick="test()">가입 완료</button>
</form>
</div>
</div>
<footer class="my-3 text-center text-small">
<p class="mb-1">© 2021 YD</p>
</footer>
</div>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="//t1.daumcdn.net/mapjsapi/bundle/postcode/prod/postcode.v2.js"></script>
<script>
function test() {
// e.preventDefault(); // 폼 제출 방지
// 1. 여기서 내가 화면에서 post 로 입력하는 정보를 하나하나 가져오기
var username = $('#username').val()
var nickname = $('#nickname').val()
var email = $('#email').val()
var password = $('#password').val()
var passwordConfirm = $('#passwordConfirm').val()
var phoneNumber = $('#phoneNumber').val()
var profilePicture = $('#profilePicture').val()
console.log(username);
console.log(nickname);
console.log(email);
console.log(password);
console.log(passwordConfirm);
console.log(phoneNumber);
console.log(profilePicture);
// 2. 가져온 정보를 data로 묶기
let data = {
"username" : username,
"nickname" : nickname,
"email" : email,
"password" : password,
"passwordConfirm" : passwordConfirm,
"phoneNumber" : phoneNumber,
"profilePicture" : profilePicture
}
// 3. 클라에서 가져온 데이터를 서버로 전송 (이 예시에서는 URL이 '/register'로 가정)
$.ajax({
type: 'POST',
url: '/register', // 가입완료 버튼을 누르면 이 URL로 매핑!!! 마지막에 가는게xx
// 사용자가 입력한 정보들이 위에 변수로 수집되고, 그 정보는 아래의 data라는 객체에 저장된다.
// 이 객체는 json 데이터형식을 가지며, 각 입력필드의 값을 해당 필드의 이름으로 매핑한다!!
// 이 요청은 /register url로 보내지며, 서버의 컨트롤러 중에 @PostMappling("/register")가 달린 메소드가 호출된다.
// 이 메서드는 json형식의 데이터인 'userDto' 객체를 파라미터로 받는다.
data: JSON.stringify(data),
contentType: 'application/json', // JSON 형식의 데이터를 전송
success: function (response, status, xhr) { // response 객체에 success, msg가 json형식으로 존재함(컨트롤러에서 반환한 값이 json으로 들어옴)
console.log(response); //응답 body부 데이터
console.log(status); //"succes"로 고정인듯함
console.log(xhr);
if (xhr.status === 200) {
// 서버 응답의 상태 코드가 200일 때만 실행
alert('가입이 완료되었습니다!');
location.href = "/board";
} else {
// 가입 실패 처리
alert('서버에서 오류가 발생했습니다.');
}
},
error: function (response, status, xhr) {
// 서버 요청 실패 시 실행
console.log('실패했다...')
console.log(response); //응답 body부 데이터
alert('서버 요청 실패');
}
});
}
function sendEmailVerification() {
// 1. 작성한 이메일 주소 가져오기
var email = $('#email').val();
// 2. 가져온 정보를 data로 묶기
let data = {
"email" : email
}
// 3. 클라에서 가져온 데이터를 서버로 전송
$.ajax({
type: 'POST',
url: '/email-confirm',
data: JSON.stringify(data),
contentType: 'application/json', // JSON 형식의 데이터를 전송v
success: function (response, status, xhr) { // response 객체에 success, msg가 json형식으로 존재함(컨트롤러에서 반환한 값이 json으로 들어옴)
console.log(response); //응답 body부 데이터
console.log(status); //"succes"로 고정인듯함
console.log(xhr);
if (xhr.status === 200) {
// 서버 응답의 상태 코드가 200일 때만 실행
alert('메일이 전송 되었습니다!');
// 인증번호 입력 칸 표시
$('#verificationCodeDiv').show();
} else {
// 실패 처리
alert('서버에서 오류가 발생했습니다.');
}
},
error: function (response, status, xhr) {
// 서버 요청 실패 시 실행
console.log('실패했다...')
console.log(response); //응답 body부 데이터
alert('서버 요청 실패');
}
});
}
function findAddr() {
console.log('주소찾기 메서드 findAddr() 실행')
new daum.Postcode({
oncomplete: function(data) {
// 각 주소의 노출 규칙에 따라 주소를 조합한다.
// 내려오는 변수가 값이 없는 경우엔 공백('')값을 가지므로, 이를 참고하여 분기 한다.
var addr = ''; // 주소 변수
var extraAddr = ''; // 참고항목 변수
//사용자가 선택한 주소 타입에 따라 해당 주소 값을 가져온다.
if (data.userSelectedType === 'R') { // 사용자가 도로명 주소를 선택했을 경우
addr = data.roadAddress;
} else { // 사용자가 지번 주소를 선택했을 경우(J)
addr = data.jibunAddress;
}
// 사용자가 선택한 주소가 도로명 타입일때 참고항목을 조합한다.
if(data.userSelectedType === 'R'){
// 법정동명이 있을 경우 추가한다. (법정리는 제외)
// 법정동의 경우 마지막 문자가 "동/로/가"로 끝난다.
if(data.bname !== '' && /[동|로|가]$/g.test(data.bname)){
extraAddr += data.bname;
}
// 건물명이 있고, 공동주택일 경우 추가한다.
if(data.buildingName !== '' && data.apartment === 'Y'){
extraAddr += (extraAddr !== '' ? ', ' + data.buildingName : data.buildingName);
}
// 표시할 참고항목이 있을 경우, 괄호까지 추가한 최종 문자열을 만든다.
if(extraAddr !== ''){
extraAddr = ' (' + extraAddr + ')';
}
// 조합된 참고항목을 해당 필드에 넣는다.
document.getElementById("detailAdr").value = extraAddr;
} else {
document.getElementById("detailAdr").value = '';
}
// 우편번호와 주소 정보를 해당 필드에 넣는다.
document.getElementById('zipcode').value = data.zonecode;
document.getElementById("streetAdr").value = addr;
// 커서를 상세주소 필드로 이동한다.
document.getElementById("detailAdr").focus();
}
}).open();
}
</script>
</body>
</html>
주소입력을 누르면 아무것도 안뜨고 저렇게 에러메시지가 뜬다.
주소입력 쪽에서 에러밑줄이 그어져있음.
findAddre() 메서드를 못찾는 것 같음. 왜그러지?,,,
id 값과 메소드 명이 findArr로 같았기 때문이다!
메소드 명을 수정해주니 해결되었다!!
'Back-end > java' 카테고리의 다른 글
유효성 검사시 기존 작성 데이터가 사라지는 문제 해결 (0) | 2023.09.14 |
---|---|
회원가입 / 로그인 템플릿 예시 (0) | 2023.09.14 |
Path with "WEB-INF" or "META-INF 에러 (0) | 2023.09.13 |
UnsatisfiedDependencyException , NoClassDefFoundError 에러 (0) | 2023.09.13 |
Illegal invocation 에러 (415에러) (0) | 2023.09.12 |