Как заставить javax xslt преобразователь кодировать национальные символы, используя utf-8, а не html-сущности? - PullRequest
0 голосов
/ 12 июня 2010

Я работаю над фильтром, который должен преобразовывать вывод с помощью некоторой таблицы стилей.Важные разделы кода выглядят так:

PrintWriter out = response.getWriter();
...
StringReader sr = new StringReader(content);
Source xmlSource = new StreamSource(sr, requestSystemId);
transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
transformer.setParameter("encoding", "UTF-8");
//same result when using ByteArrayOutputStream xo = new java.io.ByteArrayOutputStream();
StringWriter xo = new StringWriter();
StreamResult result = new StreamResult(xo);
transformer.transform(xmlSource, result);
out.write(xo.toString());

Проблема заключается в том, что национальные символы кодируются как HTML-объекты, а не с использованием UTF.Есть ли способ заставить трансформатор использовать UTF-8 вместо сущностей?

1 Ответ

1 голос
/ 12 июня 2010

Вам необходимо установить метод вывода на text вместо (по умолчанию) xml.

transformer.setOutputProperty(OutputKeys.METHOD, "text");

Однако вы должны также заранее задать кодировку ответа:

response.setCharacterEncoding("UTF-8");

И дать указание веб-браузеру использовать ту же кодировку:

response.setContentType("text/html;charset=UTF-8");
...