首页 » 网站建设 » dwphp上传图片技巧_Dynamic Web TWAIN运用教程将图像上传到Web做事器下

dwphp上传图片技巧_Dynamic Web TWAIN运用教程将图像上传到Web做事器下

访客 2024-12-08 0

扫一扫用手机浏览

文章目录 [+]

操作页面

HTTP上传方法向做事器上的操作页面发出标准HTTP发布要求。
要求包含图像数据,图像名称等。
在操作页面中,你可以根据须要处理图像数据。
从技能上讲,你可以利用任何做事器端措辞(例如C#,VB,PHP,Java)编写操作页面。

dwphp上传图片技巧_Dynamic Web TWAIN运用教程将图像上传到Web做事器下

这是C#中的一个例子:

dwphp上传图片技巧_Dynamic Web TWAIN运用教程将图像上传到Web做事器下
(图片来自网络侵删)

此操作页面从当前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) ;

上传到FTP

除了HTTP上传方法,你还可以利用FTP上传方法将图像更新到FTP Web做事器。
可用的API是:

FTPUploadDirectly( )

FTPUpload( )

FTPUploadEx( )

FTPUploadAllAsPDF( )

FTPUploadAsMultiPagePDF( )

FTPUploadAllAsMultiPageTIFF( )

FTPUploadAsMultiPageTIFF( )

代码片段

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 databaseString 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)String sFieldName:指定Web表单中文本字段的名称String sFieldValue:指定Web表单中文本字段的值

我们须要在上传之前就利用此方法。
例如:

DWObject.ClearAllHTTPFormField(); // Clear all fields firstDWObject.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做事器的教程到此结束,希望对你有所帮助。

点击“理解更多”下载产品最新版

↓↓↓

标签:

相关文章