게시판 즐겨찾기
편집
드래그 앤 드롭으로
즐겨찾기 아이콘 위치 수정이 가능합니다.
제발도와주세요 유유ㅠㅠ 공공데이터포털 api.... rest xml 사용
게시물ID : programmer_12050짧은주소 복사하기
작성자 : 뿌뿌빠뿌뿌
추천 : 0
조회수 : 2682회
댓글수 : 4개
등록시간 : 2015/07/12 20:08:49
옵션
  • 본인삭제금지
android 개발 중입니다!
막막해서 고민하다가 프게에 올려봐여! 능력자분들이 많으신 것 같아서 ㅎㅎ

공공데이터포털(www.data.go.kr)에서 api를 신청했고, 허가받아서 이걸 이용해서 코딩을 하려고 합니다.
그런데 다른 api들과는 다르게 가이드 라인도 안되어있고 (기껏해봐야 서비스 명세서...ㅠㅠ) 해서 정말 갑갑해요
원하는 정보는 github이나 google 찾아봐도 안나오고 ㅠㅠ 제가 망충해서그런가!!하하하하ㅏ...

어디가 틀린지, 어떤식으로 해야할 지 조언을 주셨으면 좋겠습니다 :-)... 정리 잘 되어있는 사이트도 추천해주시면 매우 감사하겠습니다.ㅠㅠ

대략적인 정보는 이렇습니ㄷr.. 

오유1.PNG
=> 공공데이터 포탈 정보입니다. 저작권 관련 문제가 생길 수 있어서 답변 올라오면 이미지는 지워질 수 있습니다!! (후에 다른분들이 참고하실 수 있도록 이미지 텍스트로 설명하는 정도로 수정하겠습니다!)

오유2.PNG
오유3.PNG
=> 해당 api 제가 쓰려고 하는 기능 부분의 서비스명세서입니다. 
   저작권 관련 문제가 생길 수 있어서 답변 올라오면 이미지는 지워질 수 있습니다!! (후에 다른분들이 참고하실 수 있도록 이미지 텍스트로 설명하는 정도로 수정하겠습니다!)


---------------------------
코드입니다. 제가 json, xml 등등 파싱 관련해서 지식이 많은 편이 아니고, 기존에는 sdk로 사용하는 편이어서 ㅠ (이건 sdk 지원이 안되네요)ㅠㅠ
어려움이 많습니다. 도움 부탁드립니다.

public class MainActivity extends ActionBarActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
CallRestWS callRest = new CallRestWS();
TextView text = (TextView)findViewById(R.id.textView1); // 전에 xml에 들어있는 값을 화면으로 보려고 선언해놓았어요

String xml;
try {
xml = callRest.restClient(); 
// xml이라는 String 형 변수에 리턴된 내용을 담으려고 했습니다. Try Catch문 없이는 오류가 나더군요
System.out.println(xml);
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println("실패"); //로그캣에 실패라고 뜹니다..ㅠㅠㅠㅠ쀼ㅠ!! 
e.printStackTrace();
}
}
public class CallRestWS { 
        private String restClient() throws Exception{

                 String addr = "http://ws.bus.go.kr/api/rest/pathinfo/getPathInfoByBusNSub"+"?ServiceKey=";
                 String serviceKey = "HvVDM%2BPl%2FNNxJVNLBKHLpE35VjXtQg5N2AZiQeNwkr67Wr%2BqIbHEMKJ5qTLYXzzN5ZMztp4w7nEJ%2BxuxANkzDg%3D%3D";
                 String parameter = "";              


                 //인증키(서비스키) url인코딩
                 serviceKey = URLEncoder.encode(serviceKey, "UTF-8");

                 parameter = parameter + "&" + "startX=37.626666";//광운대 (출발지점 X,Y값)
                 parameter = parameter + "&" + "startY=127.025917";
                 parameter = parameter + "&" + "endX=127.025917";//미아 (도착지점 X,Y값)
                 parameter = parameter + "&" + "endY=127.060962";
                 
                 addr = addr + serviceKey + parameter;
              
                 URL url = new URL(addr);
//                 InputStream in = url.openStream();
//                 CachedOutputStream bos = new CachedOutputStream();
//                 IOUtils.copy(in, bos);
//
//                 in.close();
//                 bos.close();
//                 
//                 return bos.getOut().toString();
// 주석처리 된 부분은 아랫 부분이랑 같은 기능을 하는걸로 보입니다. 다른 코드 참고할 때 가져왔습니다. ㅠ 
                
                 BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream(), "utf-8"));
                 String inLine;
                 String xml = "";
                 while ((inLine = in.readLine()) != null) xml = inLine;
                 in.close();
                 
                 return xml;
        }
}
}

# 매니페스트에서는 permission INTERNET으로 추가해주었습니다.

-----------------------------------
로그캣입니다.

07-12 20:03:38.389: W/ApplicationPackageManager(15132): getCSCPackageItemText()

