0

我在使用 DocumentBuilderFactory 解析 xml 字符串时遇到问题。当我查看 log.d("File",file) 时,文件包含我想要的 xml 字符串。但是,当我使用 Document doc = db.parse(inputSource) 获取文档时,它返回 SAXException。有人能告诉我我的编码有什么问题吗?谢谢你。

        String query="https://maps.googleapis.com/maps/api/directions/xml?origin=33.78917,-118.107626&destination=33.77319,-118.125221&sensor=true";
        url = new URL(query);
        URLConnection connection = url.openConnection();
        HttpURLConnection httpConnection = (HttpURLConnection)connection;
        int responseCode = httpConnection.getResponseCode();
        InputStreamReader in = new InputStreamReader(httpConnection.getInputStream());
        InputStream inputStream = httpConnection.getInputStream();
        BufferedReader buf = new BufferedReader(in);

        String file="";         
        while(buf.readLine()!=null){                        

            file+=buf.readLine();
            Log.d("File", file);
        }                               

        if(responseCode==HttpURLConnection.HTTP_OK){

            DocumentBuilderFactory dbf =DocumentBuilderFactory.newInstance();
            DocumentBuilder db= dbf.newDocumentBuilder();
            //parse xml file
                //Document doc = db.parse(file);
            InputSource inputSource = new InputSource();
            inputSource.setCharacterStream(new StringReader(file));
            Log.d("COde",httpConnection.getResponseCode()+"");
            try{
                Document doc = db.parse(inputSource);               
                Element el = doc.getDocumentElement();
                NodeList nl = el.getElementsByTagName("step");
                Log.d("COde",httpConnection.getResponseCode()+"");
                Path p;
                if(nl!=null && nl.getLength()>0){
                    for(int i=0; i<nl.getLength();i++){                     
                        Node entry =nl.item(i);
                        NodeList child= entry.getChildNodes();
                        Log.d("List Size",list.size()+"size");
                        Element elements = (Element)entry.getChildNodes();
                        Element sPoint = (Element) elements.getElementsByTagName("start_location");
                        Element ePoint = (Element)elements.getElementsByTagName("end_location");                                                
                        Point sP = new Point(sPoint.getFirstChild().getNodeValue(),sPoint.getLastChild().getTextContent());
                        Point eP = new Point(ePoint.getFirstChild().getTextContent(),ePoint.getLastChild().getTextContent());
                        String durationValue = elements.getElementsByTagName("duration").item(0).getNodeValue();
                        Log.d("Duration",durationValue);
                        String durationText = elements.getElementsByTagName("duration").item(1).getNodeValue();
                        String instr= elements.getElementsByTagName("html_instructions").item(0).getNodeValue();
                        String distanceValue =elements.getElementsByTagName("distance").item(0).getNodeValue();
                        String distanceText = elements.getElementsByTagName("duration").item(1).getNodeValue();
                        p = new Path(sP,eP,durationText,distanceText,instr);                        
                        list.add(p);
                        Log.d("List Size",list.size()+"size");
                    }
                }
            }
            finally{}
        }           
    }

    catch(MalformedURLException e1){
        Log.d("HTTP_CALL","MalformedURLException");
    }                   
    catch(ParserConfigurationException e1){
        Log.d("HTTP_CALL","ParserConfigurationException");
    }       
    catch(SAXException e1){
        Log.d("HTTP_CALL","SAXException");
    }catch(IOException e1){
        Log.d("HTTP_CALL","IOException");
    }
4

2 回答 2

1

我猜是因为您正在将它读入一个 java 字符串,该字符串正在转义您作为字符流读回的一些字符。

这似乎对我有用:

InputStream inputStream = connection.getInputStream();
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse(inputStream);
于 2013-10-23T00:43:17.517 回答
0

我可以从错误消息中了解到,它正在寻找,</leg>因为它说expected: /leg并且它得到了一个start_location.

您可能错过了在<leg>某处关闭标签

于 2013-10-23T00:43:28.827 回答