2014-12-06 6 views
1

Spring을 기반으로하는 Java 프로젝트에서 비밀번호 복구 기능을 구현할 예정입니다. 이것은 다음 화면에서 암호 링크 Spring JDBC 템플릿을 사용하여 mysql 데이터베이스에서 Timestamp 값 가져 오기

  • 을 잊고 그

    1. 사용자 클릭에 대한 나의 방법론, 사용자는 UUID 토큰 그/그녀의 계정
    2. 시스템을 등록하는 데 사용 된 자신의 이메일 주소를 생성 입력하고 입력 된 이메일 주소와 함께 데이터베이스 테이블에 저장됩니다. 또한 만료 시간은 데이터베이스에 Timestamp 값으로 저장됩니다.
    3. 비밀번호 재설정 링크가 포함 된 이메일이 사용자에게 전송됩니다. (UUID 토큰은 전자 메일에 포함됩니다.)
    4. 사용자가 전자 메일의 링크를 클릭하면 암호 재설정 페이지로 리디렉션됩니다.
    5. 해당 페이지에서 사용자의 전자 메일 주소는 UUID 토큰을 사용하는 시스템에서 텍스트 필드에 자동으로 설정됩니다. 여기에 만료 시간이 만료되었는지 확인해야합니다. 이를 위해 나는 만료 시간의 timestamp 값을 검색하려면이 코드 세그먼트를 사용 UUID token.

    사용하여 데이터베이스에서 가져 만료 시간의 Timestamp value과 현재 시간의 Timestamp value을 비교해야합니다. 내가 ctrl+space을 쳤을 때 queryForObject()에서 java.sql.Timestamp 이클립스에 의해 제안되어 있지만

    @Override 
         public String checkValidityOfToken(UUID token) { 
    
          System.out.println("INFO:token in Login Dao Impl = "+token); 
          java.sql.Timestamp ex_time; 
          try{ 
           String sql = "SELECT expiray_time FROM recover_password WHERE token = "+token; 
           ex_time = getJdbcTemplate().queryForObject(sql, java.sql.Timestamp); 
           System.out.println("INFO: first total = "+ex_time); 
          }catch(Exception exx){ 
           System.out.println("error while taking saved time count for a matching token "+exx); 
          } 
    } 
    

    는, Eclipse는이 오류를 보여줍니다. 왜 그런가? 이 작업의 올바른 코드 세그먼트는 무엇입니까?

    그럼이를 사용,이 경우

    String sql = "SELECT expiray_time FROM recover_password WHERE token = ?"; 
    ex_time = getJdbcTemplate().queryForObject(sql, new Object[] { token }, java.sql.Timestamp); 
    

    java.sql.Timestamp가 인식되지 않습니다. 위 메소드를 포함하고있는 클래스는 SimpleJdbcDaoSupport를 확장한다.

    또는

    내가 암호 재설정 링크의 유효성을 검사하는 잘못된 방법을 사용하십니까? 그렇다면 그것을 구현하는 좋은 방법은 무엇입니까?

  • 답변

    1

    queryForObject(String, Class) 메서드는 두 번째 매개 변수로 Class 인스턴스를 사용합니다.

    getJdbcTemplate().queryForObject(sql, java.sql.Timestamp.class); 
    

    사용하고있는 코드는 컴파일되지 않는 이유입니다 유효한 자바 코드되지 않습니다 : 따라서 올바른 구문이 있습니다.

    +0

    감사합니다. – vigamage