博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
扫描识别工具Dynamic Web TWAIN使用教程:将图像上传到Web服务器(下)
阅读量:6292 次
发布时间:2019-06-22

本文共 2910 字,大约阅读时间需要 9 分钟。

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

格式 方法
任何类型
支持的图像
多页PDF
多页TIFF

代码片段

DWObject.FTPUserName = 'test';DWObject.FTPPort = 21;DWObject.FTPPassword = 'test';DWObject.FTPUploadAllAsPDF(    '192.168.8.222',    'test.pdf',    OnFtpUploadSuccess,    OnFtpUploadFailure);复制代码

将图像上传到数据库

不会直接将图像保存/上传到数据库。相反,图像数据首先保存在操作页面,然后操作页面中的代码决定存储它的位置。

如果你不确定如何将图像数据上传到服务器,请参阅上一篇文章“”。

不同的数据库系统可能具有不同的图像数据数据类型。我们一般在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服务器的教程到此结束,下一篇将与大家分享如何从网上下载图片,敬请期待~

                           【】

转载于:https://juejin.im/post/5c4ab616e51d45517411ae9e

你可能感兴趣的文章
nodejs笔记1 ----关于express不是本地命令
查看>>
python debug
查看>>
docker-machine 远程安装docker
查看>>
最全的常用正则表达式大全——包括校验数字、字符、一些特殊的需求等等
查看>>
3.2 进程间通信之fifo
查看>>
WEB 开发前传——js笔记
查看>>
C++多线程编程入门(转)
查看>>
C# to IL 6 Reference and Value Types(引用类型和值类型)
查看>>
Python 爬虫十六式 - 第七式:正则的艺术
查看>>
Android Studio的使用(五)--导入第三方Jar包
查看>>
PCL学习笔记(一)
查看>>
CoreGraphics相关方法
查看>>
Node Express 初探
查看>>
回溯法-求解装载问题(类似0-1背包)
查看>>
MATLAB中求矩阵非零元的坐标
查看>>
Tabular系列之问题1:如何利用其他人的账号进行权限测试?
查看>>
Configuration、SessionFactory、Session
查看>>
Sql Server基础小结
查看>>
轻装好上阵
查看>>
从国产浏览器更换到谷歌浏览器的心路历程
查看>>