linux上编写运行 dotnet core api

安装 Ubuntu

        dotnet core 跨平台已不再是梦,它带来的意义非凡,比如api接口可以在linux上编写及部署,也可以在windows上编写好,打包发布,然后copy到linux上部署从官网下载最新版本, 然后装到虚拟机VMware中。如果是centeros,系统开启后,默认进入命令行模式,估计一部分同学,看到类似dos界面,有点恐慌,不急,在命令行中输入startx回车,进入到图形界面。无论是哪种系统,虚拟机上装的操作系统,在开机启动后,都有可能窗口不能自适应,也就是说不能全屏,非常小。针对windows,直接运行VMware Tools即可。针对linux系统,我们直接双击是安装不了的。这是Ubuntu漂亮的紫色界面:

输入密码,登录到系统中。定位到VMware Tools安装目录,它还是tar.gz压缩文件,所以首先解压缩,用cd命令转到解压后的目录(直接打开目录,然后鼠标右键打开终端,就不用cd了),输入./vmware-install.pl,一路回车。

安装vscode

  从官网下载vscode,上面有注明操作系统。centeros是从redhat发展而来的。ubantu是基于Debian。前者擅长服务器端,后者主要是pc端。

  1、下载安装包 .deb package (64-bit)

  2、sudo apt install ./<file>.deb

  3、Then update the package cache and install the package using:

  sudo apt-get install apt-transport-https
  sudo apt-get update
  sudo apt-get install code # or code-insiders

linux上安装vscode的确能麻烦一些。安装完了后,不知道装到哪儿去了。于是就搜索vscode,没有找到,搜索全名也没有找到,后来发现名称叫code,终于搜索到了,把code加入到桌面的收藏夹里,就出现在桌面左侧,相当windows的桌面快捷方式。如下图:

部署dotnet core web API

在命令行中,输入 dotnet  new webapi,结果不识别dotnet,它不是命令,建议安装.net core sdk,我装了最新的版本2.2。然后再运行命令创建api。

打包发布的命令:dotnet publish --configuration Release

自托管命令: dotnet ElectronInfoApi.dll

默认监听的地址:https://localhost:5001

我想要改变端口,在网上找了一种方法:

var host = new WebHostBuilder()
.UseKestrel()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.UseUrls("https://localhost:5001/")
.Build();

host.Run();

  更改url或者端口都可以,这就是传说中的硬编码。因为上面的代码是在 Main(string[] args)方法里,所以可以从命令行传参,经过实践,这种方式是可以的。传参:dotnet ElectronInfoApi.dll  server.urls=https://192.168.19.1:9000,代码中接受参数:var  url=args.Length>0?args[0]:" ";

  还有另外一种方法,就是什么都不用修改,这是命令行创建api的时候,自动生成的代码:

    public class Program {
        public static void Main(string[] args) {
            CreateWebHostBuilder(args).Build().Run();
        }
        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseStartup <Startup> ();
    }

  发布后运行结果:

  IIS或者其它服务器上部署,端口配置,都有图形化界面操作,不是什么问题。我在linux上发布了接口,然后window上的vue程序就可以请求了。先在postman中测试:

  好了,这样linux上的接口部署完毕,测试成功。

dotnet core api 传参 

1、get请求传参

      [HttpGet]
        [Route("Items")]
        public JsonResult GetAll(int pageSize, int pageIndex)
        {
            AjaxResult result = new AjaxResult();
            var list = DbHelper.Select<Achievement>();

            var companys = DbHelper.Select<Company>();
            var users = DbHelper.Select<User>();

            //转换为ViewModel
            List<AchievementViewModel> models = new List<AchievementViewModel>();
            foreach (var item in list)
            {

                var vm = ModelConvertion.Convert<AchievementViewModel, Achievement>(item);
                var company = companys.SingleOrDefault(c => c.Id == item.CompanyId);
                vm.CompanyName = company == null ? "" : company.CompanyName;
                var user = users.SingleOrDefault(u => u.Id == item.Completer);
                vm.CompleterName = user == null ? "" : user.UserName;
                models.Add(vm);
            }

            result.Data = models.OrderByDescending(f => f.PublishDate).Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();
            result.ItemCount = models.Count;
            return Json(result);

        }

        [HttpGet("{id}")]
        public ActionResult<Achievement> GetById(int id)
        {
            return DbHelper.SingleById<Achievement>(id);
        }

两种方法,一个把参数放到路由里,一个不放,都可以,根据情况决定。不建议在接收的时候,使用对象接收,因为可能接收不到参数,对象前加上[FromUrl],不知道能不能收到,有兴趣的同学可以尝试。

2、post方法

        [HttpPost]
        [Authorize]
        public JsonResult item([FromBody] Achievement item)
        {
            AjaxResult result = new AjaxResult();
            try
            {
                if (DbHelper.Exist<Achievement>(b => b.Id == item.Id))
                {

                    result.IsSuccess = DbHelper.Update<Achievement>(item) > 0;
                }
                else
                {
                    result.IsSuccess = DbHelper.Insert<Achievement>(item, true) > 0;
                }
            }
            catch (Exception ex)
            {
                result.IsSuccess = false;
                result.Message = "保存出错";
                this.Log().Error("保存出错", ex);
            }
            return Json(result);
        }
        [HttpPost]
        [Route("[action]/{id}")]
         [Authorize]
        public ActionResult Delete(int id)
        {
            AjaxResult result = new AjaxResult();
            if (DbHelper.Delete<Achievement>(c => c.Id == id) > 0)
            {
                result.IsSuccess = true;
                UserManager.DeleteUserRef(id,2);
            }
            else
            {
                result.IsSuccess = false;
            }
            return Json(result);
        }