07-12 20:03:38.389: I/PersonaManager(15132): getPersonaService() name persona_policy

07-12 20:03:38.449: I/dalvikvm(15132): Could not find method android.content.res.TypedArray.getChangingConfigurations, referenced from method android.support.v7.internal.widget.TintTypedArray.getChangingConfigurations

07-12 20:03:38.449: W/dalvikvm(15132): VFY: unable to resolve virtual method 405: Landroid/content/res/TypedArray;.getChangingConfigurations ()I

07-12 20:03:38.449: D/dalvikvm(15132): VFY: replacing opcode 0x6e at 0x0002

07-12 20:03:38.449: I/dalvikvm(15132): Could not find method android.content.res.TypedArray.getType, referenced from method android.support.v7.internal.widget.TintTypedArray.getType

07-12 20:03:38.449: W/dalvikvm(15132): VFY: unable to resolve virtual method 427: Landroid/content/res/TypedArray;.getType (I)I

07-12 20:03:38.449: D/dalvikvm(15132): VFY: replacing opcode 0x6e at 0x0002

07-12 20:03:38.559: I/System.out(15132): main(HTTPLog):SmartBonding Enabling is false, log to file is false, DBG is false

07-12 20:03:38.559: I/System.out(15132): 실패

07-12 20:03:38.559: W/System.err(15132): android.os.NetworkOnMainThreadException

07-12 20:03:38.569: W/System.err(15132):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1156)

07-12 20:03:38.569: W/System.err(15132):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)

07-12 20:03:38.569: W/System.err(15132):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)

07-12 20:03:38.569: W/System.err(15132):    at java.net.InetAddress.getAllByName(InetAddress.java:214)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:387)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:340)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:286)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:296)

07-12 20:03:38.569: W/System.err(15132):    at com.android.okhttp.internal.http.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:179)

07-12 20:03:38.569: W/System.err(15132):    at java.net.URL.openStream(URL.java:470)

07-12 20:03:38.569: W/System.err(15132):    at com.example.dataportalapitest.MainActivity$CallRestWS.restClient(MainActivity.java:96)

07-12 20:03:38.569: W/System.err(15132):    at com.example.dataportalapitest.MainActivity$CallRestWS.access$0(MainActivity.java:65)

07-12 20:03:38.569: W/System.err(15132):    at com.example.dataportalapitest.MainActivity.onCreate(MainActivity.java:45)

07-12 20:03:38.569: W/System.err(15132):    at android.app.Activity.performCreate(Activity.java:5426)

07-12 20:03:38.569: W/System.err(15132):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)

07-12 20:03:38.569: W/System.err(15132):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2269)

07-12 20:03:38.569: W/System.err(15132):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)

07-12 20:03:38.569: W/System.err(15132):    at android.app.ActivityThread.access$900(ActivityThread.java:161)

07-12 20:03:38.569: W/System.err(15132):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265)

07-12 20:03:38.569: W/System.err(15132):    at android.os.Handler.dispatchMessage(Handler.java:102)

07-12 20:03:38.569: W/System.err(15132):    at android.os.Looper.loop(Looper.java:157)

07-12 20:03:38.569: W/System.err(15132):    at android.app.ActivityThread.main(ActivityThread.java:5356)

07-12 20:03:38.569: W/System.err(15132):    at java.lang.reflect.Method.invokeNative(Native Method)

07-12 20:03:38.569: W/System.err(15132):    at java.lang.reflect.Method.invoke(Method.java:515)

07-12 20:03:38.569: W/System.err(15132):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)

07-12 20:03:38.569: W/System.err(15132):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)

07-12 20:03:38.569: W/System.err(15132):    at dalvik.system.NativeStart.main(Native Method)

07-12 20:03:38.599: I/Adreno-EGL(15132): <qeglDrvAPI_eglInitialize:410>: EGL 1.4 QUALCOMM build:  ()

07-12 20:03:38.599: I/Adreno-EGL(15132): OpenGL ES Shader Compiler Version: E031.24.00.08+13

07-12 20:03:38.599: I/Adreno-EGL(15132): Build Date: 03/20/14 Thu

07-12 20:03:38.599: I/Adreno-EGL(15132): Local Branch: 0320_AU200_patches

07-12 20:03:38.599: I/Adreno-EGL(15132): Remote Branch:

07-12 20:03:38.599: I/Adreno-EGL(15132): Local Patches:

07-12 20:03:38.599: I/Adreno-EGL(15132): Reconstruct Branch:

07-12 20:03:38.649: D/OpenGLRenderer(15132): Enabling debug mode 0


--------------

로그캣 전부 올렸습니다! 초록/파랑/주황 색도 구분 해놓았습니다. 

전체 추천리스트 보기
새로운 댓글이 없습니다.
새로운 댓글 확인하기
글쓰기
◀뒤로가기
PC버전
맨위로▲
공지 운영 자료창고 청소년보호