안녕하세요. 최근에 안드로이드와 스프링 mvc를 공부중인 초보입니다.
고수님들에게 몇가지 여쭤봅니다.
스프링서버에는 시큐리티 셋업을 사용하고 있습니다. 저는 여러 소스를 보고 main_activity에서 아이디와 비밀번호 넣고 로그인 하는 로직을 짰는데요.
이후 특정 버튼을 누르면 다른 레이아웃으로 넘어가게 할것이고 그 화면에서 서버 데이터를 가져와서 어댑터를 이용해서 서버 데이터를 뿌릴 건데요.
궁금한 점은
1.main_activity에서 로그인을 했는데 다른 액티비티에서 또 로그인을 하는게 맞는가요?
2.아니면 인텐트나 다른 방법으로 계속해서 requestHeader값을 갖고 다니며 인증을 안하고 계속 서버데이터를 요청하고 뿌리는 것인가요?
2번이 맞다면...어떤 식으로 하는지 간단한 코드로 알려주시면 감사하겠습니다.
main_activity...
private class FetchSecuredResourceTask extends AsyncTask<Void, Void, Message> {
private String username;
private String password;
@Override
protected void onPreExecute() {
showLoadingProgressDialog();
// build the message object
EditText editText = (EditText) findViewById(R.id.username);
this.username = editText.getText().toString();
editText = (EditText) findViewById(R.id.password);
this.password = editText.getText().toString();
}
@Override
protected Message doInBackground(Void... params) {
final String url = getString(R.string.base_uri) + "/getmessage";
// HTTP 기본인증헤더를 username , password를 이용하여 생성한다.
authHeader = new HttpBasicAuthentication(username, password);
requestHeaders = new HttpHeaders();
requestHeaders.setAuthorization(authHeader);
requestHeaders.setAccept(Collections.singletonList(MediaType.APPLICATION_JSON));
// JSON 형식 컨버터 설정
RestTemplate restTemplate = new RestTemplate();
restTemplate.getMessageConverters().add(new MappingJacksonHttpMessageConverter());
try {
// 서버의 URL에 데이터를 요청한다.받은데이터는 Message 객체로 변환
Log.d(TAG, url);
ResponseEntity<Message> response = restTemplate.exchange(url, HttpMethod.GET, new HttpEntity<Object>(requestHeaders), Message.class);
return response.getBody();
} catch (HttpClientErrorException e) {
Log.e(TAG, e.getLocalizedMessage(), e);
return new Message(0, e.getStatusText(), e.getLocalizedMessage());
} catch (ResourceAccessException e) {
Log.e(TAG, e.getLocalizedMessage(), e);
return new Message(0, e.getClass().getSimpleName(), e.getLocalizedMessage());
}
}
@Override
protected void onPostExecute(Message result) {
dismissProgressDialog();
displayResponse(result);
}
}