第六节:WebApi的部署方式(自托管)

一. 简单说明

   开篇就介绍过WebApi和MVC相比,其中优势之一就是WebApi可以不依赖于IIS部署,可以自托管,当然这里指的是 .Net FrameWork 下的 WebApi 和 MVC 相比较,在.Net Core下,当然就另行别论。

  下面我们重点介绍的就是WebApi基于控制台程序进行部署。

1. 安装程序集

  通过Nuget添加程序集:Microsoft.AspNet.WebApi 和 System.Web.Http.SelfHost。

2. 新建一个WebApi的控制器,里面有一个CheckLogin的Get方法。

 代码如下:

复制代码

 1   public class ForthController : ApiController2     {3         //Get http://localhost:1234/api/Forth/CheckLogin?userName=admin&pwd=1234564         [HttpGet]5         public string CheckLogin(string userName, string pwd)6         {7             if (userName == "admin" && pwd == "123456")8             {9                 return "ok";
10             }
11             else
12             {
13                 return "error";
14             }
15         }
16     }

复制代码

3. 编写部署代码

  包括端口设定,路由规则的配置,启动和关闭,代码如下:

复制代码

 1    class Program2     {3         static void Main(string[] args)4         {5             try6             {7                 var config = new HttpSelfHostConfiguration("http://localhost:1234");8                 config.Routes.MapHttpRoute(name: "DefaultApi",9                                            routeTemplate: "api/{controller}/{action}/{id}",
10                                            defaults: new { id = RouteParameter.Optional });
11                 using (var sever = new HttpSelfHostServer(config))
12                 {
13                     sever.OpenAsync().Wait();
14                     Console.WriteLine("服务已经成功启动");
15                     Console.WriteLine("输入任意字符关闭");
16                     Console.Read();
17                     sever.CloseAsync().Wait();
18 
19                 }
20             }
21             catch (Exception ex)
22             {
23                 Console.WriteLine(ex.Message);
24             }
25             Console.ReadKey();
26         }
27     }

复制代码

  特别注意:不能直接在VS里启动,会报权限不够的错误,正确的使用放在,在Bin文件里,找到Exe程序,以管理员的身份启动即可。

 4. 启动exe程序,然后用PostMan进行测试:http://localhost:1234/api/Forth/CheckLogin?userName=admin&pwd=123456,正常访问,结果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/438477.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第七节:WebApi与Unity整合进行依赖注入和AOP的实现

一. IOC和DI 1. 通过Nuget引入Unity程序集。 PS:【版本:5.8.6】 2. 新建DIFactory类,用来读取Unity的配置文件并创建Unity容器,需要注意的是DIFactory类需要声明成单例。 PS:这里采用静态构造函数(必须是无参的)的形式来实现单…

android 倒计时封装,react native中的聊天气泡及timer封装成的发送验证码倒计时

其实,今天我想把我近期遇到的坑都总结一下:1.goBack的跨页面跳转,又两种方法,一可以像兔哥那样修改navigation源码,二可以用navigationActions2.父子组件的传值,一可以用callBack 二可以用pubsub发布订阅模…

第八节:常见安全隐患和传统的基于Session和Token的安全校验

一. 常见的安全隐患 1. SQL注入 常见的案例: String query "SELECT * FROM T_User WHERE userID" Request["userID"] "; 这个时候,只需要在传递过来的userID后面加上个: or 11,即可以获取T_User表中…

android手机设置时间设置,如何设置电信定制手机日期与时间

