JAVA 기반 전국 일기예보 인터페이스 호출 예시
1단계: 이 기사 URL에 설명된 "국가 일기예보 인터페이스" 인터페이스를 선택합니다: https://www.juhe.cn/docs/api/id/39/aid/87
2단계: 각 인터페이스는 사용자의 토큰에 해당하는 매개변수 키를 전달해야 하므로 첫 번째 단계에서는 키를 신청해야 합니다
3단계: 문서를 읽어보세요!!! Java를 공부한 학생들은 수업이나 방법의 의도와 아이디어가 이해되지 않을 때 문서를 확인하면 된다는 것을 모두 알고 있으며, 특히 그렇지 않은 학생들에게도 마찬가지입니다. 영어를 잘함 다행히도 집계 웹사이트의 문서는 모두 중국어로 되어 있어서 Java 소스 코드의 영어 문서를 읽는 것보다 훨씬 쉬울 것입니다.
National Weather Forecast 인터페이스에는 6개의 하위 인터페이스가 있습니다. 첫 번째 인터페이스 링크를 열고 문서를 읽고 6번째 하위 인터페이스를 통해 이 매개변수를 얻을 수 있습니다. 인터페이스 간 매개변수 호출은 (Java의 메소드 간 호출)과 유사합니다. 즉, 예제에서는 먼저 이 인터페이스를 호출하여 네트워크 리소스를 요청합니다. GET 및 POST 메소드를 포함한 클래스
4단계: 코드 업로드
데모1: 네트워크 액세스 도구 클래스(get 및 post 메소드 캡슐화)package juheAPI;<br>
<br>
import java.io.BufferedReader;<br>
import java.io.BufferedWriter;<br>
import java.io.InputStream;<br>
import java.io.InputStreamReader;<br>
import java.io.OutputStream;<br>
import java.io.OutputStreamWriter;<br>
import java.net.HttpURLConnection;<br>
java.net.URL 가져오기;<br>
import java.util.Map;<br>
/**<br>
* 네트워크 액세스 도구<br>
* @author 실크<br>
*<br>
*/<br>
공개 클래스 PureNetUtil {<br>
/**<br>
* get 메소드는 post 메소드를 직접 호출합니다<br>
* @param URL 네트워크 주소<br>
* @return 네트워크 데이터 반환<br>
*/<br>
공개 정적 문자열 get(String url){<br>
게시물 반환(url,null);<br>
}<br>
/**<br>
* * 네트워크 자원을 얻기 위해 post 메소드를 설정합니다. 매개변수가 null인 경우 실제로는 get 메소드로 설정됩니다. <br>
* @param URL 네트워크 주소<br>
* @param param 요청 매개변수 키-값 쌍<br>
* @return 읽은 데이터를 반환<br>
*/<br>
public static String post(String url,Map param){<br>
HttpURLConnection conn=null;<br>
{<br>을 시도해 보세요
URL u=새 URL(url);<br>
conn=(HttpURLConnection) u.openConnection();<br>
StringBuffer sb=null;<br>
If(param!=null){//요청 매개변수가 비어 있지 않은 경우<br>
sb=new StringBuffer();<br>
/*URL 연결을 입력 및/또는 출력에 사용할 수 있습니다. DoOutput<br>을 설정합니다.
* 출력에 URL 연결을 사용하려는 경우 true로 플래그를 지정하세요.<br>
* 그렇지 않은 경우 기본값은 false입니다.*/<br>
//기본값은 false입니다. post 메소드는 매개변수를 작성해야 하며 true로 설정해야 합니다<br>
conn.setDoOutput(true);<br>
//게시 방법을 설정합니다. 기본값은 get입니다<br>
conn.setRequestMethod("POST");<br>
//출력 스트림 가져오기<br>OutputStream out=conn.getOutputStream();<br>
// 출력 스트림을 고급 출력 스트림으로 캡슐화 <br>
BufferedWriter 작가=new BufferedWriter(new OutputStreamWriter(out));<br>
//매개변수를 키-값 쌍으로 캡슐화<br>
for(Map.Entry s:param.entrySet()){<br>
sb.append(s.getKey()).append("=").append(s.getValue()).append("&");<br>
}<br>
//출력 스트림을 통해 매개변수 쓰기<br>
Writer.write(sb.deleteCharAt(sb.toString().length()-1).toString());<br>
writer.close();//반드시 닫아야 합니다. 그렇지 않으면 불완전한 매개변수 오류가 발생할 수 있습니다. <br>
sb=null;<br>
}<br>
conn.connect();//연결 설정<br>
sb=new StringBuffer();<br>
> 연결 상태 코드를 가져오려면 <br>
int recode=conn.getResponseCode();<br>
BufferedReader 리더=null;<br>
if(recode==200){<br>
//이 열린 연결에서 읽는 입력 스트림을 반환합니다<br>
// 연결에서 입력 스트림 가져오기 <br>
InputStream in=conn.getInputStream();<br>
// 입력 스트림 캡슐화 <br>
Reader=new BufferedReader(new InputStreamReader(in));<br>
문자열 str=null;<br>
sb=new StringBuffer();<br>
//입력 스트림에서 데이터 읽기 <br>
while ((str = reader.readline ())! = NULL) {<br>
sb.append(str).append(System.getProperty("line.separator"));<br>
}<br>
> >
reader.close();<br>
If (sb.toString().length() == 0) {<br>
null 반환 <br>
}<br>
return sb.toString().substring(0,<br>sb.toString().length() - System.getProperty("line.separator").length());<br>
}<br>
} 잡기(예외 e) {<br>
e.printStackTrace();<br>
> > null을 반환합니다.
}드디어{<br>
if(conn!=null)//연결 종료<br>
conn.disconnect();<br>
}<br>
null 반환;<br>
}<br>
<br>
}<br>Demo2: 도시 목록 인터페이스 호출 예시
package juheAPI;
<br>
import net.sf.json.JSONArray;<br>
import net.sf.json.JSONObject;<br>
<br>
<br>
/**<br>
* 도시 목록 받기<br>
* JAVA 예시를 호출하는 전국 일기예보 인터페이스<br>
* dtype 문자열 N 반환 데이터 형식: json 또는 xml, 기본값은 json <br>
* 키 문자열 Y 신청한 키 <br>
* @author 실크<br>
*<br>
*/<br>
공개 클래스 GetCityList {<br>
/**<br>
* 도시 목록을 가져오고 모든 데이터를 반환하려면 인터페이스를 호출하세요<br>
* @return 인터페이스 데이터 반환<br>
*/<br>
공개 정적 문자열 excute(){<br>
문자열 url="http://v.juhe.cn/weather/citys?key=***a7558b2e0bedaa19673f74a6809ce";//인터페이스 URL<br>
//PureNetUtil은 네트워크 요청 데이터를 얻기 위해 get 및 post 메소드를 캡슐화하는 도구 클래스입니다<br>
return PureNetUtil.get(url);//get 메소드 사용<br>
}<br>
/**<br>
* 인터페이스를 호출하여 데이터를 반환한 후, 데이터를 파싱하여 입력된 도시명을 기준으로 해당 ID<br>를 얻어옵니다.
* @param cityName 도시명<br>
* @return 해당 ID를 반환합니다<br>
*/<br>
공개 정적 문자열 getIDBycityName(String cityName) {<br>
String result=excute();//인터페이스 결과를 반환하고 json 형식 데이터를 가져옵니다<br>
If(결과!=null){<br>
JSONObject obj=JSONObject.fromObject(결과);<br>
result=obj.getString("resultcode");//반환 상태 코드 가져오기<br>
If(result!=null&&result.equals("200")){//200은 데이터가 성공적으로 반환되었음을 나타냅니다.<br>
result=obj.getString("result");//도시 목록의 json 형식 문자열 배열 가져오기<br>
JSONArray arr=JSONArray.fromObject(결과);<br>
for(Object o:arr){//Traverse arr<br>
//배열의 json 숫자 문자열을 구문 분석합니다<br>
>
/* 이때, {"ID": "2", "Province": "Beijing", "City": "Beijing", "Distrib": "Haidian"}*/<br>//도시 열쇠를 단서로 사용하여 찾아야 할 기록을 결정하세요 <br>
result=obj.getString("district");<br>
// 입력 도시의 불완전한 이름 입력을 방지합니다. 예를 들어 Suzhou가 Suzhou로 입력되어 유사하고 모호한 쿼리 <br>
If(result.equals(cityName)||result.contains(cityName)){<br>
result=obj.getString("id");//ID 가져오기<br>
>
}<br>
}<br>
}<br>
}<br>
결과 반환<br>
}<br>
공개 정적 무효 main(String[] args) {<br>
System.out.println(getIDBycityName("홍콩"));<br>
}<br>
}<br>Demo3: 도시 이름/ID를 기준으로 날씨를 쿼리하는 호출
package juheAPI;
<br>
import net.sf.json.JSONObject;<br>
<br>
<br>
/**<br>
* 도시 이름/ID를 기준으로 날씨 쿼리<br>
* @author 실크<br>
*<br>
*/<br>
공개 클래스 WeatherReportByCity {<br>
/**<br>
* 도시 이름을 기준으로 가져옵니다<br>
* @param cityName<br>
* * @return<br>
*/<br>
공개 정적 문자열 excute(String cityName){<br>
String url=//다음은 json 형식의 데이터를 반환하는 예이므로 format=2, 도시 이름을 예로 들면 cityName이 중국어로 전달됩니다 <br>
"http://v.juhe.cn/weather/index?cityname="+cityName+"&key=***a7558b2e0bedaa19673f74a6809ce";<br>
return PureNetUtil.get(url);//도구 클래스를 통해 반환 데이터 가져오기 <br>
}<br>
/**<br>
* 반환된 데이터의 속성 예시를 가져옵니다. 여기서는 오늘의 온도를 예시로 가져옵니다. <br>
* "온도" : "8℃~20℃" 오늘의 기온 <br>
* @param 인수<br>
* * @return <br>
*/<br>
공개 정적 문자열 GetTodayTemperatureByCity(문자열 도시) {<br>
문자열 결과=excute(city);<br>
If(결과!=null){<br>
JSONObject obj=JSONObject.fromObject(결과);<br>
/*반환 상태 코드 가져오기*/<br>
result=obj.getString("resultcode");<br>
/*상태 코드가 200이면 데이터 반환 성공*/<br>
If(결과!=null&&result.equals("200")){<br>
result=obj.getString("result");<br>
// 이때 결과의 데이터에는 여러 개의 키가 있으며, 키를 순회하여 속성 쌍을 얻을 수 있습니다 <br>
obj=JSONObject.fromObject(결과);<br>//오늘의 기온에 해당하는 열쇠는 오늘입니다<br>
result=obj.getString("오늘");<br>
obj=JSONObject.fromObject(결과);<br>
//오늘의 기온에 해당하는 핵심은 기온<br>
result=obj.getString("온도");<br>
결과 반환;
}<br>
}<br>
결과 반환<br>
}<br>
공개 정적 무효 main(String[] args) {<br>
System.out.println(GetTodayTemperatureByCity("쑤저우"));<br>
}<br>
}<br>Demo4: 날씨 유형 및 표시 목록 인터페이스 호출 예시
package juheAPI;
<br>
import net.sf.json.JSONArray;<br>
import net.sf.json.JSONObject;<br>
<br>
<br>
/**<br>
* JAVA 예제를 호출하는 날씨 유형 및 식별 목록 인터페이스<br>
* @author 실크<br>
*/<br>
공개 클래스 GetWeatherSignAndTypeList {<br>
//인터페이스 주소, 고정 키만 매개변수로 전달하면 되므로 상수로 설정하세요 <br>
비공개 정적 최종 문자열 URL= "http://v.juhe.cn/weather/uni?key=***a7558b2e0bedaa19673f74a6809ce";<br>
/**<br>
* 도구 클래스를 통해 데이터 가져오기<br>
* @return<br>
*/<br>
공개 정적 문자열 excute(){<br>
return PureNetUtil.get(URL);//인터페이스 데이터를 가져오기 위해 도구 클래스를 호출합니다<br>
}<br>
/**<br>
* * 배열을 순회하여 <br> 획득
* @param wid 날씨 해당 아이디<br>
* @return 날씨 이름<br>
*/<br>
공개 정적 문자열 getWeatherByWid(String wid) {<br>
문자열 결과=excute();//인터페이스 데이터 가져오기<br>
If(결과!=null){<br>
JSONObject obj=JSONObject.fromObject(결과);<br>
result=obj.getString("resultcode");<br>
/*반품 상태 코드 받기*/<br>
If(결과!=null&&result.equals("200")){<br>
/*배열 데이터 가져오기*/<br>
result=obj.getString("result");<br>
JSONArray arr=JSONArray.fromObject(결과);<br>
For (object o: arr) {// 배열 탐색 <br>
>
|
If(obj.getString("wid").equals(wid)){<br>
result=obj.getString("날씨");<br>>
}<br>
}<br>
}<br>
}<br>
결과 반환<br>
}<br>
공개 정적 무효 main(String[] args) {<br>
System.out.println(getWeatherByWid("10"));<br>
}<br>
}<br>5단계: 인터페이스 호출 시 상태 코드가 200이 아닌 경우 설명서를 주의 깊게 참조하세요. 즉, 3단계로 돌아가서 설명서를 읽어보세요!