Я пытался создать простое приложение, которое анализирует весь канал в строку и печатает его, а также может сохранить проанализированные данные в sqlite db в будущем.Я следил за tutorial1 и tutorial2 Я также читал учебник IBM вместе с 3-4 другими реализациями программ для чтения RSS, но не могу понять, что не так
Item.java
public class Item extends Object {
private String Data= null;
Item() {
}
Item(String data) {
this.Data = data;
}
public void setData(String data) {
this.Data = data;
}
public String getData() {
return this.Data;
}
}
RSSHandler.java
public class RSSHandler extends DefaultHandler {
public static final String ITEMS_TABLE="items";
private final String MY_DEBUG_TAG = "handler";
boolean inChannel = false;
public Item item;
LearDB leardb = null;
RSSHandler(Context context)
{
leardb = new LearDB(context);
item =new Item();
}
@Override
public void startDocument() throws SAXException {
this.item = new Item();
}
@Override
public void endDocument( ) throws SAXException{
}
@Override
public void startElement(String Uri, String localName, String qName,
Attributes atts) throws SAXException {
if (localName.equals("channel")) {
this.inChannel = true;
}
else {
return;
}
}
@Override
public void endElement(String Uri, String localName, String qName)
throws SAXException {
if (localName.equals("channel")) {
this.inChannel = false;
}
else {
return;
}
}
@Override
public void characters(char ch[], int start, int length) {
String temp = new String(ch, start, length);
try {
if (this.inChannel) {
this.item.setData(temp);
}
} catch (Exception e) {
Log.e(MY_DEBUG_TAG, "Parsing Error", e);
}
}
public String getData() {
return this.item.getData();
}
public Item getItem() {
return this.item;
}
public void insertItem(String temp) {
SQLiteDatabase db = leardb.getWritableDatabase();
ContentValues value=new ContentValues();
value.put("data", temp);
db.insert(ITEMS_TABLE, null, value);
}
}
LearDB.java
public class LearDB extends SQLiteOpenHelper {
private static final String DATABASE_NAME="lear.db";
public static final String ITEMS_TABLE="items";
public LearDB(Context context) {
super(context, DATABASE_NAME, null, 1);
}
@Override
public void onCreate(SQLiteDatabase db) {
String sql = ("CREATE TABLE items (_id INTEGER PRIMARY KEY AUTOINCREMENT, data TEXT);");
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if (oldVersion == 1 && newVersion == 2) {
String sql = "drop table items;";
db.execSQL(sql);
sql = ("CREATE TABLE items (_id INTEGER PRIMARY KEY AUTOINCREMENT, data TEXT);");
db.execSQL(sql);
}
}
}
основное действие
public class test3 extends Activity {
private final String MY_DEBUG_TAG = "test2";
@Override
public void onCreate(Bundle icicle) {
super.onCreate(icicle);
TextView text = new TextView(this);
try {
URL url = new URL("http://achdre.freehostia.com/example.xml");// URL of XML document to be parsed
InputSource source = new InputSource(url.openStream());
SAXParserFactory LearParseFactory = SAXParserFactory.newInstance();
SAXParser LearParser = LearParseFactory.newSAXParser(); //SAX Parser object
XMLReader LearReader = LearParser.getXMLReader(); // Object that scans the XML document
RSSHandler LearHandler = new RSSHandler(this); //Handler object
LearReader.setContentHandler(LearHandler);
LearReader.parse(source); //Parses the XML document
String temp=LearHandler.getData();
text.setText("12345");
LearHandler.insertItem("android"); //inserting test string to DB
}
catch (Exception e) {
text.setText("Error: " + e.getMessage());
Log.e(MY_DEBUG_TAG, "Parsing Error", e);
}
this.setContentView(text);
}}
и файл манифеста
<uses-sdk android:minSdkVersion="8" />
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<application android:icon="..." android:label="..."android:debuggable="true">
<activity android:name=".test3"android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
android:label="@string/app_name"android:debuggable="true">
edit: мне удалось запустить его.ошибки были как в xml, который я пытался проанализировать, так и в событиях обратного вызова класса моего обработчика.нет необходимости в дополнительной помощи