使用电信定制手机如A765e、A600e、A560e等的时候,可能会发现手机的日期和时间没法自己设置。这主要是因为手机使用电信卡时,会自动与电信基站进行交互并自动调节日期与时间。所以不论使用电信定制的单模或双模手机(单模是指手机只有一个卡槽,…

第一节 特有标签

1.设置浏览器兼容版本 <meta http-equiv"X-UA-Compatible" content"IE8"> 表示IE浏览器默认版本为8 <meta http-equiv"X-UA-Compatible" content"IEedge"> 表示IE浏览器默认选择最高版本 2. 手机端特有…

第二节 CSS入门介绍

一.背景 这里将陆续介绍前端CSS中相关知识&#xff0c;先介绍CSS2.1&#xff0c;后续会介绍CSS3的相关属性&#xff0c;通过该系列的文章&#xff0c;希望能给准备转战前端的人员一些帮助&#xff0c;同时也帮助自己梳理知识&#xff0c;文章中如有错误&#xff0c;欢迎指出。 …

三星sec.android.soagent,3.0降级2.5教程

给小白看的。下载五件套&#xff0c;odia&#xff0c;驱动&#xff0c;地址&#xff1a;http://www.samsungmembers.cn/thread-1019962-110-150.html&#xff0c;或者自己论坛搜索&#xff0c;请下载G9810ZCU2BTJA&#xff0c;别下k3最后一个版本的会出问题&#xff0c;刷机后再…

第三节 入门属性

1.七个基本属性 颜色&#xff1a;color&#xff0c;背景颜色&#xff1a;background-color&#xff0c;字体大小&#xff1a;font-size&#xff0c;加粗&#xff1a;font-weight:bold&#xff0c;倾斜&#xff1a;font-style:italic&#xff0c; 文字居中&#xff1a;text-alig…

doc文件转换html,HTML+CSS入门 如何使用POI将doc文件转换为HTML

本篇教程介绍了HTMLCSS入门 如何使用POI将doc文件转换为HTML&#xff0c;希望阅读本篇文章以后大家有所收获&#xff0c;帮助大家HTMLCSS入门。<需要的jar包有&#xff1a;有一些是依赖包&#xff0c;可以使用maven下载doc文件转换为html文件package com.gsww.sxzz.controll…

第四节 CSS继承性和层叠性

一. 继承性 1. 含义&#xff1a;从自己开始直到所包裹的最小的元素&#xff0c;都可以继承一些特有的属性。 2. 作用范围&#xff1a; a. color、text-开头的、line-开头的、font-开头的&#xff0c;均可以继承。 b. 文字样式的&#xff0c;都能继承&#xff1b;所有关于盒子的…

html鼠标划过显示图片,jquery实现鼠标滑过小图查看大图的方法

本文实例讲述了jquery实现鼠标滑过小图查看大图的方法。分享给大家供大家参考。具体实现方法如下&#xff1a;1. CSS部分&#xff1a;ul{list-style:none;}li{float:left;margin-left:10px;}img{border:#CCCCCC solid 1px;}#max{position:absolute;display:none; /*隐藏层*/}2.…

html一行省略号变手型,鼠标移动到表格的TD上的时候显示成一个手型的样子怎么做?...

总结CSS3新特性&lpar;Animation篇&rpar;动画(Animation),是CSS3的亮点.//之一 通过animation属性指定keyframe来完成关键帧动画; keyframe用法: keyframes name { 0% { to ...BZOJ 1103&colon; &lbrack;POI2007&rsqb;大都市meg1103: [POI2007]大都市meg Ti…

第五节 盒子模型

1. 盒子模型的五个属性 盒模型主要涉及的属性有&#xff1a;width(宽度)、height(高度)、padding(内边距)、 border(边框)、margin(外边距)。 2. 盒子模型的两种模式 模式一&#xff1a;width盒子自身的width &#xff08;正常情况&#xff09; 模式二&#xff1a;width盒子自…

html的表单图形验证码怎么做,django中简单图形验证码实现

要实现django图形验证码&#xff0c;可以使用简单的captcha一、安装captcha在Pycharm的terminal中&#xff0c;使用pip安装第三方库&#xff1a;执行命令&#xff1a;pip install django-simple-captcha二、注册captcha在settings中&#xff0c;将‘captcha’注册到app列表里&a…

用计算机弹百战成诗,百战成诗(80P纯女热血翻唱)

[00:00.00]《百战成诗》[00:02.08]【韩信绯歌】山河万里 执枪肆意笑纳[00:06.67]【张良阿令】俗尘偌大 言灵纵法[00:10.86]【刘邦九蔓】宏图双面 名利皆入麾下[00:15.21]【项羽星汉】与我为伍[00:17.44]【虞姬孤狐】彼此**[00:22.16]【鲁班**LeMon】造物的复杂 无穷无极无垠无瑕…

第六节 标准文档流

一.标准文档流 标准文档流包括&#xff1a;块级元素和行内元素。 (1). 块级元素 特点&#xff1a; 一个元素单独一行&#xff0c;不与其他元素并行&#xff0c;可以设置其宽度和高度&#xff0c;如果不设置宽度&#xff0c;宽度默认为其父元素的100%。 (2). 行内元素 特点&…

第七节 浮动

一. 浮动的性质 1. 脱标&#xff08;脱离标准文档流&#xff09; 无论是块级元素还是行内元素&#xff0c;一旦浮动了&#xff0c;就脱离标准文档流&#xff08;脱标&#xff09;了&#xff0c;就可以设置宽和高了。 下面事例是两个div&#xff0c;其中第一个div浮动了。 1 &l…

html5测试 iphone6sp,5款旧iPhone测试iOS运行速度:只有6S速度明显提升

苹果在周三凌晨推送了iOS13.3.1更新&#xff0c;这款最新系统修复了许多Bug&#xff0c;而且还新增了功能。那么升级后的流畅度表现如何呢&#xff1f;外媒就在第一时间将iPhoneSE、iPhone6S、iPhone7、iPhone8、iPhoneXR这5款旧iPhone进行了一次速度测试&#xff0c;与iOS13.3…

第八节 定位

一. 定位介绍 谈到定位&#xff0c;顾名思义&#xff0c;就确定元素的位置&#xff0c;定位分为三种&#xff1a;相对定位、绝对定位、固定定位&#xff1b;分别用 position&#xff1a;relative、position&#xff1a;absolute、position&#xff1a;fixed来表示&#xff0c;它…

html将字符串按逗号分隔,js如何截取以逗号隔开的字符串

使用string对象的split()方法能够处理。正则表达式定义&#xff1a; split() 方法用于把一个字符串分割成字符串数组。数组使用方法以下&#xff1a;cdnstringObject.split(separator,howmany)对象参数描述&#xff1a;blogseparator 必需。字符串或正则表达式&#xff0c;从该…