MainActivity

...더보기
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package com.example.boostcoursepractice;
 
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
 
import com.android.volley.AuthFailureError;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
 
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
 
import androidx.annotation.NonNull;
import androidx.core.view.GravityCompat;
import androidx.appcompat.app.ActionBarDrawerToggle;
 
import android.view.MenuItem;
 
import com.google.android.material.navigation.NavigationView;
 
import androidx.drawerlayout.widget.DrawerLayout;
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import androidx.fragment.app.Fragment;
 
import android.view.Menu;
import android.widget.Button;
import android.widget.EditText;
import android.widget.FrameLayout;
import android.widget.TextView;
import android.widget.Toast;
 
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.net.HttpURLConnection;
import java.net.Socket;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
 
public class MainActivity extends AppCompatActivity {
 
    TextView textView;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        textView = (TextView) findViewById(R.id.textView);
        Button button = (Button) findViewById(R.id.button);
 
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                sendRequest();
            }
        });
 
        if(AppHelper.requestQueue == null) AppHelper.requestQueue = Volley.newRequestQueue(getApplicationContext());
 
    }
 
    public void sendRequest()
    {
        String url = "http://www.google.co.kr";
        StringRequest request = new StringRequest(
                Request.Method.GET,
                url,
                new Response.Listener<String>() {
                    @Override
                    public void onResponse(String response) {
                        println("응답 -> " + response);
                    }
                },
                new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {
                        println("에러 -> " + error.getMessage());
                    }
                }
        ){
            @Override
            protected Map<StringString> getParams() throws AuthFailureError {////Post방식으로 파라미터를 전달해주고싶을 때
                 Map<StringString> params = new HashMap<StringString>() ;
 
                return params ;
            }
        };
 
        request.setShouldCache(false);
        AppHelper.requestQueue.add(request);
        println("응답 보냄");
    }
 
    public void println(String data) {
        textView.append(data + "\n");
    }
 
}
 
 
 
 
 
cs

AppHelper

...더보기
1
2
3
4
5
6
7
8
9
10
11
package com.example.boostcoursepractice;
 
import com.android.volley.RequestQueue;
 
public class AppHelper
{
    public static RequestQueue requestQueue;
 
    
}
 
cs

 

 

activity_main.xml

...더보기
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
32
33
34
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
 
    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="요청하기" />
 
    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@android:color/holo_orange_light">
 
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
 
            <TextView
                android:id="@+id/textView"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:textSize="18dp" />
        </LinearLayout>
    </ScrollView>
 
</LinearLayout>
 
cs

 

우선 Volley는 네트워크연결을 할 때 무조건 스레드를 통해서 해야되고 스레드 안에서 UI를 접근하려면 핸들러를 이용해야 하는 데 이거 모든 과정을 간단히 하기 위한 외부라이브러리이다.(gradel에 implementation

'com.android.volley:volley:1.1.0' 추가) 사용법은 위의 코드와 같고 개념적인 그림은 아래의 그림과 같다.

 

여기서 중요한 것은 Volley를 이용하면 메인스레드의 리퀘스트큐에 리케스트를 보내는 것이고 그 리퀘스트들은 다시 스레드로 작동한다. 이 때 각 리퀘스트들은 아래처럼 

 

new Response.Listener<String>() {

                    @Override

                    public void onResponse(String response) {

                        println("응답 -> " + response);

                    }

                },

                new Response.ErrorListener() {

                    @Override

                    public void onErrorResponse(VolleyError error) {

                        println("에러 -> " + error.getMessage());

                    }

                }

 

리스너를 등록하여 사용하며 실제적으로는 onResponse가 핸들러를 이용하여 동작하게 되는 것이다(UI접근 가능)

 

 

 

결과화면

 

+ Recent posts