Android 上的 Apache Commons Configuration Plist 解析器 - 没有可用的验证 SAXParser 实现
Posted
技术标签:
【中文标题】Android 上的 Apache Commons Configuration Plist 解析器 - 没有可用的验证 SAXParser 实现【英文标题】:Apache Commons Configuration Plist parser on Android - No validating SAXParser implementation available 【发布时间】:2012-02-28 17:52:10 【问题描述】:我正在尝试在 Apache Commons 配置库的帮助下解析苹果的 plist 文件。当我尝试下面的示例作为 Java 应用程序时,一切正常,但 android 上的相同代码抛出异常。
好的,更多细节请看下面的代码:
这是我的 android 应用程序的入口点:
@Override
public void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
try
Log.i("AC", "Hello");
XMLPropertyListConfiguration plist = new XMLPropertyListConfiguration();
plist.setFileName("assets/data.plist");
plist.load();
Object prop = plist.getProperty("Resorts");
if(prop instanceof List)
List<XMLPropertyListConfiguration> resorts = (List<XMLPropertyListConfiguration>) prop;
Log.i("AC",resorts.get(0).getClass().toString());
Log.i("AC",resorts.get(1).getClass().toString());
for(int i=0; i<resorts.size(); i++)
String folder = (String) resorts.get(i).getProperty("Folder");
List<XMLPropertyListConfiguration> courses = (List<XMLPropertyListConfiguration>) resorts.get(i).getProperty("Courses");
Log.i("AC","Resort "+i+" in folder "+folder);
for(int j=0; j<courses.size(); j++)
BigInteger course_index = (BigInteger) courses.get(j).getProperty("Index");
String course_name = (String) courses.get(j).getProperty("Name");
Log.i("AC","- Course "+course_index+": "+course_name);
catch (ConfigurationException e)
Log.e("AC","ConfigurationException");
e.printStackTrace();
这是我要解析的 plist:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Resorts</key>
<array>
<dict>
<key>Courses</key>
<array>
<dict>
<key>Index</key>
<integer>1</integer>
<key>Name</key>
<string>Black Stork International</string>
</dict>
<dict>
<key>Index</key>
<integer>2</integer>
<key>Name</key>
<string>Black Stork Panorama</string>
</dict>
<dict>
<key>Index</key>
<integer>3</integer>
<key>Name</key>
<string>Black Stork Village</string>
</dict>
</array>
<key>Folder</key>
<string>01</string>
</dict>
</array>
</dict>
</plist>
在构建路径中我添加了外部 jar:
commons-configuration-1.8.jar commons-lang-2.6.jar产生的异常:
02-28 18:23:52.531: W/System.err(795): org.apache.commons.configuration.ConfigurationException: Unable to parse the configuration file
02-28 18:23:52.531: W/System.err(795): at org.apache.commons.configuration.plist.XMLPropertyListConfiguration.load(XMLPropertyListConfiguration.java:263)
02-28 18:23:52.541: W/System.err(795): at org.apache.commons.configuration.AbstractHierarchicalFileConfiguration$FileConfigurationDelegate.load(AbstractHierarchicalFileConfiguration.java:565)
02-28 18:23:52.541: W/System.err(795): at org.apache.commons.configuration.AbstractFileConfiguration.load(AbstractFileConfiguration.java:395)
02-28 18:23:52.541: W/System.err(795): at org.apache.commons.configuration.AbstractFileConfiguration.load(AbstractFileConfiguration.java:361)
02-28 18:23:52.551: W/System.err(795): at org.apache.commons.configuration.AbstractFileConfiguration.load(AbstractFileConfiguration.java:324)
02-28 18:23:52.551: W/System.err(795): at org.apache.commons.configuration.AbstractFileConfiguration.load(AbstractFileConfiguration.java:261)
02-28 18:23:52.560: W/System.err(795): at org.apache.commons.configuration.AbstractFileConfiguration.load(AbstractFileConfiguration.java:238)
02-28 18:23:52.560: W/System.err(795): at org.apache.commons.configuration.AbstractHierarchicalFileConfiguration.load(AbstractHierarchicalFileConfiguration.java:184)
02-28 18:23:52.560: W/System.err(795): at sk.datacrea.common.skuska2.CommonSkuska2Activity.onCreate(CommonSkuska2Activity.java:58)
02-28 18:23:52.571: W/System.err(795): at android.app.Activity.performCreate(Activity.java:4465)
02-28 18:23:52.571: W/System.err(795): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
02-28 18:23:52.571: W/System.err(795): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
02-28 18:23:52.582: W/System.err(795): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
02-28 18:23:52.582: W/System.err(795): at android.app.ActivityThread.access$600(ActivityThread.java:123)
02-28 18:23:52.582: W/System.err(795): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
02-28 18:23:52.592: W/System.err(795): at android.os.Handler.dispatchMessage(Handler.java:99)
02-28 18:23:52.592: W/System.err(795): at android.os.Looper.loop(Looper.java:137)
02-28 18:23:52.592: W/System.err(795): at android.app.ActivityThread.main(ActivityThread.java:4424)
02-28 18:23:52.601: W/System.err(795): at java.lang.reflect.Method.invokeNative(Native Method)
02-28 18:23:52.601: W/System.err(795): at java.lang.reflect.Method.invoke(Method.java:511)
02-28 18:23:52.601: W/System.err(795): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-28 18:23:52.601: W/System.err(795): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-28 18:23:52.601: W/System.err(795): at dalvik.system.NativeStart.main(Native Method)
02-28 18:23:52.601: W/System.err(795): Caused by: javax.xml.parsers.ParserConfigurationException: No validating SAXParser implementation available
02-28 18:23:52.625: W/System.err(795): at org.apache.harmony.xml.parsers.SAXParserFactoryImpl.newSAXParser(SAXParserFactoryImpl.java:75)
02-28 18:23:52.625: W/System.err(795): at org.apache.commons.configuration.plist.XMLPropertyListConfiguration.load(XMLPropertyListConfiguration.java:256)
02-28 18:23:52.625: W/System.err(795): ... 22 more
希望有高手为我解答:)
【问题讨论】:
在开发组中找到:groups.google.com/group/android-developers/browse_thread/thread/… 是的,我之前读过它并且我推测要调用 setValidating(false) 但是当在文件 XMLPropertyListConfiguration.class 中调用此方法时,我该怎么做,该文件是作为外部添加的库的一部分罐子? 【参考方案1】:异常“没有可用的验证 Saxparser 实现”确实是因为在文件 XMLPropertyListConfiguration 中将 Saxparser 工厂的验证设置为 true。
最终我使用了这个解决方案: 我在项目的源文件夹中创建了新类 XMLPropertyListConfiguration2,它与外部 JAR 中的 XMLPropertyListConfiguration 类相同,除了验证更改为 false。
然后在我的 Activity 的 onCreate 方法中,我使用了这个类而不是 XMLPropertyListConfiguration。
【讨论】:
以上是关于Android 上的 Apache Commons Configuration Plist 解析器 - 没有可用的验证 SAXParser 实现的主要内容,如果未能解决你的问题,请参考以下文章
Android 开发:Java.lang.NoSuchMethodError: org.apache.commons.codec.binary.Base64.encodeBase64String()
ANDROID : java.lang.NoSuchMethodError: org.apache.commons.codec.binary.Base64.encodeBase64String in
无法使用Apache Commons FTPClient访问FTP服务器上的子文件夹