WebService,ASMX文件使用XML格式数据传递参数、验证与获取XML格式返回值的一种方式
1:首先WebService方法定义,每个方法定义两个参数,一个用于验证权限,string格式的XML文本用于传输数据。最终目的实现,WebService方法,验证权限,获取XML数据,处理之后返回XML数据。一下面一段代码为例进行说明:
[WebMethodAttribute(Description = "新增督学计划")]
public string InspectorPlan_Add(string Token, string XMLParas)
{ try
{
//安全凭证检查
if (!TokenAuth.Check(Token))
{
//为了测试方便先注释掉
//return this.GetResult(false, "安全凭证无效!", "");
}
Hashtable paras = GetParametersFromXML(XMLParas);
//检查参数是否存在
string msg = this.CheckParas("InspectorGuid,Year,Month,MainContent", paras);
if (msg != "")
{
return GetResult(false, msg, "", "InspectorPlan_Add", XMLParas);
}
string UserGuid = paras["InspectorGuid"].ToString(); //用户UserGuid
string Year = paras["Year"].ToString();//传过来的月份
string Month = paras["Month"].ToString();//传过来的月份
string MainContent = paras["MainContent"].ToString();//传过来的计划内容
//根据UserGuid获取用户所在部门名称,所在部门Guid,用户姓名
string UserInfoSql = "select a.userguid,a.displayname,b.ouguid,b.ouname from frame_user a join frame_ou b on a.ouguid = b.ouguid where a.userguid ='" + UserGuid + "'";
//查询该月督学计划是否存在,存在则不能重复插入
if (DB_XXTInspectorPlan.InspectorPlan_CheckExist(UserGuid, Year, Month))
{
//如果该月已经存在,则提示月度督学计划重复
return GetResult(false, "月度督学计划重复", "", "AddInspectorPlan", XMLParas);
}
else
{
DataView dv = Epoint.EduFront.Bizlogic.DB_Common.ExecuteToDataView(UserInfoSql); if (dv.Count > )
{
string RowGuid = DB_XXTInspectorPlan.InspectorPlan_Add(dv[]["UserGuid"].ToString(), dv[]["displayname"].ToString(), dv[]["ouguid"].ToString(), dv[]["ouname"].ToString(), MainContent, Year, Month);
//评价成功,返回评价的rowguid
return GetResult(true, "添加成功", "<RowGuid>" + RowGuid + "</RowGuid>", "AddInspectorPlan", XMLParas);
}
else
{
return GetResult(false, "", "<RowGuid>添加失败</RowGuid>", "ParEvaSchInsert", XMLParas);
}
}
}
catch (Exception ex)
{
ErrorLog("AddInspectorPlan", XMLParas, ex.Message);
return GetResult(false, ex.Message, "", "AddInspectorPlan", XMLParas);
}
}
2:Token参数用于验证权限,XMLParas用于传递string格式的XML数据
此方法需要传递的参数如下:
<?xml version="1.0" encoding="gb2312" ?> <paras> <InspectorGuid>当前用户UserGuid</InspectorGuid> <Year>年份,1000至9999字符串。(☆注意必须是四位)</Year> <Month>月份,01至12字符串。(☆注意必须是两位)</Month> <MainContent>督学计划内容</MainContent> </paras>
3:循环解析每个节点获取对应的参数值,Hashtable paras = GetParametersFromXML(XMLParas);该语句调用解析XML字符串并转化参数到HashTable中
GetParametersFromXML方法如下:
Hashtable paras = GetParametersFromXML(XMLParas);
public Hashtable GetParametersFromXML(string XMLParameters)
{
XmlDocument xml = new XmlDocument();
xml.LoadXml(XMLParameters);
XmlNode DataNode = xml.SelectSingleNode("paras"); Hashtable Parameters = new Hashtable();
foreach (XmlNode node in DataNode.ChildNodes)
{
Parameters.Add(node.Name, node.InnerText);
}
return Parameters;
}
4:检查必填参数是否存在,并对缺少的参数给出提示。checkParas方法,用于检测每个参数。实现代码如下:
//检查参数是否存在,第一个值为必填参数节点名称,每个参数用","隔开
string msg = this.CheckParas("InspectorGuid,Year,Month,MainContent", paras);
/// <summary>
/// 检查是否缺少参数必填参数
/// </summary>
/// <param name="Parastr">参数名称,多个参数用逗号隔开</param>
/// <param name="Paras">获取到参数Hastable</param>
/// <returns></returns>
public string CheckParas(string Parastr, Hashtable Paras)
{
string[] listParas = Parastr.Split(',');
string Error = "";
for (int i = ; i < listParas.Length; i++)
{
if (listParas[i] != "")
{
if (!Paras.ContainsKey(listParas[i]))
{
Error += listParas[i] + ",";
}
}
} if (Error != "")
{
return "缺少参数:" + Error.TrimEnd(',');
}
else
{
return "";
} }
5:确认必填参数存在后获取对应的参数值,进行操作,每个XML参数的节点名称作为hashtable的name,每个节点的值作为nodevalue,根据nodename获取参数值代码
string UserGuid = paras["InspectorGuid"].ToString(); //用户UserGuid
string Year = paras["Year"].ToString();//传过来的月份
string Month = paras["Month"].ToString();//传过来的月份
string MainContent = paras["MainContent"].ToString();//传过来的计划内容
6:参数的返回,对获取的数据处理后,把需要返回的数据用拼接为XML格式的字符串返回。
string UserInfoSql = "select a.userguid,a.displayname,b.ouguid,b.ouname from frame_user a join frame_ou b on a.ouguid = b.ouguid where a.userguid ='" + UserGuid + "'";
//查询该月督学计划是否存在,存在则不能重复插入
if (DB_XXTInspectorPlan.InspectorPlan_CheckExist(UserGuid, Year, Month))
{
//如果该月已经存在,则提示月度督学计划重复
return GetResult(false, "月度督学计划重复", "", "AddInspectorPlan", XMLParas);
}
else
{
DataView dv = Epoint.EduFront.Bizlogic.DB_Common.ExecuteToDataView(UserInfoSql); if (dv.Count > )
{
string RowGuid = DB_XXTInspectorPlan.InspectorPlan_Add(dv[]["UserGuid"].ToString(), dv[]["displayname"].ToString(), dv[]["ouguid"].ToString(), dv[]["ouname"].ToString(), MainContent, Year, Month);
//评价成功,返回评价的rowguid
return GetResult(true, "添加成功", "<RowGuid>" + RowGuid + "</RowGuid>", "AddInspectorPlan", XMLParas);
}
else
{
return GetResult(false, "", "<RowGuid>添加失败</RowGuid>", "ParEvaSchInsert", XMLParas);
}
}
public string GetResult(bool status, string description, string UserData, string MethodName, string XMLPars)
{
StringBuilder sb = new StringBuilder();
sb.Append("<?xml version=\"1.0\" encoding=\"gb2312\"?>");
sb.Append("<EpointDataBody>");
sb.Append("<DATA>");
sb.Append("<ReturnInfo>");
sb.Append("<Status>" + status.ToString() + "</Status>");
sb.Append("<Description><![CDATA[" + description + "]]></Description>");
sb.Append("</ReturnInfo>");
if (status && UserData != "")
{
sb.Append("<UserArea>" + UserData + "</UserArea>");
}
sb.Append("</DATA>");
sb.Append("</EpointDataBody>"); //保存接口调用日志
//string ClientIP = Context.Request.ServerVariables.GetValues("REMOTE_ADDR")[0];
//DB_XXTWebServiceLog.InsertLog(ClientIP, MethodName, System.Text.Encoding.Default.GetBytes(XMLPars), System.Text.Encoding.Default.GetBytes(sb.ToString()), status ? "1" : "0", description); return sb.ToString();
}
7:最终实现返回的XML格式文本如下:
新增成功时返回插入行的RowGuid
<?xml version="1.0" encoding="gb2312"?>
<EpointDataBody>
<DATA><ReturnInfo><Status>True</Status><Description>
<![CDATA[插入成功]]>
</Description></ReturnInfo><UserArea>
<RowGuid>42ccaec8---a653-ecbb4328428c</RowGuid>
</UserArea>
</DATA>
</EpointDataBody>
一个月份重复插入时返回:
<EpointDataBody><DATA>
<ReturnInfo><Status>False</Status>
<Description><![CDATA[月度计划重复]]>
</Description></ReturnInfo></DATA>
</EpointDataBody>
8:最后的也是最重要的一步形成文档,以方便调用此方法的人进行开发。
|
服务名称 |
InspectorPlan_Add |
|||
|
服务说明 |
插入用户所填写的督学计划信息 |
|||
|
输入值 |
<?xml version="1.0" encoding="gb2312" ?> <paras> <InspectorGuid>当前用户UserGuid</InspectorGuid> <Year>年份,1000至9999字符串。(☆注意必须是四位)</Year> <Month>月份,01至12字符串。(☆注意必须是两位)</Month> <MainContent>督学计划内容</MainContent> </paras> |
|||
|
输入参数详细 |
参数名称 |
参数说明 |
类型 |
是否必填 |
|
UserGuid |
当前用户UserGuid |
字符型 |
是 |
|
|
Year |
所选择年份Year |
字符型 |
是 |
|
|
Month |
月份,01至12字符串 |
字符型 |
是 |
|
|
MainContent |
计划内容 |
字符型 |
是 |
|
|
返回值 |
新增成功时返回插入行的RowGuid <?xml version="1.0" encoding="gb2312"?> <EpointDataBody> <DATA><ReturnInfo><Status>True</Status><Description> <![CDATA[插入成功]]> </Description></ReturnInfo><UserArea> <RowGuid>42ccaec8-9091-4950-a653-ecbb4328428c</RowGuid> </UserArea> </DATA> </EpointDataBody> 一个月份重复插入时返回: <EpointDataBody><DATA> <ReturnInfo><Status>False</Status> <Description><![CDATA[月度计划重复]]> </Description></ReturnInfo></DATA> </EpointDataBody> |
|||
9:浏览器中测试的结果


