當前位置:首頁 » 網頁前端 » webapi文件上傳
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

webapi文件上傳

發布時間: 2022-12-23 11:23:06

Ⅰ MES系統如何其他系統通訊

MES和第三方系統或者設備集成方式:

1.WebService或者WebAPI,最常見也是最基本的方式,比如和ERP或者OA對接,基本屬於這種方式。

2.開放資料庫,比如和工廠MES對接,數據上傳,工廠MES可以給我們一個資料庫用戶許可權,然後我們直接把數據寫到資料庫。

3.文件上傳,比如和其它系統對接上傳數據,可以把生產過程數據保存到CSV或者XML文件,然後把文件上傳到指定路徑。

4.TCP/IP協議,比如第三方系統開放socket服務端或者我們開放服務端,通過socket編程傳輸數據。

5.Modbus協議,通過這種協議,比較常見的是和設備的對接,直接從設備讀取分析數據。

6.串口協議,比較常見的是和設備的對接,通過串口編程,從指定的串口讀取數據。

7.OPCUA協議,最常見的也是最多使用的協議,通過該協議和PLC通訊,從PLC讀寫數據。

8.其它協議,比如西門子PLC的S7協議,歐姆龍plc的fins協議等。

Ⅱ asp.net下如何實現文件的拖拽上傳,最好是能支持大文件的上傳

其實這種拖拽上傳跟asp.net沒有關系,主要是jquery,有個jquery上傳插件叫jquery file upload,支持拖拽上傳,同時也支持多文件上傳,大文件上傳,在大文件上傳那一塊主要的用asp.net webapi做

Ⅲ 怎麼把WebApi介面部署到IIS

用flashfxp 工具上傳到伺服器 前提是你需要有伺服器上有操作空間許可權的用戶名和密碼如果是ASP的 或者.NET的 傳完用IIS配置網站文件夾安全也需要增加一個對應文件夾的用戶 或者everyone用戶 來給它寫許可權還要記得IIS配置里開啟父路徑。

Ⅳ webapi stream模式文件上傳分包嗎

WebAPI下的如何實現參數綁定 本文將概述在WebAPI方式下將如何將參數綁定到一個action方法,包括參數是如何被讀取,一系列規則決定特定環境採用的那種綁定方式,文章最後將給出一些實際的例子。 Parameter binding說到底是接到一個Http請求,將其...

Ⅳ 如何執行使用webapi HttpClient文件上傳多後

HttpClient c = new HttpClient();
var fileContent = new ByteArrayContent(new byte[100]);
fileContent.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
{
FileName = "myFilename.txt"
};

var formData = new FormUrlEncodedContent(new[]
{
new KeyValuePair<string, string>("name", "ali"),
new KeyValuePair<string, string>("title", "ostad")
});

MultipartContent content = new MultipartContent();
content.Add(formData);
content.Add(fileContent);
c.PostAsync(myUrl, content);

Ⅵ 如何使 WebAPI 自動生成漂亮又實用在線API文檔

1.1 SwaggerUI

SwaggerUI 是一個簡單的Restful API 測試和文檔工具。簡單、漂亮、易用(官方demo)。通過讀取JSON 配置顯示API. 項目本身僅僅也只依賴一些 html,css.js靜態文件. 你可以幾乎放在任何Web容器上使用。

1.2 Swashbuckle

Swashbuckle 是.NET類庫,可以將WebAPI所有開放的控制器方法生成對應SwaggerUI的JSON配置。再通過SwaggerUI 顯示出來。類庫中已經包含SwaggerUI 。所以不需要額外安裝。

2.快速開始

創建項目 OnlineAPI來封裝網路音樂服務(示例下載) ,通過API可以搜索、獲取音樂的信息和播放連接。

我盡量刪除一些我們demo中不會用到的一些文件,使其看上去比較簡潔。

WebAPI 安裝 Swashbuckle

Install-Package Swashbuckle

代碼注釋生成文檔說明。
Swashbuckle 是通過生成的XML文件來讀取注釋的,生成 SwaggerUI,JSON 配置中的說明的。
安裝時會在項目目錄 App_Start 文件夾下生成一個 SwaggerConfig.cs 配置文件,用於配置 SwaggerUI 相關展示行為的。如圖:

將配置文件大概99行注釋去掉並修改為
c.IncludeXmlComments(GetXmlCommentsPath(thisAssembly.GetName().Name));

並在當前類中添加一個方法

/// <summary>
/// </summary>
/// <param name="name"></param>
/// <returns></returns>
protected static string GetXmlCommentsPath(string name)
{
return string.Format(@"{0}\bin\{1}.XML", AppDomain.CurrentDomain.BaseDirectory, name);
}

緊接著你在此Web項目屬性生成選卡中勾選 「XML 文檔文件」,編譯過程中生成類庫的注釋文件

添加網路音樂 3個API

訪問 http://<youhost>/swagger/ui/index,最終顯示效果

我們通過API 測試API 是否成功運行

3.添加自定義HTTP Header

在開發移動端 API時常常需要驗證許可權,驗證參數放在Http請求頭中是再好不過了。WebAPI配合過濾器驗證許可權即可

首先我們需要創建一個 IOperationFilter 介面的類。IOperationFilter
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Http;
using System.Web.Http.Description;
using System.Web.Http.Filters;
using Swashbuckle.Swagger;