post时,数据也可以从路由来,也可以直接传,接收时,如果以对象接收,前面加上[FromBody]。否则部署后,很有可能接收不到参数。

原文地址:https://www.cnblogs.com/wangqiang3311/p/10113325.html

时间: 2024-09-30 11:21:10

linux上编写运行 dotnet core api的相关文章

.NET跨平台之旅:在生产环境中上线第一个运行于Linux上的ASP.NET Core站点

2016年7月10日,我们在生产环境中上线了第一个运行于Linux上的ASP.NET Core站点,这是一个简单的提供后端服务的ASP.NET Core Web API站点. 项目是在Windows上用V2015开发的,以self-contained应用部署方式发布到Linux服务器.Linux服务器用的是Ubuntu 14.04,站点通过supervisor以服务方式运行,部署在2台阿里云服务器上,用了1台阿里云内网负载均衡. 虽然是很简单的站点,虽然是很小的一步,但是进入生产环境就意味着对性

DOCKER上运行DOTNET CORE

原文:DOCKER上运行DOTNET CORE 下载microsoft/dotnet镜像 运行命令: docker pull microsoft/dotnet 如果没有使用阿里镜像加速的,参照这篇先配置好再跑上面命令: http://www.cnblogs.com/windchen/p/6231009.html 启动持久化容器 docker run -itd -p 5000:5000 microsoft/dotnet -p用来添加Host跟Container的端口映射 创建.NET Core M

.NET跨平台之旅:生产环境中第2个跑在Linux上的ASP.NET Core站点

今天我们在生产环境中上线了第2个跑在Linux上的ASP.NET Core站点.这是一个简单的Web API站点,通过命令行的方式调用安装在Linux服务器上的程序完成操作.之前用的是nodejs,现在换成了ASP.NET Core,主要代码如下: var psi = new ProcessStartInfo(command, arguments) { RedirectStandardOutput = true, RedirectStandardInput = true, CreateNoWin

Linux上的运行的jar包

以调用json-simple为例 java程序(CsvTest.java) import org.json.simple.JSONObject; import java.util.*; public class SplitDemo { public static void main(String[] args) { JSONObject obj = new JSONObject(); } } 放置 将外部jar包(json-simple.jar)放在Linux路径下面.如/home/cys/li

如何在64位版本Linux上开发运行32位应用程序

最近换了Linux系统,由i686换成了x86-64,导致在进行开发的时候出用不了原来SDK中32位的开发工具.于是,博主找到如下文章,博主亲测实用: 如何在64位版本Linux上开发运行32位应用程序 内容如下: 很多程序员(特别是别的公司的)跟我抱怨说他们32位软件无法在我们的64位Linux系统上正常运行,而在他们32位机上正常,其实这个很好解决,一般 是64位系统安装后没有默认安装glibc的32位版本,通过简单的执行以下命令即可实现在64位Linux系统上开发运行32位应用程序,而不用

在树莓派上运行dotNet core console 程序

---恢复内容开始--- 微软的dotNet Core 已经发布很长时间了,现在最新的版本是2.0.2 发现大家对dotNet Core 在service & micro service上的文章不少.不过本地程序却少的可怜. 作为CS端坚守的dotneter  我觉得应该做点什么,让误入dotNet CS端的小盆友们不要再无助下去. 好了身家,三围,银行卡号已经交代清楚,下来我们进入正题,看看如何在armhf设备上run起来一个dotNet Core的Console Application. 首

Linux CentOS 7 下dotnet core webpai + nginx 部署

参考:https://www.jianshu.com/p/b1f573ca50c7 跟着做到,配置nginx访问dotnet core网站时,报错了. 错误如下所示—— 查看nginx的错误日志: cat /var/log/nginx/error.log | more 再查看系统的nginx相关的审计日志 cat /var/log/audit/audit.log | grep nginx | grep denied bing查找关键字——.netcore webapi nginx permiss

Ubuntu运行DOTNET Core MVC(基础,非部署项目)

一. 配置 Ubuntu18.04.3 LTS DOTNET Core3.0 SDK 1.更新 sudo apt-get update 二.安装DOTNET Core SDK 1.首先注册微软密钥以及所需依赖 wget -q https://packages.microsoft.com/config/ubuntu/18.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb sudo dpkg -i packages-micro

java项目在linux上的运行

之前一直在windows下开发java项目,现如今在项目组主要是spring + mybatis +maven + git +MySQL来开发项目,最近碰到将项目移植到linux上去跑,遇到了一系列的问题,比如java程序在linux下的运行,由于接触java不长,对java的运行机制还不是很了解,最后先用maven 对项目进行了编译后,再在maven自动生成的target的class文件中直接执行main.class 文件运行,具体的命令是:java -classpath [jar包目录][配