c#后台调用API
前两周赶上项目第一个版本上线,着实忙了一把,毕竟只有两个人负责。如今已完结,总算喘了一口气,现在任务就是写API、测API,许久之前写过JS前台调用 项目API,也写过后台调用开放的手机号归属地查询,这些仅仅是自己闲暇之余写的 最为简单的例子,算是过家家的级别吧,现在就项目各模块测试API时 注意的点和出现的问题进行记录。
套路就是
1.新建一个API 项目,引用web项目的dll
2.在API项目中 将要测试的方法全部写好(new对象,然后引用dll中方法)
3.再新建一测试项目,根据url 拼接参数(API不认参数名和Action名,只识别参数个数)
比如: 测试 web项目中的 A方法时
① API项目中
//调用A方法
public IList<Student> Get(string conn, string Id, string level)
{
StudentBIZ biz = new StudentBIZ(conn, Id,level);
return biz.A();
}
②APITest项目中
string url = "API网址" + "A方法控制器名";
string AllUrl = string.Format("{0}?conn={1}&Id={2}&level={3}", url, conn, Id, level);
var b = WebRequestHelper.GetData<Student>(AllUrl);
return View(b);
这里 WebRequestHelper 作为 APITest 调用WebAPI 方法的帮助类,针对需要的返回类型去编写对应的访问方法,一般都会有Post、Put、Get、Delete 等请求方式,网上也有很完善的Code,不想自己写,可以直接贴过来自己用。不够用的时候自己在写对应的访问方法,如:
private static string PostWebApi(string url)
{
var request = HttpWebRequest.Create(url) as HttpWebRequest;
request.Method = "Post";
request.ContentType = "application/json; charset=utf-8";
request.Timeout = ;
var app = request.Address.Segments[];
string result = "";
request.ContentLength = ;
// 取得回應資料
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
using (StreamReader sr = new StreamReader(response.GetResponseStream()))
{
result = sr.ReadToEnd();
}
}
return result;
}
红色部分是获取API项目中 对应方法的回调内容,如果你在API项目中对应的方法下打断点,调试到这里的时候就会跳转过去,有时候你想跑去DLL里面的方法中,只要将其web项目打开,不需要运行,直接在调的底层方法下打断点,程序即可跑进去。比如①中的 biz.A() 方法。
调试的时候有时候会抛出不少异常,最常见的就是 405方法不被允许;其实就是请求方式不对,put\post\get 等等的先屡清楚,然后就是发布服务器,很多时候,本地往往是正常的,一发布到服务器上就尴尬了,各种点击没有反应、或者404,一开始是比较头疼,后来做多了好耐晓得了一些套路,或者说是需要注意的点
1. 404的错误,找不到是资源,就是路径的问题,服务器上发布站点、应用程式的时候对路径的要求也不一样,在发布程式的时候,URL前面会带有一个本地文件夹的名字,这里一定好区分好
2. 点击按钮无响应, 这个肯定是程序出了问题,平时在本地写代码的时候,就随手返回一个bool值到前台,然后弹出成功/失败,但是部署到服务器上就不同了,一旦出了问题,也不能调试,只能靠猜。。。(笑),当然不是,主要方法下都会记录日志,看日志找错误。此外,对于网页的调试时,还可以新建一个实体类,写上bool、string 两个成员字段,返回前台的时候,直接返回此对象,string记录异常信息,正常则不记录,前天在解析此对象,弹出操作结果(若失败,则会提示失败原因)
c#后台调用API的更多相关文章
- ASP.NET后台调用API方法
/// <summary> /// 调用API POST请求与获取结果 /// </summary> ///URL 与 JSON串 public static string H ...
- atitit.js javascript 调用c# java php后台语言api html5交互的原理与总结p97
atitit.js javascript 调用c# java php后台语言api html5交互的原理与总结p97 1. 实现html5化界面的要解决的策略1 1.1. Js交互1 1.2. 动态参 ...
- 获取ip ,百度地图坐标点 和 在 后台调用 url()
protected void getip() { string ips = HttpContext.Current.Request.UserHostA ...
- 小白的springboot之路(十一)、构建后台RESTfull API
0.前言 开发系统中,前后端分离,后端一般返回RESTfull API,前端调用API构建UI,彼此分离.互相完全独立: 后台API中,我们一般返回结果码.提示信息.数据三部分内容,如图: 我们今天 ...
- Apsara Clouder专项技能认证:实现调用API接口
一.API 简介 1.API 的概念 API(Application Programming Interface应用程序编程接口)是一些预定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访 ...
- 由ASP.NET所谓前台调用后台、后台调用前台想到HTTP——实践篇(二)
在由ASP.NET所谓前台调用后台.后台调用前台想到HTTP——理论篇中描述了一下ASP.NET新手的三个问题及相关的HTTP协议内容,在由ASP.NET所谓前台调用后台.后台调用前台想到HTTP—— ...
- 由ASP.NET所谓前台调用后台、后台调用前台想到HTTP——理论篇
工作两年多了,我会经常尝试给公司小伙伴儿们解决一些问题,几个月下来我发现初入公司的小朋友最爱问的问题就三个 1. 我想前台调用后台的XXX方法怎么弄啊? 2. 我想后台调用前台的XXX JavaScr ...
- WebService – 3.后台调用WebService,根级别上的数据无效
1.因为我的webservice返回的是json, 2.ajax传递跨域不安全, 3.contentType: "application/json; charset=utf-8", ...
- C#中调用API
介绍 API( Application Programming Interface ),我想大家不会陌生,它是我们Windows编程的常客,虽然基于.Net平台的C#有了强大的类库,但是,我们还是不能 ...
随机推荐
- 工作整理: python报表系统常见错误整理
1.一般收不到邮件是因为配置文件邮箱写错 2.如果报表数据不对,看数据插入的时候是否再次写入产生冲突 3.如果收不到报表某些组别的excel查看组别名称是否匹配正确,是否匹配成功,不成功无法发送
- 关于java中,json字符串转集合和对象,或者集合转json字符串的解决方法
1 List集合转成json字符串 //Java集合 List<String> list = new ArrayList<String>(); list.add("a ...
- Nginx日常维护操作(3)
一.简明nginx常用命令 1. 启动 Nginx /sbin/nginx service nginx start 2. 停止 Nginx /sbin/nginx -s stop /sbi ...
- [翻译]QT core wallet manual 狗狗币核心钱包使用教程
译注:比特币没赶上可以玩狗狗币啊,水电厂包不起可以用CPU挖啊.为了顺应时代潮流,了解一下区(fa)块(heng)链(cai)和加密货币技术,准备从研究狗狗币开始.网上找了一圈没有看到很好的入门级教程 ...
- 开发高性能JAVA应用程序基础(内存篇)
虽然Java的垃圾回收和当前高配置的服务器可以让程序员大部分时间忘掉OutOfMemoryError的存在,但是访问量增大后频繁的GC会额外消耗CPU (使用top查看结果为us值高),系统响应速度下 ...
- Codefoces 723B Text Document Analysis
B. Text Document Analysis time limit per test:1 second memory limit per test:256 megabytes input:sta ...
- 微积分入门("SX"T版)
哎,微积分,表示暂时并没有很深入的研究……虽然高中有教,但是好像跟小西瓜学的顺序不太一样,嗯……教微积分之前不应该把极限学下来么……不管了,本文按傻X腾的理解来搞吧. 极限……大学的东西喔,我们先来认 ...
- CSS3动画属性和flex弹性布局各个属性
[CSS3动画的使用] 1.声明一个关键帧(动画): @keynames name{ from{} to{} } 每个阶段的写法: ①可以直接使用from-to的写法 ②可以设置0%-100%的写法, ...
- webpack + babel
webpack设计思想:不区分.png .css .js 等文件,都视为一个模块.通过require导入,loader加载器编译之后打包在一个主js文件里. 优势:减少http请求. 1. webpa ...
- angular $compile的使用
在写前端js时,经常会动态创建标签放入文本元素中: 比如:var strDiv='<div>new create element</div>'; $(strDiv).appen ...