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#有了强大的类库,但是,我们还是不能 ...
随机推荐
- equals和hashcode重写的问题
public static void main(String[] args) { Set<Test> set = new HashSet<>(); Test t1 = new ...
- PHP使用文件流下载文件方法(附:解决下载文件内容乱码问题)
1.flush - 刷新输出缓冲 2.ob_clean - 清空(擦掉)输出缓冲区 此函数用来丢弃输出缓冲区中的内容. 此函数不会销毁输出缓冲区,而像 ob_end_clean() 函数会销毁输出缓冲 ...
- 初识DJango——MTV模型
一.Django—MTV模型 Django的MTV分别代表: Model(模型):负责业务对象与数据库的对象(ORM) Template(模版):负责如何把页面展示给用户 View(视图):负责业务逻 ...
- Maven适配多种运行环境的打包方案
项目从开发到部署会历经多个运行环境,如开发环境.测试环境和生产环境,不同环境中项目的配置文件通常也会不同,典型的如数据库连接配置.我们当然不希望每次部署打包前都去修改配置文件以适配环境,利用Maven ...
- bzoj:1703: [Usaco2007 Mar]Ranking the Cows 奶牛排名
Description 农夫约翰有N(1≤N≤1000)头奶牛,每一头奶牛都有一个确定的独一无二的正整数产奶率.约翰想要让这些奶牛按产奶率从高到低排序. 约翰已经比较了M(1≤M≤100 ...
- HDU 1232 并查集
畅通工程 Time ...
- POJ_1064 二分搜索
/*POJ 1064 *题目大意:有N条绳子,他们的长度分别为Li,如果从他们中切割K条长度相同的绳子的话,这K条绳子每条最长能有多长?答案保留到小数点后2位 *算法分析:这个问题用二分搜索可以非常容 ...
- 【Python】爬虫-Scrapy
[Scrapy] Python开发的一个快速,高层次的屏幕抓取和web抓取框架,用于抓取web站点并从页面中提取结构化的数据. Scrapy用途广泛,可以用于数据挖掘.监测和自动化测试. Scrapy ...
- centos6+cdh5.4.0 离线搭建cdh搭建
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- javascript之事件监听
addEventListener是一个监听事件并处理相应的函数,用于向指定元素添加事件句柄,可使用removeEventListener()方法来移除addEventListener()方法添加的事件 ...