HTTP POST/GET FOR JAVA

2181 단어 자바.netAccess
문제 요약:
며칠 전 N 오래된 HTTP API 를 디 버 깅 했 는데 문제 가 해결 되 지 않 았 습 니 다.http get/post 방식 으로 중국어 문 자 를 전송 할 때 수신 단 에서 문자열 을 정확하게 읽 지 못 하 는 문 제 는 다음 과 같 습 니 다.
의사 코드 는 다음 과 같 습 니 다:
    String URL="http://127.0.0.1:8080/access.do";
    String content=java.net.URLEncoder.encode("중국어 테스트","GBK");
     String params="id=1&content="+content;
encode 를 통과 한 문자열 은'%D6%D0%CE%C4%B2%E2%CA%D4'입 니 다.
수신 단 출력 문 구 는 다음 과 같 습 니 다.
    request.getParameter("content");
그러나 인쇄 된 문자열 은'%D6%D0%CE%C4%B2%E2%CA%D4'가 아니 라 다른 전 의 된 문자열 로 인해 원본 문자열 로 올 바 르 게 decode 할 수 없습니다.
해결 방안
지금까지 이상 의 문제 원인 이 무엇 인지 알 수 없다.나중에 http get/post 에 대한 연 구 를 통 해 다음 과 같이 처 리 했 습 니 다.

		String httpMethod = request.getMethod();
		//   get request,  request.getQueryString()  request information
		String requestInfo = "";
		BufferedReader in = null;
		if(httpMethod.equals("GET")){
			requestInfo = request.getQueryString(); 
		}else{		
		//   post request,  BufferedReader  request information
		 in = new BufferedReader(new InputStreamReader(
				request.getInputStream()));
		String line = "";
		StringBuffer stringValue=new StringBuffer();
		while ((line = in.readLine()) != null) {			 
			stringValue.append(line);
		}
		
		requestInfo = stringValue.toString();
		}
	    logger.info("requestInfo************* is :"+ requestInfo);
		String[] params = requestInfo.split("&");

//		  params
		if(params!=null && params.length>0){
			for(int i=0;i<params.length;i++){
                            if((params[i].indexOf("content=")>=0) && params[i].split("=").length>1){
					content= (params[i].split("="))[1];
				}
                            }
                   }

주의 하 다.
http GET/POST 의 문자 흐름 가 져 오 는 방식 은 다 릅 니 다.
get request 라면 request.getQuery String()으로 가 져 옵 니 다.
post request 라면 Buffered Reader 로 가 져 옵 니 다.

좋은 웹페이지 즐겨찾기