androidxml字元轉義
㈠ android中的xml文件中文亂碼怎麼解決
一、android sax庫遇到gbk或gb2312編碼時
方法1. 可以顯示的指明編碼比如
InputSource is = new InputSource(inputStream); is.setEncoding("UTF-8");
方法2. 使用InputStreamReader轉換 在SDK中可以查看有這樣實例化方法,參數二為字元集
InputStreamReader(InputStream in, Charset charset)
具體使用可以是
InputSource is=new InputSource(new InputStreamReader(inputStream,"gb2312"));
有關InputSource的細節, 如果有字元流可用,則解析器將直接讀取該流,而忽略該流中找到的任何文本編碼聲明。如果沒有字元流,但卻有位元組流,則解析器將使用該位元組流,從而使 用在 InputSource 中指定的編碼,或者另外(如果未指定編碼)通過使用某種諸如 XML 規范 中的演算法演算法自動探測字元編碼。如果既沒有字元流,又沒有位元組流可用,則解析器將嘗試打開到由系統標識符標識的資源的 URI 連接 。
二、android開發網提倡盡量在伺服器上配置使用utf-8編碼,雖然顯示英文字元較為兩非,但是兼容性是最好的,也是國際最主流的標准。
㈡ Android將這xml文件用sax方式解析怎麼弄
在 Android中解析XML文主要有三種方式,分別為Simple API for XML(SAX)、Document Object Model(DOM)和Android附帶的PULL解析器。其中SAX是一個解析速度非常快並且佔用內存少的XML解析器,非常適合Android手機等移動設備。
SAX解析XML文件採用事件驅動的方式進行,也就是說,SAX是逐行掃描文件,遇到符合條件的設定條件後就會觸發特定的事件,回調你寫好的事件處理程序。使用SAX的優勢在於其解析速度較快,佔用內存較少(相對於DOM而言)。而且SAX在解析文件的過程中得到自己需要的信息後可以隨時終止解析,並不一定要等文件全部解析完畢。凡事有利必有弊,其劣勢在於SAX採用的是流式處理方式,當遇到某個標簽的時候,它並不會記錄下以前所遇到的標簽,也就是說,在處理某個標簽的時候,比如在 startElement方法中,所能夠得到的信息就是標簽的名字和屬性,至於標簽內部的嵌套結構,上層標簽、下層標簽以及其兄弟節點的名稱等等與其結構相關的信息都是不得而知的。實際上就是把XML文件的結構信息丟掉了,如果需要得到這些信息的話,只能你自己在程序里進行處理了。所以相對DOM而言,SAX處理XML文檔沒有DOM方便,SAX處理的過程相對DOM而言也比較復雜。
使用SAX解析XML文件一般有以下五個步驟:
1、創建一個SAXParserFactory對象(通過類名很容易得知它利用工廠方法模式實現的);
2、調用SAXParserFactory中的newSAXParser方法創建一個SAXParser對象;
3、然後在調用SAXParser中的getXMLReader方法獲取一個XMLReader對象;
4、在XMLReader中注冊事件處理介面,一般有ContentHandler、ErrorHandler、DTDHandler、EntityHandler四種;
5、調用XMLReader中的parse方法解析指定的XML字元串對象;
步驟四中提到的四個Handler是事件處理介面,SAX的事件處理函數就定義在這四個介面中,利用SAX解析XML文件需要重寫介面中的方法。其中ContentHandler用來處理XML中的內容,ErrorHandler用來處理錯誤,DTDHandler用來處理DTD,EntityHandler用來處理XML文檔中的實體;最常用的是ContentHandler這個介面,下面是該介面中的一些常用方法:
startDocument()
當遇到文檔的開頭的時候,調用這個方法,可以在其中做一些預處理的工作。
endDocument()
和上面的方法相對應,當文檔結束的時候,調用這個方法,可以在其中做一些善後的工作。
startElement(String uri, String localName, String qName, Attributes atts)
當讀到一個開始標簽的時候,會觸發這個方法。uri是命名空間(通過xmlns聲明),localName是不帶命名空間前綴的標簽名,qName是帶命名空間前綴的標簽名。通過atts可以得到所有的屬性名和相應的值。注意,如果沒有指定Namespace,則qName可能為空,當然不同的SAX實現會有所不同,比如在Android中qName為空,而J2SE中localName為空,所以想要總是得到標簽名,就需要檢查這兩個參數的值了。
endElement(String uri, String localName, String name)
這個方法和上面的方法相對應,在遇到結束標簽的時候,調用這個方法。
characters(char[] ch, int start, int length)
這個方法用來處理在XML文件中讀到的內容,第一個參數為文件的字元串內容,後面兩個參數是讀到的字元串在這個數組中的起始位置和長度,使用new String(ch,start,length)就可以獲取內容。
下面是利用SAX解析XML文件的DEMO程序,首先定義一個XML文件users.xml,內容如下:
01 <?xml version="1.0" encoding="utf-8"?>
02 <users>
03 <user id="1">
04 <name>wuxianglong</name>
05 <password>199098</password>
06 </user>
07 <long:user id="2">
08 <name>wuwenyuan</name>
09 <password>199189</password>
10 </long:user>
11 </users>
其中第二個user標簽中字元串long就是所謂的前綴,標簽中的id則是該標簽的一個屬性。
然後我們來實現ContentHandler這個介面,並重寫其中的方法來處理上面的XML文件,代碼如下:
01 package sax.test;
02
03 import java.util.ArrayList;
04
05 import org.xml.sax.Attributes;
06 import org.xml.sax.SAXException;
07 import org.xml.sax.helpers.DefaultHandler;
08
09 public class MyHandler extends DefaultHandler {
10 private ArrayList<User> users;
11 private User user;
12 private String content;
13
14 public ArrayList<User> getUsers() {
15 return users;
16 }
17
18 @Override
19 public void startDocument() throws SAXException {
20 super.startDocument();
21 users = new ArrayList<User>();
22 System.out.println("----------Start Parse Document----------" );
23 }
24
25 @Override
26 public void endDocument() throws SAXException {
27 System.out.println("----------End Parse Document----------" );
28 }
29
30 @Override
31 public void characters(char[] ch, int start, int length)
32 throws SAXException {
33 super.characters(ch, start, length);
34 // 獲得標簽中的文本
35 content = new String(ch, start, length);
36 }
37
38 @Override
39 public void startElement(String uri, String localName, String qName,
40 Attributes attributes) throws SAXException {
41 super.startElement(uri, localName, qName, attributes);
42 // 列印出localname和qName
43 System.out.println("LocalName->" + localName);
44 System.out.println("QName->" + qName);
45 if ("user".equals(localName)) {
46 user = new User();
47 user.setId(Integer.parseInt(attributes.getValue("id")));
48 }
49 }
50
51 @Override
52 public void endElement(String uri, String localName, String qName)
53 throws SAXException {
54 super.endElement(uri, localName, qName);
55 if ("name".equals(localName)) {
56 user.setName(content);
57 } else if ("password".equals(localName)) {
58 user.setPassword(content);
59 } else if ("user".equals(localName)) {
60 users.add(user);
61 }
62 }
63 }
最後我們編輯TestSAX這個類,獲取users.xml這個文件中的內容,並利用SAX進行解析,代碼如下:
01 package sax.test;
02
03 import java.io.IOException;
04
05 import javax.xml.parsers.ParserConfigurationException;
06 import javax.xml.parsers.SAXParser;
07 import javax.xml.parsers.SAXParserFactory;
08
09 import org.xml.sax.InputSource;
10 import org.xml.sax.SAXException;
11 import org.xml.sax.XMLReader;
12
13 import android.app.Activity;
14 import android.os.Bundle;
15 import android.widget.TextView;
16
17 public class TestSAX extends Activity {
18 private TextView text;
19
20 /** Called when the activity is first created. */
21 @Override
22 public void onCreate(Bundle savedInstanceState) {
23 super.onCreate(savedInstanceState);
24 setContentView(R.layout.main);
25
26 text = (TextView) findViewById(R.id.result);
27
28 try {
29 // 創建一個工廠對象
30 SAXParserFactory factory = SAXParserFactory.newInstance();
31 // 通過工廠對象得到一個解析器對象
32 SAXParser parser = factory.newSAXParser();
33 // 通過parser得到XMLReader對象
34 XMLReader reader = parser.getXMLReader();
35 // 為reader對象注冊事件處理介面
36 MyHandler handler = new MyHandler();
37 reader.setContentHandler(handler);
38 // 解析指定XML字元串對象
39 reader.parse(newInputSource(TestSAX.class.getClassLoader().getResourceAsStream("users.xml")));
40
41 String usersInfo = "";
42 for (User user : handler.getUsers()) {
43 usersInfo += "ID->" + user.getId() + "\n";
44 usersInfo += "NAME->" + user.getName() + "\n";
45 usersInfo += "PASSWORD->" + user.getPassword() + "\n";
46 usersInfo += "\n\n";
47 }
48 text.setText(usersInfo);
49 } catch (SAXException e) {
50 e.printStackTrace();
51 } catch (ParserConfigurationException e) {
52 e.printStackTrace();
53 } catch (IOException e) {
54 e.printStackTrace();
55 }
56 }
57
58 }
㈢ android調用webservice傳xml格式的字元串過去,服務端接收到的尖括弧被轉義了。要怎樣傳才不會被轉義
加轉義字元\,或者還有一個辦法。比如回車鍵\n會被轉移。你把\n replace一下,換成別的單詞,在服務端收到這個單詞的時候,在轉換回來
㈣ Android audio_policy_configuration.xml
前言
Android的audioserver 進程啟動時,會創建AudioPolicyManager,在構造函數中,首先會去解析audio_policy_configuration.xml文件。
audio音頻數據從一個源走到一個目的都是需要根據配置文件audio_policy_configuration.xml來決定,所以理解configuration配置文件中各個標簽項轉化為c++實體類的及各成員至關重要。
audio_policy_configuration.xml為音頻audio的設備、流以及路由等配置文件,裡面寫明了audio音頻部分有哪些設備、哪些流以及它們支持的編碼、格式以及通道存儲布局等等
audio_policy_configuration.xml中 的<moles>對應每一個audio hal 的so,mole中列出的mixPorts,devicePorts和routes解析之後完整的描述了音頻的路由規則
mole name
支持「primary」 (用於車載使用場景), "A2DP", "remote_submix"和"USB"。模塊名稱和相應音頻驅動程序應編譯到 audio.primary.$(variant).so 中
devicePorts
包含可從此模塊訪問的所有輸入和輸出設備(包括永久連接的設備和可移除設備)的設備描述符列表。設備的output和input,不是像mixport那樣以role來分,而是以type中有關鍵字「IN」和「OUT」來區分
mixPorts
包含由音頻 HAL 提供的所有輸出流和輸入流的列表。每個 mixPort 實例都可被視為傳輸到 Android AudioService 的物理音頻流,stream配置了自己的格式、采樣率以及mask,並且分為輸出、輸入流。一個mixPort標簽可能有多個profile屬性,也就是支持很多編碼格式屬性
routes
定義輸入和輸出設備之間或音頻流和設備之間可能存在的連接的列表。route是把deviceport和mixport連接起來的路由,數據由一個stream輸出到另一個device,或者從一個device輸出到另一個stream。
㈤ Android 如何解析Xml字元串
其實把它當成string就可以了,用string的split方法通過標示符來切割string就可以拿到你想要的數據了