㈠ JAVA 如何获取并替换XML格式的字符串
xml文件:
<?xml version="1.0" encoding="UTF-8"?>
<transaction>
<body>
<request>
<tranTyp>批量业务现存</tranTyp>
<acctNm>0085213560</acctNm>
<acctNo>6225885517843413</acctNo>
<avlBal>201958.65</avlBal>
<acctTyp>0</acctTyp>
<tranTime>20170801101030</tranTime>
<currencyTyp>CNY</currencyTyp>
<tranDesc></tranDesc>
<bal>201958.65</bal>
<tranAmt>100000.00</tranAmt>
</request>
</body>
<header>
<msg>
<sndTm>101019</sndTm>
<msgCd>WCS0000200</msgCd>
<seqNb>632376531000009</seqNb>
<sndMbrCd>5200</sndMbrCd>
<rcvMbrCd>0000</rcvMbrCd>
<sndDt>20170821</sndDt>
<sndAppCd>CBS</sndAppCd>
<rcvAppCd>WCS</rcvAppCd>
<callTyp>SYN</callTyp>
</msg>
<ver>1.0</ver>
<pnt>
<sndTm>101216</sndTm>
<sndMbrCd>0000</sndMbrCd>
<rcvMbrCd>0000</rcvMbrCd>
<sndDt>20170809</sndDt>
<sndAppCd>ESB</sndAppCd>
<rcvAppCd>WCS</rcvAppCd>
</pnt>
</header>
</transaction>
2. java实现实例:
public class Test {
/**
*
* @param document
* Document对象(读xml生成的)
* @return String字符串
* @throws Throwable
*/
public String xmlToString(Document document) throws Throwable {
TransformerFactory ft = TransformerFactory.newInstance();
Transformer ff = ft.newTransformer();
ff.setOutputProperty("encoding", "GB2312");
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ff.transform(new DOMSource(document), new StreamResult(bos));
return bos.toString();
}
/**
*
* @param xml形状的str串
* @return Document 对象
*/
public Document StringTOXml(String str) {
StringBuilder sXML = new StringBuilder();
sXML.append(str);
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
Document doc = null;
try {
InputStream is = new ByteArrayInputStream(sXML.toString().getBytes("utf-8"));
doc = dbf.newDocumentBuilder().parse(is);
is.close();
} catch (Exception e) {
e.printStackTrace();
}
return doc;
}
/**
*
* @param document
* @return 某个节点的值 前提是需要知道xml格式,知道需要取的节点相对根节点所在位置
*/
public String getNodeValue(Document document, String nodePaht) {
XPathFactory xpfactory = XPathFactory.newInstance();
XPath path = xpfactory.newXPath();
String servInitrBrch = "";
try {
servInitrBrch = path.evaluate(nodePaht, document);
} catch (XPathExpressionException e) {
e.printStackTrace();
}
return servInitrBrch;
}
/**
*
* @param document
* @param nodePath
* 需要修改的节点相对根节点所在位置
* @param vodeValue
* 替换的值
*/
public void setNodeValue(Document document, String nodePath, String vodeValue) {
XPathFactory xpfactory = XPathFactory.newInstance();
XPath path = xpfactory.newXPath();
Node node = null;
;
try {
node = (Node) path.evaluate(nodePath, document, XPathConstants.NODE);
} catch (XPathExpressionException e) {
e.printStackTrace();
}
node.setTextContent(vodeValue);
}
3. 测试
public static void main(String[] args) throws Throwable {
// 读取xml文件,生成document对象
DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
// 文件的位置在工作空间的根目录(位置随意,只要写对就ok)
Document document = builder.parse(new File("a.xml"));
Test t = new Test();
// XML————》String
String str = t.xmlToString(document);
System.out.println("str:" + str);
// String ————》XML
Document doc = t.StringTOXml(str);
String nodePath = "/transaction/header/msg/sndMbrCd";
// getNodeValue
String nodeValue = t.getNodeValue(doc, nodePath);
System.out.println("修改前nodeValue:" + nodeValue);
// setNodeValue
t.setNodeValue(doc, nodePath, nodeValue + "hello");
System.out.println("修改后nodeValue:" + t.getNodeValue(doc, nodePath));
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
测试结果:
str:<?xml version="1.0" encoding="UTF-8" standalone="no"?><transaction>
<body>
<request>
<tranTyp>批量业务现存</tranTyp>
<acctNm>0085213560</acctNm>
<acctNo>6225885517843413</acctNo>
<avlBal>201958.65</avlBal>
<acctTyp>0</acctTyp>
<tranTime>20170801101030</tranTime>
<currencyTyp>CNY</currencyTyp>
<tranDesc/>
<bal>201958.65</bal>
<tranAmt>100000.00</tranAmt>
</request>
</body>
<header>
<msg>
<sndTm>101019</sndTm>
<msgCd>WCS0000200</msgCd>
<seqNb>632376531000009</seqNb>
<sndMbrCd>5200</sndMbrCd>
<rcvMbrCd>0000</rcvMbrCd>
<sndDt>20170821</sndDt>
<sndAppCd>CBS</sndAppCd>
<rcvAppCd>WCS</rcvAppCd>
<callTyp>SYN</callTyp>
</msg>
<ver>1.0</ver>
<pnt>
<sndTm>101216</sndTm>
<sndMbrCd>0000</sndMbrCd>
<rcvMbrCd>0000</rcvMbrCd>
<sndDt>20170809</sndDt>
<sndAppCd>ESB</sndAppCd>
<rcvAppCd>WCS</rcvAppCd>
</pnt>
</header>
</transaction>
结果显示
修改前nodeValue:5200
修改后nodeValue:5200hello
㈡ java过滤非法字符的filter
filter代码在pujia12345提供的代码上改的;
jsp页面的编码你设成你自己的,我用的是-8。
input.jsp输入后,正常跳转到handle.jsp,而禁词已经被过滤。
filter:
package test;
import java.io.*;
import javax.servlet.*;
import java.util.*;
public class MyFilter implements Filter
{
private List<String> unString;
public void init(FilterConfig filterConfig) throws ServletException
{
unString = new ArrayList<String>();
unString.add("日");
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException
{
String content = request.getParameter("content");//需要过滤的参数
if(content!=null){
for (int i = 0; i < unString.size(); i++)
{
String strIllegal = unString.get(i);
if (content.indexOf(strIllegal) >= 0)
{
content = content.replaceAll(strIllegal, "");//非法字符替换成空
}
request.setAttribute("content", content);//为request设置属性保存修改后的值
}
}
chain.doFilter(request, response);
}
public void destroy()
{
//System.out.println("过滤器销毁");
}
}
//---------------------------//
web.xml:
<filter>
<filter-name>myfilter</filter-name>
<filter-class>test.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>myfilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
//---------------------------//
输入页面input.jsp:
<%@page contentType="text/html;charset=utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>input.jsp</title>
</head>
<body>
<form action="handle.jsp" method="post">
<input type="text" name="content" />
<input type="submit" value=" 提交 " />
</form>
</body>
</html>
//---------------------------//
input提交的页面handle.jsp:
<%@page contentType="text/html;charset=utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title> handle.jsp </title>
</head>
<body>
<%
String content = (String)request.getAttribute("content");
out.println(content);
%>
</body>
</html>
㈢ java分割xml类型的字符串
public static void main(String[] args) {
String xml="<response>" +
"<head>" +
"<code>0</code>" +
"<message></message>" +
"</head>" +
"<body>" +
"<test>" +
"<no>1</no>" +
"<addr>123</addr>" +
"</test>" +
"<test>" +
"<no>2</no>" +
"<addr>124</addr>" +
"</test>" +
"</body>" +
"</response>";
try {
Document document = DocumentHelper.parseText(xml);
Element root = document.getRootElement();
List<Element> dataList = root
.selectNodes("//body/test");
for (Element e2 : dataList) {
String no=e2.elementText("no");
String addr=e2.elementText("addr");
System.out.println(no+" "+addr);
}
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
需要这个dom4j-1.6.1.jar
㈣ java 去除xml字符串里有null的节点 求大神
publicclassRemoveNullElement{
publicstaticvoidmain(String[]args){
Stringxml="<?xmlversion="1.0"encoding="UTF-8"standalone="yes"?><A><id>null</id><name>李三</name><id><id>null</id><name>李三</name><id>null</id></id></A>";
try{
Documentdoc=DocumentHelper.parseText(xml);
newRemoveNullElement().removeNullElement(doc.getRootElement(),doc.getRootElement());
System.out.println(doc.asXML());
}catch(DocumentExceptione){
System.out.println("parsexmlfailed!"+e);
e.printStackTrace();
}
}
privatevoidremoveNullElement(Elementele,Elementparent){
if(ele==null){
return;
}
if(ele.getText()!=null&&ele.getText().equalsIgnoreCase("null")){
parent.remove(ele);
}else{
List<Element>children=ele.elements();
if(children!=null&&children.size()>0){
for(Elementchild:children){
removeNullElement(child,ele);
}
}
}
}
}
写了个删除null节点的方法,递归调用。
㈤ java 截取 xml(字符串)的子节点
你好,直接indexOf <task> 跟 </task> 然后subString一下都没问题.
或者正则表达式
<task>(.*?)</task>
如果是一个长期的工程,量比较大的,考虑用dom4j来做吧.
http://xhy0422.iteye.com/blog/50235
对于已经是字符串的xml,可以
㈥ XML 解析中,如何排除控制字符
package com.huayu;
import Java.io.*;
import javax.xml.parsers.*;
import org.w3c.dom.*;
public class Test3 {
public static void main(String []args){
try {
//1.创建一个工厂
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
//2.得到解析器
DocumentBuilder db=dbf.newDocumentBuilder();
//3.//字符串
String strTest="<?xml version=/"1.0/" encoding=/"gb2312/"?>"
+"<company>"
+"<person sex=/"male/">"
+"<name>小三子</name>"
+"<email>[email protected]</email>"
+"</person>"
+"<person sex=/"male/">"
+"<name>小三子</name>"
+"<email>[email protected]</email>"
+"</person>"
+"<person sex=/"male/">"
+"<name>小三子</name>"
+"<email>[email protected]</email>"
+"</person>"
+"</company>";
//在编程中,字符串从网络传递
InputStream is=new ByteArrayInputStream(strTest.getBytes());
Document dm=db.parse(is);
NodeList nl=dm.getElementsByTagName("person");
//5.改进将 Node 换成 Element (Element提供了更加丰富的方法,解决不能指定得到某个子节点的问题)
//得到第一个人的信息
Element el=(Element)nl.item(0);
//指定得到某个子节点
NodeList nll=el.getElementsByTagName("email");
//打印name值,这是固定的取法
String name=((Element)nll.item(0)).getFirstChild().getNodeValue();
System.out.println("email="+name);
} catch (Exception e) {
e.printStackTrace();
// TODO: handle exception
}
}
}
㈦ java截取XML字符串
indexOf("<")
indexOf(">")
subString
㈧ java解析第三方xml文件 文件中的特殊字符如何处理 文件不可改
一般的特殊字符都是需要转义的,请参阅xml特殊字符如何转义。
㈨ 在Java程序处理中,对于XML格式的字符串,碰到&,‘,“等字符,该如何处理
& 是用 & a m p ; 来代替
去掉空格……昨天写完忘记看被自己换成&了
引号不记得了
差不多的方法,自己查查吧
㈩ java过滤特殊字符的问题
"+"在URL中会被当作空格处理。
必须使用URLEncoder将其变成URL编码。
或者使用 javascript 的 encodeURIComponent(url) 函数对URL进行编码转换。