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]。否則部署後,很有可能接收不到引數。