Riucc's Storage
RSS
태그
관리
쓰기
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
Riucc's Storage

[Ajax] - Ajax와 Servlet 이용 아이디 중복 체크하기

Servlet|2018. 6. 29. 19:40
336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

○ Ajax와 Servlet 이용 아이디 중복 체크하기

 

Ajax와 Servlet, DAO 이용하여 DB에서 아이디 중복 체크하기


// index.jsp (Ajax 부분)


<head>

// 중복체크 버튼 AJAX <-> 서블릿으로 보내서 결과 가져오기

<script type="text/javascript">

function registerCheckFunction(){

// userID 변수에 userID의 입력된 값을 가져오게 함

var userID = $('#userID').val();

$.ajax({

type: 'POST',  // GET or POST 전송방법 

url: './UserRegisterCheckServlet',  // 이쪽으로 보낸다(호출URL)

data: {userID: userID},  // userID 이름에 userID 데이터 값을 넣어서 보낸다

success: function(result){  // 만약 성공적으로 수행되었다면 result로 값반환

if(result == 1){  // id가 checkMessage인 것에 아래 텍스트 출력

$('#checkMessage').html('사용할 수 있는 아이디입니다.');

} else {

$('#checkMessage').html('사용할 수 없는 아이디입니다.');

}

// id 가 checkModal인 모달함수 실행시켜서 모달 실행시키기 위해

$('#checkModal').modal("show");

} 

})

}

</head>


// index.jsp (폼 부분 + 모달 부분)


<body>

<!-- 아이디 입력 폼 부분 -->

<tbody>

<tr>

<td style="width: 120px;"><h5>아이디</h5></td>

<td><input class="form-control" type="text" id="userID" maxlength="20"></td>

<td style="width: 120px;"><button class="btn btn-primary" onclick="registerCheckFunction();" type="button">중복체크</button></td>

</tr>

</tbody>


<!-- 중복체크를 위한 알림메시지 모달 -->

<div class="modal fade" id="checkModal" tabindex="-1" role="dialog" aria-hidden="true">

    <div class="vertical-alignment-helper">

<div class="modal-dialog vertical-align-center">

<!--  패널 출력 성공 메시지냐 오류 메시지에 따라 -->

<div class="modal-content panel-info">

<div class="modal-header panel-heading">

<button type="button" class="close" data-dismiss="modal">

<span aria-hidden="true">&times;</span>

<span class="sr-only">Close</span>

</button>

<h4 class="modal-title">

확인 메시지

</h4>

<div class="modal-body" id="checkMessage">

</div>

<div class="modal-footer">

<button type="button" class="btn btn-primary" data-dismiss="modal">확인</button>

</div>

</div>

</div>

</div>

</div>

</div>

</body>


// UserRegisterCheckServlet.java (아이디 중복체크 서블릿)


@WebServlet("/UserRegisterCheckServlet")

public class UserRegisterCheckServlet extends HttpServlet {

private static final long serialVersionUID = 1L;

       


       public UserRegisterCheckServlet() {

            super();

        }


protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

}



protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

                // 한글 설정 위한

request.setCharacterEncoding("UTF-8");

response.setContentType("text/html; charset=UTF-8");


String userID = request.getParameter("userID");

                // 해당 체크함수는 숫자 결과값 나오기 때매 공백 추가해서 문자열 추가 ""

                // 해당 결과가 0, 1 나온 것을 보내니 ajax에서 결과값으로 받아서 처리

response.getWriter().write(new UserDAO().registerCheck(userID) + ""); 

}

}


// UserDAO.java


