オンライン XML ファイルから現在の為替レートを読み取り、w3c DOM を介して解析する Android アプリを開発しています。ファイルは AWS S3 ストレージにあります。
パーサーは正常に動作し、すべてのレートを希望どおりに取得できますが、アンチウイルス アプリ ( avast! ) はアプリにマルウェア ( Android:Agent-YI[Trj] ) としてフラグを立て続けます。コードをコメントアウトし、使用するメソッドが返されるだけでtrue
、AV が静かになるため、以下のコードに絞り込みました。
AVが私のコードを受け入れない理由を誰か知っていますか? アプリの唯一の権限は次のとおりです。
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>
パーサー コード:
public static boolean fetchCurrencyRates(String in)
{
boolean success = true;
HashMap<String, Double> onlineRates = new HashMap<String, Double>();
try
{
Document xmlRates = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(in);
xmlRates.getDocumentElement().normalize();
NodeList xmlItems = xmlRates.getElementsByTagName("item");
for(int i = 0; i < xmlItems.getLength(); i++)
{
Node n = xmlItems.item(i);
if(n != null && n.getNodeType() == Node.ELEMENT_NODE)
{
Element currency = (Element) n;
String code = currency.getElementsByTagName("title").item(0)
.getTextContent()
.substring(0, 3);
String rate = currency.getElementsByTagName("description").item(0)
.getTextContent()
.split(" ")[3];
Log.i("DEV", code + ": " + rate);
onlineRates.put(code, Double.parseDouble(rate.replaceAll(",", "")));
}
}
}
catch(Exception e)
{
Log.e("DEV", e.getMessage();
success = false;
}
return success && !onlineRates.isEmpty();
}
また、Android ドキュメントで推奨されているように使用しようとしXmlPullParser
ましたが、同じ問題に遭遇しました。