asp.net core api 等调用webservice以及 处理返回值踩坑之路

首先添加引用然他自动生成文件

image.png

点击go services 填写如http://192.168.1.5/Service1.asmx 里面会加载出来记住名字 如Service1Soap
image.png

将自动生成
image.png

下一步 默认 ,完成
然后定位项目文件夹
image.png

查看命名空间 并引用


image.png
image.png
       //创建 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(binding, endpoint);
            //从工厂获取具体的调用实例
            var callClient = factory.CreateChannel();
            /*          //调用具体的方法,这里是 HelloWorldAsync 方法
                      Task responseTask = callClient.HelloWorldAsync(new HelloWorldRequest());
                      //获取结果
                      HelloWorldResponse response = responseTask.Result;
                      // 获取HelloWorld方法的返回值
                      string result1 = response.Body.HelloWorldResult;*/

            // 调用TestMethod方法,不传递参数
            string userid = "";
            Task 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

image.png

刚开始采用如下方法

   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大概数据集如下:

  
    
                不告诉你
    

    
        你号aaaa
    

当然我认为还有一个思路就是直接研究System.XML.element 类的用法直接递归
System.XML.element本身也属于 XmlNode
每个xmlnode都包好childNodes 也就是XmlNodeList 可以直接用下标访问

image.png
     List values = new List();
                    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
文档如下

image.png

那么应该是这样的访问
http://192.168.1.1/A.asmx/CheckUser?sUser=1&sPwd=1&ssuserid=1&ssAllow=0

关于xml返回的 文档 可以看到相关定义,这里方别为请求 和返回。


image.png

可以看到 为xmlxml。

最后还有一种方式最麻烦的调用,就是安卓这边要调用 则找到soap 插件库,调用这么个落后的东西搞那么多麻烦事情。

https://blog.csdn.net/lyq8479/article/details/6428288?spm=1001.2101.3001.6650.2&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-2-6428288-blog-76473231.pc_relevant_vip_default&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-2-6428288-blog-76473231.pc_relevant_vip_default&utm_relevant_index=3

https://blog.csdn.net/yegshun/article/details/81278976?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-1-81278976-blog-6428288.pc_relevant_vip_default&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7ERate-1-81278976-blog-6428288.pc_relevant_vip_default&utm_relevant_index=1

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/函数名
参数就是正常的表单传递了

你可能感兴趣的:(asp.net core api 等调用webservice以及 处理返回值踩坑之路)