public class UserDAO {

private Connection conn;

public UserDAO() { // 생성자를 통한 db 연결

try {

String dbURL = "jdbc:mysql://localhost:3306/register";

String dbID = "root";

String dbPW = "wlgns930";

Class.forName("com.mysql.jdbc.Driver");

conn = DriverManager.getConnection(dbURL, dbID, dbPW);

} catch(Exception e) {

e.printStackTrace();

}

}


// 입력받은 유저 아이디 디비에서 있는지를 체크해서 값 반환
public int registerCheck(String userID) {
PreparedStatement pstmt = null;
ResultSet rs = null;
String SQL = "select * from user where userID = ?";
try {
pstmt = conn.prepareStatement(SQL);
pstmt.setString(1, userID);
rs = pstmt.executeQuery();
if(rs.next() || userID.equals("")) { // 결과가 있다면
return 0; // 이미 존재하는 아이디
} else {
return 1; // 가입 가능한 아이디
} 
}catch(Exception e) {
e.printStackTrace();
} finally {
try {
if(rs != null) rs.close();
if(pstmt !=null) pstmt.close();
} catch(Exception e) {
e.printStackTrace();
}
}
return -1; // 데이터베이스 오류
}
}


// UserDTO.java


public class UserDTO {

String userID;

String userPassword;

String userName;

int userAge;

String userEmail;

String userGender;  // 오른쪽마우스 - source - getter/setter 한다

}




모달부분이 bootstrap 버전이 낮아 이쁘지 않게 디자인되었다 !


저작자표시

'Servlet' 카테고리의 다른 글

[Ajax] - TextArea 게시물 및 댓글 수 실시간 출력하기  (0) 2018.11.06
[Servlet] - 서블릿에서 Session 사용하기  (0) 2018.07.23
[Javascript] - javascript 이용하여 패스워드 불일치 체크하기  (0) 2018.06.29
[Servlet] - 서블릿 활용한 회원가입 구현하기  (0) 2018.06.29
[Servlet] - *.do 서블릿과 FrontController 패턴  (0) 2018.06.27

댓글()
카테고리
  • IT (593)
    • 정리 (0)
    • C# (42)
    • ASP.NET MVC (16)
    • JQuery&Javascript (12)
    • CSS (11)
    • 데이터베이스 (32)
    • Windows Server (6)
    • Active Directory (3)
    • Exchange (9)
    • JAVA (2)
    • JSP (39)
    • JSP 게시판 만들기 (21)
    • JSP 개발 참고 (15)
    • JSP 안드로이드 (4)
    • Servlet (17)
    • Spring (42)
    • HTML (14)
    • NodeJS (46)
    • MongoDB (11)
    • 리눅스 (18)
    • 자료구조 (16)
    • 아이폰 (24)
    • 안드로이드 (68)
    • API 활용하기 (10)
    • 소켓네트워크 (28)
    • 라즈베리파이 (11)
    • AWS클라우드 (10)
    • 빅데이터Hadoop (22)
    • 커널모듈프로그래밍 (8)
    • 기타 (10)
    • 자격증 (26)
최근 등록 현황
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
최근 글
최근 월별 글
최근 댓글
달력
지난달
2025.5
다음달
일월화수목금토
123
45678910
11121314151617
18192021222324
25262728293031
태그 구름
  • nodejs express
  • 정보처리기사 실기 정리
  • 정보처리산업기사 총정리
  • 정보처리산업기사 필기
  • 카카오 로그인 연동
  • 정보처리산업기사 15년 필기
  • 이클립스 디비 연동
  • 정보처리산업기사 요약
  • 안드로이드 intent
  • 정보처리산업기사 15년
  • 커널 모듈 프로그래밍
  • 정보처리산업기사 정리
  • nodejs MySQL 연동하기(Connection Pool)
  • 소켓
  • 이클립스 mysql 연동
  • HTML
  • 정보처리산업기사 16년
  • 소켓 프로그래밍
  • 정규형
  • 카카오 로그인
  • 정보처리산업기사 필기 정리
  • 리눅스
  • 정보처리산업기사 16년 필기
  • 자료구조
  • 정규화
  • 안드로이드 카카오 로그인
  • 데이터베이스
  • jsp
  • 안드로이드 카카오 로그인 연동
  • 안드로이드
카운터
전체 방문자
오늘
어제
Skin by M1REACT. Designed by M1STORY.TISTORY.COM. Valid XHTML 1.0 and CSS 3. Copyright ⓒ Riucc's Storage. All rights reserved.

티스토리툴바