【教程】扫描识别工具Dynamic Web TWAIN使用教程:将图像上传到Web服务器(下)

上一篇文章教大家如何将图片上传到服务器,本篇文章将继续与大家分享如何将图像上传到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) ;

上传到FTP

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

格式方法
任何类型FTPUploadDirectly( )
支持的图像FTPUpload( )
FTPUploadEx( )
多页PDFFTPUploadAllAsPDF( )
FTPUploadAsMultiPagePDF( )
多页TIFFFTPUploadAllAsMultiPageTIFF( )
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 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)
  • String sFieldName:指定Web表单中文本字段的名称
  • String sFieldValue:指定Web表单中文本字段的值

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

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服务器的教程到此结束,下一篇将与大家分享如何从网上下载图片,敬请期待~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会根据你的要求为你提供关于使用 Dynamic Web TWAIN 扫描识别工具教程,下面是一个建立一个“Hello World”扫描页面的示例: 1. 首先,你需要在你的项目中引入 Dynamic Web TWAIN 的库文件。你可以直接使用它的在线 CDN 地址,也可以将它下载到本地并引入。 ```html <script src="https://cdn.dynamsoft.com/dwt/16.1.1/dynamsoft.webtwain.min.js"></script> ``` 2. 接下来,你需要在你的 HTML 文件中建立一个扫描按钮和一个容器来展示扫描结果。 ```html <button id="btnScan">扫描</button> <div id="dwtcontrolContainer"></div> ``` 3. 在你的 JavaScript 文件中,你需要初始化 Dynamic Web TWAIN 并为扫描按钮添加一个点击事件。在初始化时,你需要设置它的授权密钥和容器 ID。 ```javascript // 初始化 Dynamic Web TWAIN Dynamsoft.WebTwainEnv.AutoLoad = false; Dynamsoft.WebTwainEnv.RegisterEvent("OnWebTwainReady", onReady); Dynamsoft.WebTwainEnv.ProductKey = "授权密钥"; Dynamsoft.WebTwainEnv.Load(); // 扫描按钮的点击事件 document.getElementById("btnScan").onclick = function() { var dwtObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer'); dwtObject.IfShowUI = true; dwtObject.AcquireImage(); } // 初始化成功后的回调函数 function onReady() { var dwtObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer'); dwtObject.IfShowUI = false; dwtObject.HTTPPort = 80; dwtObject.HTTPDownload( "http://localhost/HelloWorld.tif", function() { console.log("下载成功!"); }, function(errorCode, errorString) { console.log(errorString); } ); } ``` 4. 最后,你需要在你的服务器上建立一个用于保存扫描结果的接口。你可以使用 Java、PHP 等语言来实现这个接口,具体实现方式可以参考 Dynamic Web TWAIN 的官方文档。 以上就是一个使用 Dynamic Web TWAIN 建立一个“Hello World”扫描页面的示例。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值