/**
* 解析.mms文件内容 所有文件将解析到%source%+%fileName%文件夹下, <br/>
* smil将会重命名为%fileName%.smil
*
* @param source
* 源文件
* eg:"D:\\apache-tomcat-6.0.26\\webapps\\lvxian_unicom\\UserFiles\\1273719840015"
* @param fileName
* 解析内容存储文件夹 eg:"1273719840015"
* @throws Exception
*/
@SuppressWarnings("unchecked")
public static void readMms(String source, String fileName) throws Exception {
FileOutputStream Filefo = null;
try
{
File f = new File(source + fileName);
SAXReader reader = new SAXReader();
Document doc = reader.read(f);
Element root = doc.getRootElement();
Element content = root.element("Content");
Element foo;
for (Iterator i = content.elementIterator("PresentationContent"); i.hasNext();)
{
foo = (Element) i.next();
String name = foo.elementText("ContentID");
String data = foo.elementText("Data");
if ("application/smil".equals(foo.elementText("ContentType")))
{
name = fileName + ".smil";
File txt = new File(source + name);
txt.createNewFile();
Writer writer = new OutputStreamWriter(new FileOutputStream(txt), "UTF-8");
writer.write(toStringHexTest(data.toUpperCase()));
writer.close();
}
}
for (Iterator i = content.elementIterator("SubContent"); i.hasNext();)
{
foo = (Element) i.next();
String type = foo.elementText("ContentType");
String name = foo.elementText("ContentID");
String data = foo.elementText("Data");
File txt = new File(source + name);
txt.createNewFile();
if ("text/plain".equalsIgnoreCase(type))
{
Filefo = new FileOutputStream(txt);
Filefo.write(data.getBytes("UTF-8"));
}
else
{
byte[] bb = toByteArr(data);
Filefo = new FileOutputStream(txt);
Filefo.write(bb);
}
}
// f.delete();
// forceDelDir(new File(source));
}
catch (Exception e)
{
throw new Exception("彩信文件解析失败!文件地址:" + source + fileName + "-->"
+ e.getMessage());
}
finally
{
try
{
if (Filefo != null)
{
Filefo.close();
}
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
解析.mms文件内容
最新推荐文章于 2022-06-09 10:44:47 发布