1.写入xml(用户填写留言)
复制代码
```csharp
public void WriteXml()
{
//创建一个数据集,将其写入xml文件
string optime = DateTime.Now.ToString("yyyyMMddHHmmss") + ".xml";
System.Data.DataSet ds = new System.Data.DataSet("MESSAGE");
System.Data.DataTable table = new System.Data.DataTable("FeedBack");
ds.Tables.Add(table);
table.Columns.Add("ID", typeof(string));
table.Columns.Add("email", typeof(string));
table.Columns.Add("telephone", typeof(string));
table.Columns.Add("problem", typeof(string));
System.Data.DataRow row = table.NewRow();
row[0] = DateTime.Now.ToString("yyyyMMddHHmmss");
row[1] = this.txtEmail.Text;
row[2] = this.txtMobile.Text;
row[3] = this.txtBody.Text;
ds.Tables["FeedBack"].Rows.Add(row);
string path = Server.MapPath("~/feedback/" + optime);
ds.WriteXml(path);
}
写入后xml结果:
复制代码
```csharp
<MESSAGE>
<FeedBack>
<ID>20130612105102</ID>
<email>21703@qq.com</email>
<telephone>435435</telephone>
<problem>EWWREEWREW</problem>
</FeedBack>
</MESSAGE>
复制代码
2.另一种写入方法
复制代码
public void WriteXml()
{
string path = Server.MapPath("~/feedback/" + "test1.xml");//创建或者覆盖文件
XmlTextWriter xml = new XmlTextWriter(path, Encoding.UTF8);
xml.Formatting = Formatting.Indented;
xml.WriteStartDocument();
xml.WriteStartElement("MESSAGE");
xml.WriteStartElement("feedback");
xml.WriteStartElement("邮箱");
xml.WriteCData("qwert@163.com");
xml.WriteEndElement();
xml.WriteStartElement("电话");
xml.WriteCData("134000000");
xml.WriteEndElement();
xml.WriteEndElement();
xml.WriteEndElement();
xml.WriteEndDocument();
xml.Flush();
xml.Close();
}
复制代码
结果如下:
复制代码
<?xml version="1.0" encoding="utf-8"?>
<MESSAGE>
<feedback>
<邮箱><![CDATA[qwert@163.com]]></邮箱>
<电话><![CDATA[134000000]]></电话>
</feedback>
</MESSAGE>
复制代码
两种写入方法的结果不一样,区别在于CDATA,主要是因为文本内容有可能包含“非法”字符,加入CDATA标记后,在CDATA标记中的信息被解析器原封不动地传给应用程序,并且不解析该段信息中的任何控制标记。
3.xml读取
方法1
//将xml文件的数据放到数据集里,再将数据集绑定到所需的控件即可
System.Data.DataSet ds = new System.Data.DataSet();
ds.ReadXml(Server.MapPath("~/feedback/" + "answer.xml"));
方法2
XmlReader _axisXmlReader = XmlReader.Create($"{SysPath}");
string name = "目标名字";
string ObjValue = "目标值";
while (_axisXmlReader.Read())
{
if ((_axisXmlReader.NodeType == XmlNodeType.Element) && (_axisXmlReader.Name == name))
{
ObjValue = _axisXmlReader.ReadElementContentAsString();
break;
}
}