namespace OnlineAPI.Utility
{
public class HttpHeaderFilter : IOperationFilter
{
public void Apply(Operation operation, SchemaRegistry
schemaRegistry, ApiDescription apiDescription)
{
if (operation.parameters == null) operation.parameters = new
List<Parameter>();
var filterPipeline =
apiDescription.ActionDescriptor.GetFilterPipeline();
//判斷是否添加許可權過濾器
var isAuthorized = filterPipeline.Select(filterInfo =>
filterInfo.Instance).Any(filter => filter is IAuthorizationFilter);
//判斷是否允許匿名方法
var allowAnonymous =
apiDescription.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().Any();

if (isAuthorized && !allowAnonymous)
{
operation.parameters.Add(new Parameter
{
name = "access-key",
@in = "header",
description = "用戶訪問Key",
required = false,
type = "string"
});
}
}
}
}

在 SwaggerConfig.cs 的 EnableSwagger 配置匿名方法類添加一行注冊代碼
c.OperationFilter<HttpHeaderFilter>();

添加Web許可權過濾器
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Web;
using System.Web.Http;
using System.Web.Http.Controllers;
using Newtonsoft.Json;

namespace OnlineAPI.Utility
{
/// <summary>
///
/// </summary>
public class AccessKeyAttribute : AuthorizeAttribute
{
/// <summary>
/// 許可權驗證
/// </summary>
/// <param name="actionContext"></param>
/// <returns></returns>
protected override bool IsAuthorized(HttpActionContext actionContext)
{
var request = actionContext.Request;
if (request.Headers.Contains("access-key"))
{
var accessKey = request.Headers.GetValues("access-key").SingleOrDefault();
//TODO 驗證Key
return accessKey == "123456789";
}
return false;
}

/// <summary>
/// 處理未授權的請求
/// </summary>
/// <param name="actionContext"></param>
protected override void HandleUnauthorizedRequest(HttpActionContext actionContext)
{
var content = JsonConvert.SerializeObject(new {State = HttpStatusCode.Unauthorized});
actionContext.Response = new HttpResponseMessage
{
Content = new StringContent(content, Encoding.UTF8, "application/json"),
StatusCode = HttpStatusCode.Unauthorized
};
}
}
}

在你想要的ApiController 或者是 Action 添加過濾器
[AccessKey]

最終顯示效果

4.顯示上傳文件參數

SwaggerUI 有上傳文件的功能和添加自定義HTTP Header 做法類似,只是我們通過特殊的設置來標示API具有上傳文件的功能
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Http.Description;
using Swashbuckle.Swagger;

namespace OnlineAPI.Utility
{
/// <summary>
///
/// </summary>
public class UploadFilter : IOperationFilter
{

/// <summary>
/// 文件上傳
/// </summary>
/// <param name="operation"></param>
/// <param name="schemaRegistry"></param>
/// <param name="apiDescription"></param>
public void Apply(Operation operation, SchemaRegistry schemaRegistry, ApiDescription apiDescription)
{
if (!string.IsNullOrWhiteSpace(operation.summary) && operation.summary.Contains("upload"))
{
operation.consumes.Add("application/form-data");
operation.parameters.Add(new Parameter
{
name = "file",
@in = "formData",
required = true,
type = "file"
});
}
}
}
}

在 SwaggerConfig.cs 的 EnableSwagger 配置匿名方法類添加一行注冊代碼
c.OperationFilter<UploadFilter>();

API 文檔展示效果

Ⅶ 2018年10月微信小程序上傳文件的問題webapi方式

必須在微信公眾平台填寫請求,下載,上傳,websocket 域名,必須是SSL加密的

Ⅷ 演示如何通過 web api 上傳文件MVC40

WebApiWebFormHost/UploadFileController.cs/* * 通過 web api 上傳文件 */using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Http; using System.Threading.Tasks; using System.Web.Http; namespace MVC40.Controllers { publicclass UploadFileController : ApiController { publicasync Task<string> Post() { // 檢查是否是 multipart/form-dataif (!Request.Content.IsMimeMultipartContent("form-data")) thrownew HttpResponseException(HttpStatusCode.UnsupportedMediaType); // 設置上傳目錄var provider = new (@"c:\\temp"); // 接收數據,並保存文件var bodyparts = await Request.Content.ReadAsMultipartAsync(provider); string result = ""; // 獲取表單數據 result += "formData txtName: " + bodyparts.FormData["txtName"]; result += "<br />"; // 獲取文件數據 result += "fileData headers: " + bodyparts.FileData[0].Headers; // 上傳文件相關的頭信息 result += "<br />"; result += "fileData localFileName: " + bodyparts.FileData[0].LocalFileName; // 文件在服務端的保存地址,需要的話自行 rename 或 movereturn result; } } }WebApiWebFormHost/UploadDemo.cshtml@{ Layout = null; } <!DOCTYPE html><html><head><title>調用web api 上傳文件的 demo</title></head><body> @using (Html.BeginForm("UploadFile", "api", FormMethod.Post, new { enctype = "multipart/form-data" })) { <input type="text" id="txtName" name="txtName" value="webabcd"/><div>please select a file</div><input name="data" type="file" multiple /><input type="submit"/> } </body></html>