首先添加引用然他自动生成文件
点击go services 填写如http://192.168.1.5/Service1.asmx 里面会加载出来记住名字 如Service1Soap
将自动生成
下一步 默认 ,完成
然后定位项目文件夹
查看命名空间 并引用
//创建 HTTP 绑定对象
var binding = new BasicHttpBinding();
//根据 WebService 的 URL 构建终端点对象,参数是提供的WebService地址
var endpoint = new EndpointAddress(@"http://192.168.1.5/Service1.asmx");
//创建调用接口的工厂,注意这里泛型只能传入接口 泛型接口里面的参数是WebService里面定义的类名+Soap
var factory = new ChannelFactory<Service1Soap>(binding, endpoint);
//从工厂获取具体的调用实例
var callClient = factory.CreateChannel();
/* //调用具体的方法,这里是 HelloWorldAsync 方法
Task<HelloWorldResponse> responseTask = callClient.HelloWorldAsync(new HelloWorldRequest());
//获取结果
HelloWorldResponse response = responseTask.Result;
// 获取HelloWorld方法的返回值
string result1 = response.Body.HelloWorldResult;*/
// 调用TestMethod方法,不传递参数
string userid = "";
Task<CheckUserResponse> testResponse = callClient.callAsync(new CheckUserRequest(username, password, userid, 0));
假如返回datatable ,但是实际上是System.Xml.Element
https://docs.microsoft.com/zh-cn/dotnet/api/system.xml.xmlelement?view=net-6.0
思路:成员对象的innerXml
刚开始采用如下方法
System.Data.DataTable dataTable = new System.Data.DataTable();
StringReader sr = new StringReader(str2);
、// dataTable.ReadXmlSchema("");//此方法需要readXmlSchema
dataTable.ReadXml(sr);*
提示错误 System.InvalidOperationException:“DataTable does not support schema inference from Xml.”
解决方法是需要填写写入 xmlschema,但是这个东西没有schema样板。
改成如下即可
System.Data.DataSet dsData = new System.Data.DataSet();
dsData.ReadXml(new System.Xml.XmlTextReader(new StringReader(str2)));
System.Data.DataTable dt = dsData.Tables["DT_Webservice"];//HH
System.IO.FileStream stream =
new System.IO.FileStream($@"{directory}\Schema.txt", System.IO.FileMode.Create);
dt.WriteXmlSchema(stream);
foreach (System.Data.DataRow dr in dt.Rows)
{
foreach (System.Data.DataColumn dc in dr.Table.Columns)
{
string n = dc.ColumnName;
string value = dr[n].ToString();
Console.WriteLine("test:" + value + "," + n);
}
}
完美
其中DT_Webservice 是根据 innerxml里面的节点得知,
innerxml大概数据集如下:
<DocumentElement
xmlns="">
<DT_Webservice diffgr:id="DT_Webservice1" msdata:rowOrder="0"
xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"
xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<app_desc>不告诉你</app_desc>
</DT_Webservice>
<DT_Webservice diffgr:id="DT_Webservice34" msdata:rowOrder="33"
xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"
xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<app_desc>你号aaaa</app_desc>
</DT_Webservice>
</DocumentElement>
当然我认为还有一个思路就是直接研究System.XML.element
类的用法直接递归
System.XML.element本身也属于 XmlNode
每个xmlnode都包好childNodes 也就是XmlNodeList 可以直接用下标访问
List<String> values = new List<string>();
XmlNodeList? list = a.Result.Any1?.SelectNodes("//app_desc")??null;
foreach (XmlNode current in list)
{
String currentText=current.InnerText;
}}
关于 selectNodes语法参考
注意这里AddNamespace方法的前面一个参数用于标记这个命名空间,在下面SelectNodes方法中加上对应的标记。给出的这一段是为了查找数据库连接字符串的节点。顺便附带扯下SelectNodes中XPath的语法:
SelectNodes("node") 从当前子节点中查找节点
SelectNodes("/node") 从根节点的子节点中查找节点
SelectNodes("//node") 从任意位置上查找名为node的节点
SelectNodes(".") 选择当前节点
SelectNodes("..") 选择当前节点父节点
SelectNodes("//node[1]") 选择名为node的第一个节点,注意这里是从1开始,不是从0开始
SelectNodes("/@name") 选择有name属性的节点
SelectNodes("/node[position() < 3]") 选择名为node的前两个节点
SelectNodes("//node[@name]") 选择node节点,并且该节点有name属性
SelectNodes("//node[@name='limit']") 选择node节点,并且该节点有name属性,而且name属性值为limit
SelectNodes("//node[contains(item)]") 选择node节点,该节点存在名字item的子节点,注意,如果有命名空间,这里要加命名空间,XX:item
SelectNodes("//node[contains(item,‘Hello World’)]") 选择node节点,该节点存在名字item的子节点,并且item节点内容为Hello World
https://blog.csdn.net/Austin_link/article/details/45246055
除此之外 ,调用webservice采用http访问
假设为
WebService 引用这个http://192.1.1/A.asmx
方法名为checkUser
文档如下
那么应该是这样的访问
http://192.168.1.1/A.asmx/CheckUser?sUser=1&sPwd=1&ssuserid=1&ssAllow=0
关于xml返回的 文档 可以看到相关定义,这里方别为请求 和返回。
可以看到 为xmlxml。
最后还有一种方式最麻烦的调用,就是安卓这边要调用 则找到soap 插件库,调用这么个落后的东西搞那么多麻烦事情。
2023-3-17 10:18:06
发现asmx里面有直接测试的,抓包后用sh调用
curl -H 'Host: 127.0.0.1:8088' -H 'Cache-Control: max-age=0' -H 'Upgrade-Insecure-Requests: 1' -H 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36' -H 'Origin: 127.0.0.1:8088' -H 'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9' -H 'Referer: 127.0.0.1:8088/WebService1.asmx?op=SqlSP_YTL_GetMinPackMtNoData' -H 'Accept-Language: zh-CN,zh;q=0.9' --data "param=11111111111111111" --compressed 'http://127.0.0.1:8088/WebService1.asmx/FunctionName'
其中param是参数1
FunctionName是参数名
get访问
```http://127.0.0.1:8088/WebService1.asmx?op=函数名``
可以直接进入测试页,实际上 里面的测试 上面的是post请求
也就是说post,get都可以访问
get是
http://127.0.0.1:8088/WebService1.asmx/函数名?参数名=参数值
而post是
http://127.0.0.1:8088/WebService1.asmx/函数名
参数就是正常的表单传递了