提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:黄竹雯|2019-01-18 13:59:59.000|阅读 232 次
概述:本文为你介绍在Dynamic Web TWAIN中如何将图像上传到Web服务器。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
上一篇文章教大家如何将图片上传到服务器,本篇文章将继续与大家分享如何将图像上传到FTP和数据库。
HTTP上传方法向服务器上的操作页面发出标准HTTP发布请求。请求包含图像数据,图像名称等。在操作页面中,你可以根据需要处理图像数据。从技术上讲,你可以使用任何服务器端语言(例如C#,VB,PHP,Java)编写操作页面。
这是C#中的一个例子:
此操作页面从当前HTTP请求对象中检索图像数据,并将其作为本地文件保存在服务器上。
HttpFileCollection files = HttpContext.Current.Request.Files; HttpPostedFile uploadfile = files["RemoteFile"]; uploadfile.SaveAs(System.Web.HttpContext.Current.Request.MapPath(".") + "/" + uploadfile.FileName);
请注意,RemoteFile是上传图像数据的默认名称/密钥。如有必要,可以使用属性HttpFieldNameOfUploadedImage更改它。
在PHP中:
$fileTempName = $_FILES['RemoteFile']['tmp_name']; $fileSize = $_FILES['RemoteFile']['size']; $fileName = $_FILES['RemoteFile']['name']; move_uploaded_file($fileTempName, $fileName) ;
除了HTTP上传方法,你还可以使用FTP上传方法将图像更新到FTP Web服务器。可用的API是:
格式 | 方法 |
任何类型 | |
支持的图像 | |
多页PDF | |
多页TIFF |
代码片段
DWObject.FTPUserName = 'test'; DWObject.FTPPort = 21; DWObject.FTPPassword = 'test'; DWObject.FTPUploadAllAsPDF( '192.168.8.222', 'test.pdf', OnFtpUploadSuccess, OnFtpUploadFailure );
Dynamic Web TWAIN不会直接将图像保存/上传到数据库。相反,图像数据首先保存在操作页面,然后操作页面中的代码决定存储它的位置。
如果你不确定如何将图像数据上传到服务器,请参阅上一篇文章“服务器磁盘上的上传和保存”。
不同的数据库系统可能具有不同的图像数据数据类型。我们一般在MSSQL Server中使用BLOB或varbinary,在Oracle中使用Long raw或BLOB,在MySQL中使用BLOB。
以下是在MSSQL Server中使用C+的示例:
int iFileLength; HttpFileCollection files = HttpContext.Current.Request.Files; HttpPostedFile uploadfile = files["RemoteFile"]; String strImageName = uploadfile.FileName; iFileLength = uploadfile.ContentLength; Byte[] inputBuffer = new Byte[iFileLength]; System.IO.Stream inputStream; inputStream = uploadfile.InputStream; inputStream.Read(inputBuffer,0,iFileLength); // add code to connect to database String SqlCmdText = "INSERT INTO tblImage (strImageName,imgImageData) VALUES (@ImageName,@Image)"; System.Data.SqlClient.SqlCommand sqlCmdObj = new System.Data.SqlClient.SqlCommand(SqlCmdText, sqlConnection); sqlCmdObj.Parameters.Add("@Image",System.Data.SqlDbType.Binary,iFileLength).Value = inputBuffer; sqlCmdObj.Parameters.Add("@ImageName",System.Data.SqlDbType.VarChar,255).Value = strImageName; sqlConnection.Open(); sqlCmdObj.ExecuteNonQuery(); sqlConnection.Close();
在此代码片段中,我们从当前HTTP请求获取文件对象,并将图像数据写入字节数组。在SQL语句中,我们将字节数组作为System.Data.SqlDbType.Binary传递给数据库,并将数据存储在imgImageData的BL字段中。
有时我们需要将更多信息传递给服务器。例如,文档类型,员工ID,文档描述等。由于在HTTP上传方法中没有传递附件数据的方法,因此我们需要使用名为SetHTTPFormField的方法。
SetHTTPFormField(String sFieldName, String sFieldValue)
我们需要在上传之前就使用此方法。例如:
DWObject.ClearAllHTTPFormField(); // Clear all fields first DWObject.SetHTTPFormField("EmployeeID", "2012000054"); DWObject.SetHTTPFormField("DocumentType", "Invoice"); DWObject.SetHTTPFormField("DocumentDesc", "This is an invoice from ...");
在操作页面中,你可以通过字段名称从请求对象中检索数据。例如:
String EmployeeID = HttpContext.Current.Request.Form["EmployeeID"];
关于如何使用Dynamic Web TWAIN将图像上传到Web服务器的教程到此结束,下一篇将与大家分享如何从网上下载图片,敬请期待~
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