导航:首页 > 净水问答 > javaxml过滤字符

javaxml过滤字符

发布时间:2021-12-24 01:04:09

㈠ JAVA 如何获取并替换XML格式的字符串

  1. 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进行编码转换。

阅读全文

与javaxml过滤字符相关的资料

热点内容
敦煌污水处理厂 浏览:609
反渗透膜用胶带 浏览:336
长安逸动机油滤芯型号和什么车通用 浏览:842
常减压蒸馏装置由哪几部分组成 浏览:722
益方泉净水机多少钱一台 浏览:817
污水直排的情况进行全面整治 浏览:182
顺达货车空调滤芯在哪里 浏览:129
城市污水处理厂污泥氰化物 浏览:545
污水流入消费者的主要形式 浏览:659
净水器反渗透上型号怎么看 浏览:866
粉末活性炭废水 浏览:779
反渗透膜ge 浏览:594
企业污水排污费计算公式 浏览:507
立升净水机哪个型号好 浏览:488
适合做反渗透膜的聚砜 浏览:536
纯水机买多少加仑的 浏览:550
雪佛兰乐风滤芯是什么规格 浏览:76
热水器排污水的钟有什么作用 浏览:449
硬挺树脂厂家 浏览:83
智能马桶滤芯怎么看是否换 浏览:208