WebService,ASMX文件使用XML格式数据传递参数、验证与获取XML格式返回值的一种方式的更多相关文章
- php 如何利用 soap调用.Net的WebService asmx文件
原文:php 如何利用 soap调用.Net的WebService asmx文件 最近,帮一个同行测试用.net写的WebService接口,C#调用通过,现在需要测试一下php版本对它的调用,经过各 ...
- ASP.NET页面之间传递值的几种方式(转载)
页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryString,Session,Cookie ...
- ASP中页面之间传递值的几种方式
ASP.NET页面之间传递值的几种方式 页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有QueryS ...
- 【mybatis xml】数据层框架应用--Mybatis 基于XML映射文件实现数据的CRUD
使用MyBatis框架进行持久层开发 MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架. MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索. MyBa ...
- WebService 实现BS环境与BS环境传递参数,根据参数生成txt文档
客户端: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Client.as ...
- linux使用curl上传文件并且同时携带其它传递参数
一般使用linux原生态的命令curl上传文件时命令如下 假如要上传文件是myfile.txt curl -F "file_name=@myfile.txt" -X POST &q ...
- 嵌入式开发之davinci--- 8148/8168/8127 中的图像采集格式Sensor信号输出YUV、RGB、RAW DATA、JPEG 4种方式区别
简单来说,YUV: luma (Y) + chroma (UV) 格式, 一般情况下sensor支持YUV422格式,即数据格式是按Y-U-Y-V次序输出的RGB: 传统的红绿蓝格式,比如RGB565 ...
- 关于form表单提交数据后不跳转页面+ajax接收返回值的处理
1.前台的form表单建立,注意action.enctype的内容, 2.通过添加一个隐藏的iframe标签使form的target指向iframe来达到不跳转页面的效果,同时需要在js里获取ifra ...
- ASP.NET页面之间传递值的几种方式
目录 QueryString Session Cookie Application 一.QueryString QueryString是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中. ...
随机推荐
- 阿里云ros实例
模板文件 { "ROSTemplateFormatVersion": "2015-09-01", "Parameters": { " ...
- 多并发编程基础 之线程程 Thried
原贴 https://www.cnblogs.com/gbq-dog/p/10365669.html 今日要整理的内容有 1. 操作系统中线程理论 2.python中的GIL锁 3.线程在python ...
- win7 wifi sharing
1.启用并设定虚拟WiFi网卡: netsh wlan set hostednetwork mode=allow ssid=mywifi key=12345678 此命令有三个参数,mode:是否启用 ...
- 第十篇----------javascript函数的三种定义方式及区别
javascript定义函数有3种方式: //3种函数定义方式,前两种常用 /** * 1,function 语句式 * 形式:句子 * 名称:有名 * 性质:静态 * 解析时机:优先解析 * 作用域 ...
- Hibernate3.3.2_ID生成策略
1,xml生成id generator:常用四个:native.identity.sequence.uuid. Annotation: 1,@GeneratedValue: a)自定义ID b)AUT ...
- ubuntu 16.04通过源码方式安装nginx
1.下载nginx源码包 wget http://nginx.org/download/nginx-1.11.12.tar.gz 2.解压该tar包 tar zxvf nginx-1.11.12.t ...
- IPC之AIDL&binder关系
binder是一个远程对象的基础类,核心部分是远程调用机制,这部分是由IBinder定义的.它是对IBinder类的实现,其中IBinder类提供这样一个类的标准的本地化实现方式. 大多数开发者不会去 ...
- Android四种跨进程通信
由于android系统中应用程序之间不能共享内存.因此,在不同应用程序之间交互数据(跨进程通讯)就稍微麻烦一些.在android SDK中提供了4种用于跨进程通讯的方式.这4种方式正好对应于andro ...
- Determining IP information for eth0...failed
事故现场 eth0 Link encap:Ethernet HWaddr :0C::B6:D2:5A inet6 addr: fe80::20c:29ff:feb6:d25a/ Scope:Link ...
- 用table布局和div布局的区别
table布局的渲染是将整个table全部渲染出来,如果网路不给力的情况下,整个table会卡死在页面div布局的话,页面渲染,会一个一个的div渲染,网页出现会一个一个出来,不管网速怎样,不会全局卡 ...