JAVA如何上传图片到数据库
java中图片上传并在jsp页面显示
image mediumblob not null,
description varchar(100) null
);
5,应用程序的目录结构
%catalina_home%\webapps\demo
------test_upload.htm
------upload.jsp
------WEB-INF
|-------commons-fileupload-1.0.jar
|----src
|----com
|-----cf
<html>
<head>
<title>
上传测试
</title>
<body>
<form action="upload.jsp" enctype="multipart/form-data" method="post">
your name:
<br>
<input type="text" name="name">
6,web.xml文件内容
<?xml version="1.0"?>
<!DOCTYPE web-app
PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"/j2ee/dtds/web-app_2_3.dtd">
<%
DiskFileUpload upload=new DiskFileUpload();
libwebp用法java
libwebp用法javalibwebp是一个开源的图像编码库,可用于将图像转换为WebP格式。
Java是一种广泛使用的编程语言,可以使用libwebp库来实现图像处理功能。
下面是一些关于如何使用libwebp库在Java中处理图像的步骤和示例。
一、准备工作首先,需要确保你的开发环境中已经安装了Java和相关开发工具。
另外,还需要下载并安装libwebp库,并将其添加到Java的类路径中。
二、导入库文件在Java项目中,需要将libwebp库文件导入到项目中。
可以使用以下步骤:1.将libwebp库文件添加到Java项目的类路径中。
通常,可以在开发工具的库文件夹中找到这些文件。
2.在Java代码中导入所需的库文件,例如:```javaimportlibwebp.LibWebP;```三、使用libwebp库下面是一个简单的示例代码,展示了如何使用libwebp库将图像转换为WebP格式:```javaimportlibwebp.LibWebP;importlibwebp.WebP;importjava.awt.image.BufferedImage;importjava.io.File;importjava.io.IOException;publicclassWebPConverter{publicstaticvoidmain(String[]args){//加载图像文件BufferedImageimage=null;try{image=ImageIO.read(newFile("input.jpg"));}catch(IOExceptione){e.printStackTrace();}if(image==null){System.out.println("无法加载图像文件");return;}//将图像转换为WebP格式并保存为输出文件StringoutputPath="output.webp";WebPwebp=newWebP(image,WebP.UNCOMPRESSED,100);//100表示无损压缩质量为100%byte[]result=null;try{result=LibWebP.encode(webp,LibWebP.ENCODE_WEBP_ALWAYS);//将图像编码为WebP格式并保存结果到byte数组中}catch(Exceptione){e.printStackTrace();}finally{if(result!=null){try{FileoutputFile=newFile(outputPath);//输出文件路径ImageIO.write(image,"webp",outputFile);//将编码后的图像保存到输出文件中}catch(IOExceptione){e.printStackTrace();}finally{LibWebP.free(result);//释放byte数组内存空间}}else{System.out.println("编码失败");}}}}```上述代码中,首先加载了一个输入图像文件,并将其转换为WebP 格式。
java中的imageio.write 用法
java中的imageio.write 用法imageio.write() 是Java 中用于将图像数据写入图像文件的方法。
它允许开发人员将图像数据以不同的格式(例如JPEG、PNG、BMP等)保存到本地磁盘上的文件中。
imageio.write() 方法的使用方法如下:javapublic static boolean write(RenderedImage im, String formatName, File output) throws IOException {ImageWriter writer = null;ImageOutputStream ios = null;try {根据格式名称获取合适的图像写入器Iterator<ImageWriter> writers =ImageIO.getImageWritersByFormatName(formatName);if (!writers.hasNext()) {throw new UnsupportedOperationException("Unsupported image format: " + formatName);}writer = writers.next();创建图像输出流ios = ImageIO.createImageOutputStream(output);writer.setOutput(ios);设置压缩参数ImageWriteParam param = writer.getDefaultWriteParam();if (formatName.equalsIgnoreCase("JPEG") formatName.equalsIgnoreCase("JPG")) {param.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);param.setCompressionQuality(0.8f);}写入图像文件writer.write(null, new IIOImage(im, null, null), param);return true;} finally {关闭资源if (writer != null) {writer.dispose();}if (ios != null) {ios.close();}}}上述代码展示了一个基本的使用imageio.write() 方法保存图像的示例。
Java文件上传与文件下载实现方法详解
Java⽂件上传与⽂件下载实现⽅法详解本⽂实例讲述了Java⽂件上传与⽂件下载实现⽅法。
分享给⼤家供⼤家参考,具体如下:Java⽂件上传数据上传是客户端向服务器端上传数据,客户端向服务器发送的所有请求都属于数据上传。
⽂件上传是数据上传的⼀种特例,指客户端向服务器上传⽂件。
即将保存在客户端的⽂件上传⼀个副本到服务器,并保存在服务器中。
1、上传表单要求⽂件上传要求客户端提交特殊的请求——multipart请求,即包含多部分数据的请求。
必须将<form/>标签的enctype属性值设为“multipart/form-data”,enctype表⽰encodingType,及编码类型由于客户端上传⽂件的⼤⼩是不确定的,所以http协议规定,⽂件上传的数据要存放于请求正⽂中,不能出现在URL地址栏内。
也就是说,想要上传⽂件必须提交POST请求。
表单中要有<input type="file" />标签注意:multipart/form-data请求与普通请求不同2、下载⽂件上传jar包并查看官⽅⽂档选择Commons中的FileUpload项⽬,并下载jar包和源⽂件查看FileUpload的⼯作⽅式查看FileUpload项⽬的API3、使⽤第三⽅jar包上传⽂件public class RegisterServlet extends HttpServlet {private static final long serialVersionUID = 1L;public RegisterServlet() {super();}protected void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.getWriter().append("Served at: ").append(request.getContextPath());}protected void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {//第⼀步、判断请求是否为multipart请求if(!ServletFileUpload.isMultipartContent(request)) {throw new RuntimeException("当前请求只⽀持⽂件上传");}try {//第⼆步、创建FileItem⼯⼚DiskFileItemFactory factory = new DiskFileItemFactory();//设置临时⽂件存储⽬录String path = this.getServletContext().getRealPath("/Temp");File temp = new File(path);factory.setRepository(temp);//单位:字节。
java与ckeditor和ckfinder整合后实现上传图片功能
<maxSize>0</maxSize>
<allowedExtensions>7z,aiff,asf,avi,bmp,csv,doc,docx,fla,flv,gif,gz,gzip,jpeg,jpg,mid,mov,mp3,mp4,mpc,mpeg,mpg,ods,odt,pdf,png,ppt,pptx,pxd,qt,ram,rar,rm,rmi,rmvb,rtf,sdc,sitd,swf,sxc,sxw,tar,tgz,tif,tiff,txt,vsd,wav,wma,wmv,xls,xlsx,zip
</type>
</types>
<!-- 可允许的操作 -->
<accessControls>
<accessControl>
<role>*</role>
<resourceType>*</resourceType>
<folder>/</folder>
<params>
<param name="smallThumb" value="90x90"></param>
<param name="mediumThumb" value="120x120"></param>
<param name="largeThumb" value="180x180"></param>
java实现文件上传和下载
java实现⽂件上传和下载本⽂实例为⼤家分享了java实现⽂件上传和下载的具体代码,供⼤家参考,具体内容如下⽂件的上传upload:⽂件上传客户端通过表单的⽂件域file 把客户端的⽂件上传保存到服务器的硬盘上页⾯⾸先对上传的表单有以下要求:必须有⽂件域:input type=file表单提交⽅式:method=post表单的 enctype=multipart/form-data<form method="post" action="/user/regist" enctype="multipart/form-data"><table style="border: chartreuse;solid:2px"><tr><th>⽤户名</th><td><input type="text" name="username"></td></tr><tr><th>密码</th><td><input type="password" name="password"></td></tr><tr><th>⽤户头像</th><td><input type="file" name="photo"> </td></tr><tr><td colspan="2"><input type="submit" value="提交"></td></tr></table></form>Servlet1)⾸先要导⼊以下两个jar包,通过commons-fileupload实现⽂件上传2)创建⼀个⼯⼚对象DiskFileItemFactory,在创建⼀个多部件表单解析器ServletFileUpload,构造⽅法传⼊⼯⼚对象3)解析器解析请求对象,获得⼀个list集合,其中list集合存储的是⼀个⼀个的fileItem对象,⼀个fileItem对应⼀个组件,也就是⼀个<input>4) 遍历集合⽤isFormField()⽅法判断是否为普通组件,然后着重处理⽂件域组件5)获取⽂件名,并⽤getRealPath⽅法获取服务器上传⽂件所在路径,创建新⽂件夹6)获取输⼊流和创建输出流,进⾏⽂件的读写@WebServlet(value = "/user/regist")public class UploadServlet extends HttpServlet {protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//创建⼀个⼯⼚对象DiskFileItemFactory factory = new DiskFileItemFactory();//创建⼀个多部件解析器对象ServletFileUpload fileUpload = new ServletFileUpload(factory);User user = new User();FileOutputStream out=null;try {//⽤解析器对象解析请求,返回⼀个FileItem类型的集合List<FileItem> list = fileUpload.parseRequest(req);for (FileItem fileItem : list) {/*** fileItem.getFieldName());:::获取组件的name值* fileItem.getName());::::获取⽂件域的⽂件名* fileItem.getSize());::::获取数据的字节个数* fileItem.getString());::::获取数据的字符串* fileItem.isFormField());:::判断是否为普通组件*///判断部件是否为普通组件if (fileItem.isFormField()) {//普通组件//获取组件名字也就是name的值String fieldName = fileItem.getFieldName();//获取组件的值也就是value的值String value = fileItem.getString("utf-8");if ("username".equals(fieldName)) { //设置实体类的属性user.setUsername(value);} else if ("password".equals(fieldName)) {user.setPassword(value);}} else {// ⽂件域//获取⽂件名String fielName = fileItem.getName();//输⼊流来读数据InputStream in = fileItem.getInputStream();//设置⽂件写出的路径,并⽤随机码来保证图⽚可以重复String path=req.getServletContext().getRealPath("/imgs/"+ UUID.randomUUID()+fielName);System.out.println("⽂件路径为:"+path);File file = new File(path);out = new FileOutputStream(file);//利⽤commons-io-1.4.jar的IOUtils的copy⽅法直接实现⽂件的复制IOUtils.copy(in,out);user.setPhoto(file.getName());}}} catch (Exception e) {e.printStackTrace();}finally {if(out!=null){out.close();}}req.getSession().setAttribute("user",user);req.getRequestDispatcher("/sucess.jsp").forward(req,resp);}}⽂件的下载页⾯只需⼀个超链接,传需要下载的⽂件名,或者直接输⼊路径在浏览器例: <a href="<c:url value='/file/download?fileName=14.jpg'/>" >狗狗1</a><br/>Servlet1)接收参数,获取⽂件名2)获取imgs的路径,也就是存储⽂件的⽂件夹的路径,然后创建⽂件,传⼊该路径和⽂件名3)创建输⼊流读取⽂件4)设置响应头,⾸先根据⽂件名字获取⽂件的⼤类型,设置响应头Content-Type指定响应的类型;设置响应头Content-Disposition,指定⽂件以附件形式保存到本地磁盘5)⽤响应获取输出流,读出⽂件到客户端@WebServlet("/user/download")public class DownloadServlet extends HttpServlet {protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {request.setCharacterEncoding("UTF-8");//获取要下载的⽂件名String fileName = request.getParameter("fileName");System.out.println(fileName);//获取服务器中存储图⽚的⽂件夹的路径String path1 = request.getServletContext().getRealPath("/imgs");String path=path1+"/"+fileName;File file = new File(path);//创建输⼊流读⽂件FileInputStream in = new FileInputStream(file);//通过⽂件名字获取⽂件的⼤类型String type = request.getServletContext().getMimeType(fileName);//设置响应头ContentType指定响应内容的类型response.setHeader("Content-type",type);//设置响应头Content-Disposition 指定以附件形式保存响应的信息response.setHeader("Content-Disposition","attachment;filename="+(URLEncoder.encode(fileName, "utf-8"))); ServletOutputStream out = response.getOutputStream();//实现⽂件的读写IOUtils.copy(in,out);if(in!=null){in.close();}}}以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
18.Javaweb中文件的上传和下载【重要】
18.Javaweb中⽂件的上传和下载【重要】Javaweb中⽂件的上传和下载⽂件上传⽂件上传指的是⽤户通过浏览器向服务器上传某个⽂件,服务器接收到该⽂件后会将该⽂件存储在服务器的硬盘中,通常不会存储在数据库中,这样可以减轻数据库的压⼒并且在⽂件的操作上更加灵活,常见的功能是上传头像图⽚。
⽂件上传的原理所谓的⽂件上传就是服务器端通过request对象获取输⼊流,将浏览器端上传的数据读取出来,保存到服务器端。
⽂件上传的要求提供form表单,表单的提交⽅式必须是post【get请求装不下那么多】form表单中的enctype属性必须是 multipart/form-data 【照着做就⾏】表单中提供input type=”file”上传输⼊域 【⽂件那个表单】先来个表单:<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title></head><body><figure><img src=""></figure><form action="#" method="post" accept-charset="utf-8" enctype="multipart/form-data"> <!--# 提交地址记得改!--><input type="file" name="photo"><br><input type="submit" value="上传头像"></form></body></html>来个Servlet来接收⼀下这个图⽚:package upload;import java.io.IOException;import java.io.InputStream;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/*** ⽂件上传例⼦*/public class file extends HttpServlet {protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {}protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//获取请求的输⼊流InputStream is = request.getInputStream();//读取输⼊流中的数据int leng = 0;byte[] bytes = new byte[1024];while ((leng = is.read(bytes)) != -1) {//先打印控制台看看System.out.println(new String(bytes,0,leng));}}}打印出来的数据:------WebKitFormBoundarypM4ZEsxzVdl0NfZVContent-Disposition: form-data; name="photo"; filename="4-2 鍥剧墖鍒囨崲鏁堟灉[20210508-164643].jpg"Content-Type: image/jpeg反正⼀堆乱码但是头部我们是看的懂的就是⼀些标签的属性和上传的照⽚名字!和⽂件类型!如何解决?请看:FileUpload⼯具的使⽤在实际开发中通常会借助第三⽅⼯具来实现上传功能,应⽤较多的是apache旗下的Commons-fileupload。
java中调用oss的putobject方法 -回复
java中调用oss的putobject方法-回复Java中调用OSS的PutObject方法一、引言在互联网时代,数据存储与传输已经成为企业服务的核心需求之一。
阿里云对象存储服务(OSS)作为一款大规模、高可用、低成本、安全可靠的云存储服务,为企业提供了一种方便快捷的数据存储解决方案。
本文将详细介绍如何在Java中调用OSS的PutObject方法,实现文件的上传。
二、准备工作1. 注册阿里云账号并开通OSS服务首先需要注册一个阿里云账号,并在控制台中开通OSS服务。
创建一个新的Bucket用于存放待上传的文件。
2. 安装和配置Java SDK为了在Java程序中使用OSS服务,我们需要安装阿里云提供的Java SDK。
可以通过Maven或Gradle来添加依赖:Maven:xml<dependency><groupId>com.aliyun.oss</groupId><artifactId>aliyun-sdk-oss</artifactId><version>3.12.0</version></dependency>Gradle:groovyimplementation 'com.aliyun.oss:aliyun-sdk-oss:3.12.0'三、编写代码接下来,我们将编写一个简单的Java程序,演示如何使用PutObject方法上传文件。
1. 导入所需库javaimport com.aliyun.oss.OSS;import com.aliyun.oss.OSSClientBuilder;import java.io.FileInputStream;import java.io.InputStream;2. 初始化OSS客户端javapublic class Main {public static void main(String[] args) {String endpoint = "Your endpoint";String accessKeyId = "Your AccessKeyId";String accessKeySecret = "Your AccessKeySecret";String bucketName = "Your bucket name";创建OSSClient实例。
图片存入mySql数据库
我在程序代码里贴了向Mysql数据库写入image代码的程序,可是好多人都是Java的初学者,对于这段代码,他们无法将它转换成jsp,所以我在这在写一下用jsp怎样向数据库写入图像文件。
大家先在数据库建这样一张表,我下面的这些代码对任何数据库都通用,只要支持blob类型的只要大家将连接数据库的参数改一下就可以了。
SQL>create table image(id int,content varchar(200),image blob);如果在sqlserver2000的数据库中,可以将blob字段换为image类型,这在SqlServer2000中是新增的。
testimage.html文件内容如下:<HTML><HEAD><TITLE>Image File </TITLE><meta http-equiv="Content-Type" content="text/html; charset=gb2312"></HEAD><FORM METHOD=POST ACTION="testimage.jsp"><INPUT TYPE="text" NAME="content"><BR><INPUT TYPE="file" NAME="image"><BR><INPUT TYPE="submit"></FORM><BODY></BODY></HTML>我们在Form的action里定义了一个动作testimage.jsp,它的内容如下:<%@ page contentType="text/html;charset=gb2312"%><%@ page import="java.sql.*" %><%@ page import="java.util.*"%><%@ page import="java.text.*"%><%@ page import="java.io.*"%><html><body><%Class.forName("org.gjt.mm.mysql.Driver").newInstance();Stringurl="jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding= 8859_1";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String content=request.getParameter("content");String filename=request.getParameter("image");FileInputStream str=new FileInputStream(filename);String sql="insert into test(id,content,image) values(1,?,?)"; PreparedStatement pstmt=dbconn.conn.prepareStatement(sql);pstmt.setString(1,content);pstmt.setBinaryStream(2,str,str.available());pstmt.execute();out.println("Success,You Have Insert an Image Successfully");%>下面我写一个测试image输出的例子看我们上面程序写的对不对,testimageout.jsp的内容如下:<%@ page contentType="text/html;charset=gb2312"%><%@ page import="java.sql.*" %><%@ page import="java.util.*"%><%@ page import="java.text.*"%><%@ page import="java.io.*"%><html><body><%Class.forName("org.gjt.mm.mysql.Driver").newInstance();Stringurl="jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding= 8859_1";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String sql = "select image from test where id=1";Statement stmt=null;ResultSet rs=null;try{stmt=conn.createStatement();rs=stmt.executeQuery(sql);}catch(SQLException e){}try {while(rs.next()) {res.setContentType("image/jpeg");ServletOutputStream sout = response.getOutputStream();InputStream in = rs.getBinaryStream(1);byte b[] = new byte[0x7a120];for(int i = in.read(b); i != -1;){sout.write(b);in.read(b);}sout.flush();sout.close();}}catch(Exception e){System.out.println(e);}%></body></html>你运行这个程序,你就会看到刚才你写入美丽的图片就会显示在你面前。
java中的imageio.write 用法 -回复
java中的imageio.write 用法-回复Java中的ImageIO.write用法ImageIO.write是Java提供的一种用于将图像数据写入到指定输出源的方法。
它是javax.imageio.ImageIO类提供的静态方法之一,用于将图像数据以指定的格式写入到输出源中。
在本文中,我们将深入探讨ImageIO.write的用法,并按步骤回答您的问题。
第一步:导入必需的类在使用ImageIO.write之前,我们首先需要导入相关的类。
由于ImageIO 类位于javax.imageio包中,因此我们需要在代码文件的顶部添加import 语句:import javax.imageio.ImageIO;此外,还需要导入关于文件操作的相关类,以便在将图像数据写入到输出源时进行处理。
下面是一个例子:import java.io.File;import java.io.IOException;第二步:准备图像数据在调用ImageIO.write之前,我们需要先准备好要写入到输出源的图像数据。
这可能是从网络上下载的图像,也可以是通过其他方式获取到的图像。
为了简单起见,我们将使用本地文件系统中的图像作为示例。
因此,我们需要先将图像文件读取到内存中。
下面是一个例子:File inputFile = new File("path/to/input/image.jpg"); BufferedImage inputImage = ImageIO.read(inputFile);在这个例子中,我们通过File类创建了一个指向要读取的图像文件的对象,并将其传递给ImageIO.read方法。
这将返回一个BufferedImage对象,其中包含了图像文件的数据。
第三步:指定输出格式接下来,我们需要指定要将图像数据写入到输出源时所需的格式。
ImageIO.write方法提供了许多支持的图像格式,例如JPEG、PNG、GIF 等。
Java通用文件上传功能实现
Java通用文件上传功能实现一、文件上传流程说明:Java文件上传功能是指在Java开发中,实现文件上传的功能,可以用于各种场景,如网站上传图片、文件管理系统等。
以下是一种常见的实现方式:1、创建一个包含文件上传功能的表单页面,用户可以选择要上传的文件并提交表单。
2、在后端Java代码中,接收表单提交的文件数据。
可以使用Apache Commons FileUpload库或Spring框架提供的MultipartFile类来处理文件上传。
3、对接收到的文件进行处理,可以将文件保存到服务器的指定位置,或者将文件存储到数据库中。
4、返回上传成功或失败的信息给用户。
二、代码实现,方案一:在Java中实现文件上传功能可以通过以下步骤来完成:1、创建一个HTML表单,用于选择要上传的文件:<form action="upload"method="post" enctype="multipart/form-data"> <input type="file" name="file" /><input type="submit" value="Upload" /></form>2、创建一个Servlet或者Controller来处理文件上传请求:@WebServlet("/upload")public class UploadServlet extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) {// 获取上传的文件Part filePart = request.getPart("file");String fileName = filePart.getSubmittedFileName();// 指定上传文件的保存路径String savePath = "C:/uploads/" + fileName;// 将文件保存到指定路径filePart.write(savePath);// 返回上传成功的消息response.getWriter().println("File uploaded successfully!");}}3、配置web.xml(如果使用传统的Servlet方式)或者使用注解(如果使用Servlet 3.0+)来映射Servlet。
JSP上传图片到数据库的例子
现在想写个程序向数据库中插入图片路径(或则插入图片也可以)最好是插入图片的路径这样可插入任意大的图片...请高手指点一下思路..感激不尽1.通过显示层向数据库中插入图片2.在界面显示的时候是小图片(缩小过的)3.当点击查看大图片会显示图片(原来的大小)提供给你图片上传和显示的代码吧!希望对你有帮助我在程序代码里贴了向Mysql数据库写入image代码的程序,可是好多人都是Java的初学者,对于这段代码,他们无法将它转换成jsp,所以我在这在写一下用jsp怎样向数据库写入图像文件。
大家先在数据库建这样一张表,我下面的这些代码对任何数据库都通用,只要支持blob类型的只要大家将连接数据库的参数改一下就可以了。
SQL> create table image(id int,content varchar(200),image blob);如果在sqlserver2000的数据库中,可以将blob字段换为image类型,这在SqlServer2000中是新增的。
testimage.html文件内容如下:<HTML><HEAD><TITLE> Image File </TITLE><meta http-equiv= "Content-Type " content= "text/html; charset=gb2312 "></HEAD><FORM METHOD=POST ACTION= "testimage.jsp "><INPUT TYPE= "text " NAME= "content "> <BR><INPUT TYPE= "file " NAME= "image "> <BR><INPUT TYPE= "submit "> </FORM><BODY></BODY></HTML>我们在Form的action里定义了一个动作testimage.jsp,它的内容如下:<%@ page contentType= "text/html;charset=gb2312 "%><%@ page import= "java.sql.* " %><%@ page import= "java.util.* "%><%@ page import= "java.text.* "%><%@ page import= "java.io.* "%><html><%Class.forName( "org.gjt.mm.mysql.Driver ").newInstance();String url= "jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding=885 9_1 ";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String content=request.getParameter( "content ");String filename=request.getParameter( "image ");FileInputStream str=new FileInputStream(filename);String sql= "insert into test(id,content,image) values(1,?,?) ";PreparedStatement pstmt=dbconn.conn.prepareStatement(sql);pstmt.setString(1,content);pstmt.setBinaryStream(2,str,str.available());pstmt.execute();out.println( "Success,You Have Insert an Image Successfully ");%>下面我写一个测试image输出的例子看我们上面程序写的对不对,testimageout.jsp的内容如下:<%@ page contentType= "text/html;charset=gb2312 "%><%@ page import= "java.sql.* " %><%@ page import= "java.util.* "%><%@ page import= "java.text.* "%><%@ page import= "java.io.* "%><html><body><%Class.forName( "org.gjt.mm.mysql.Driver ").newInstance();String url= "jdbc:mysql://localhost/mysql?user=root&password=&useUnicode=true&characterEncoding=885 9_1 ";//其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改Connection conn= DriverManager.getConnection(url);String sql = "select image from test where id =1 ";Statement stmt=null;ResultSet rs=null;try{stmt=conn.createStatement();rs=stmt.executeQuery(sql);}catch(SQLException e){}while(rs.next()) {res.setContentType( "image/jpeg ");ServletOutputStream sout = response.getOutputStream();InputStream in = rs.getBinaryStream(1);byte b[] = new byte[0x7a120];for(int i = in.read(b); i != -1;){sout.write(b);in.read(b);}sout.flush();sout.close();}}catch(Exception e){System.out.println(e);}%></body></html>你运行这个程序,你就会看到刚才你写入美丽的图片就会显示在你面前。
JavaMultipartFile实现上传文件上传图片
JavaMultipartFile实现上传⽂件上传图⽚1. 判断允许上传⽂件的⽂件后缀/图⽚后缀/相⽚后缀和其它⼯具类import ponent;import java.io.File;import java.util.Arrays;import java.util.List;@Componentpublic class FileUtil {public static final List<String> IMAGE_EXTENSIONS = Arrays.asList(".jpg", ".jpeg", ".png");}import java.util.UUID;public class CommonUtil {public static String getUUID() {String uuid = UUID.randomUUID().toString().replaceAll("-", "");return uuid;}}import java.time.LocalDateTime;import java.time.format.DateTimeFormatter;public class DateUtil {public static final String HH = "HH";public static final String YYYY_MM_DD = "yyyy-MM-dd";public static final DateTimeFormatter FORMATTER_HH = DateTimeFormatter.ofPattern(HH);public static final DateTimeFormatter FORMATTER_YYYY_MM_DD = DateTimeFormatter.ofPattern(YYYY_MM_DD);public static String getHH() {return FORMATTER_HH.format(LocalDateTime.now());}public static String getYYYYMMDD() {return FORMATTER_YYYY_MM_DD.format(LocalDateTime.now());}}2. 上传接⼝@PostMapping("/updateImage.do")public Map<String, String> updateImage(@RequestParam("image") MultipartFile[] multfiles) {Map<String, String> result = new HashMap<>();if (multfiles.length == 0) {result.put("message", "请选择图⽚!");return result;}// 源⽂件名称final String originalFileName = multfiles[0].getOriginalFilename();if (StringUtils.isBlank(originalFileName)) {result.put("message", "请选择图⽚!");return result;}// ⽂件后缀[.jpg]final String suffix = originalFileName.substring(stIndexOf(".")).toLowerCase();if (!FileUtil.IMAGE_EXTENSIONS.contains(suffix)) {result.put("message", "图⽚格式错误!");return result;}String lastFilePath;String newFileName = CommonUtil.getUUID() + suffix;String folderName = File.separator + "temp" + File.separator;String relativePath = folderName + DateUtil.getYYYYMMDD() + File.separator + DateUtil.getHH();String filePath = "D:\\file" + relativePath;String fileUrl = null;File targetFile = new File(filePath);if (!targetFile.exists()) {targetFile.mkdirs();}FileOutputStream out = null;try {lastFilePath = filePath + File.separator + newFileName;out = new FileOutputStream(lastFilePath);out.write(multfiles[0].getBytes());fileUrl = "http://127.0.0.1:9000" + relativePath + File.separator + newFileName;} catch (Exception e) {e.printStackTrace();} finally {if (out != null) {try {out.flush();} catch (IOException e) {e.printStackTrace();}try {out.close();} catch (IOException e) {e.printStackTrace();}}}if (fileUrl == null) {result.put("message", "图⽚上传失败!");return result;}result.put("message", "上传成功!");result.put("url", fileUrl);return result;}3. 上传成功url => http://127.0.0.1:9000/temp/2019-09-12/14/0eac00b96f134652b34172e84febe8d1.jpg以上就是Java MultipartFile实现上传⽂件/上传图⽚的详细内容,更多关于Java MultipartFile上传⽂件的资料请关注其它相关⽂章!。
jimageupload的用法
jimageupload的用法jImageUpload是一个简单且易于使用的Java图像上传库。
它为开发人员提供了一种便捷的方式来实现图像上传功能。
以下是jImageUpload的几种用法:1. 添加依赖:要在项目中使用jImageUpload,首先需要在项目的构建文件中添加相应的依赖。
例如,如果您使用Maven构建项目,可以在pom.xml文件中添加以下依赖项:```<dependency><groupId>com.github.wangtonghe</groupId><artifactId>jimageupload</artifactId><version>1.0.0</version></dependency>```2. 初始化jImageUpload:要使用jImageUpload,在您的Java代码中导入jImageUpload库,并创建一个jImageUpload对象。
您可以通过调用`JImageUpload()`构造函数来实现。
```javaimport com.github.wangtonghe.jimageupload.JImageUpload;public class Main {public static void main(String[] args) {JImageUpload jImageUpload = new JImageUpload();// 其他代码...}}```3. 设置上传配置:在使用jImageUpload之前,您可以对上传过程进行配置。
例如,您可以设置上传文件的最大大小、允许的文件类型等参数。
以下是一个示例:```javaimport com.github.wangtonghe.jimageupload.JImageUpload;import com.github.wangtonghe.jimageupload.config.UploadConfig;public class Main {public static void main(String[] args) {JImageUpload jImageUpload = new JImageUpload();UploadConfig uploadConfig = new UploadConfig();uploadConfig.setMaxSize(10 * 1024 * 1024); // 设置上传文件的最大大小为10MBuploadConfig.setAllowedTypes("jpg", "png", "gif"); // 仅允许上传jpg、png、gif 文件jImageUpload.setUploadConfig(uploadConfig);// 其他代码...}}```4. 处理上传请求:使用jImageUpload的一个主要目的是处理图像上传请求。
jimageupload的用法
jimageupload的用法(最新版)目录1.jimageupload 的简介2.jimageupload 的安装与配置3.jimageupload 的基本使用方法4.jimageupload 的高级功能与应用5.jimageupload 的优点与局限性正文【1.jimageupload 的简介】jimageupload 是一款基于 Java 的开源图片上传插件,适用于各种Web 应用程序。
它可以轻松实现图片的上传、裁剪、缩放等操作,为网站开发者提供了便捷的图片处理解决方案。
【2.jimageupload 的安装与配置】安装 jimageupload 非常简单,只需将其 JAR 文件添加到应用程序的类路径中即可。
配置方面,jimageupload 提供了丰富的配置选项,可以通过 XML 文件进行设置。
开发者可以根据需要调整参数,例如上传文件的大小限制、临时文件存储路径等。
【3.jimageupload 的基本使用方法】使用 jimageupload 进行图片上传,主要分为以下几个步骤:1) 在 HTML 页面中创建一个表单,包含一个文件输入框,用于选择要上传的图片文件。
2) 在服务器端,处理上传请求,使用 jimageupload 的相关类来处理上传的图片。
3) 对上传成功的图片进行处理,例如保存到服务器、生成缩略图等。
【4.jimageupload 的高级功能与应用】除了基本的上传功能,jimageupload 还提供了许多高级功能,如图片裁剪、缩放、旋转等。
这些功能可以帮助开发者轻松实现图片的处理和优化,提高用户体验。
【5.jimageupload 的优点与局限性】优点:1) 开源免费,使用成本低。
2) 功能丰富,满足大部分图片上传需求。
3) 易于集成,支持多种服务器环境。
局限性:1) 相较于一些开源图片处理库,jimageupload 的文档较少,学习成本较高。
2) 对于一些特殊的图片处理需求,可能需要额外的自定义开发。
java 读取并保存excel中的图片件
java 读取并保存excel中的图片收藏/** 保存excel中的图片(以文件形式保存,或者存入数据库)** basePath:应用所在路径,附件存放路径:* 参数:is是上传的附件文件流*/public void saveSheetImgByFile(String basePath,InputStream is) throws ParseException { FileOutputStream os = null;try {Workbook wbk = Workbook.getWorkbook(is);//建文件目录File mkFile = new File(basePath);if (!mkFile.exists() && !mkFile.isDirectory()) {mkFile.mkdirs();}// 循环所有sheetfor (int k = 0; k < wbk.getNumberOfSheets(); k++) {Sheet sheet = wbk.getSheet(k);// 共有多少行int imgNumber = sheet.getNumberOfImages();// 获得sheet所包含的图片数// 循环sheet的所有图片for (int i = 0; i < imgNumber; i++) {Image image = sheet.getDrawing(i);byte[] imageData = image.getImageData();String fileName = image.getImageFile().getName().trim()+ ".jpg";File file = new File(basePath+"/" + fileName);os = new FileOutputStream(file);// 建立一个上传文件的输出流os.write(imageData, 0, imageData.length);// 将文件写入服务器}}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();} finally {try {if (os != null) {os.close();}} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}/** 将excel图片文件保存到数据库*/public void saveSheetImgByDB(InputStream is) throws ParseException,ClassNotFoundException, SQLException, IOException {Class.forName("com.mysql.jdbc.Driver");Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/数据库名?characterEncoding=utf8", "root", "root");String INSERT_PICTURE = "insert into t_mypicture(name, photo) values (?, ?)";PreparedStatement ps = null;FileOutputStream os = null;try {Workbook wbk = Workbook.getWorkbook(is);// 循环所有sheetfor (int k = 0; k < wbk.getNumberOfSheets(); k++) {Sheet sheet = wbk.getSheet(k);// 共有多少行int imgNumber = sheet.getNumberOfImages();// 获得sheet所包含的图片数// 循环sheet的所有图片for (int i = 0; i < imgNumber; i++) {Image image = sheet.getDrawing(i);byte[] imageData = image.getImageData();String fileName = image.getImageFile().getName().trim() + ".jpg";conn.setAutoCommit(false);ps = conn.prepareStatement(INSERT_PICTURE);ps.setString(1, fileName);ps.setBytes(2, imageData);ps.executeUpdate();mit();}}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();} finally {try {if (os != null) {os.close();}} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}2.action方法调用:ImportExcelUtil ieu = new ImportExcelUtil();ExcelForm excelForm = (ExcelForm) form;FormFile file = excelForm.getExcelFile();// 附件方式保存String basePath = request.getSession().getServletContext().getRealPath( "/")+"excelFile";try {ieu.saveSheetImgByFile(basePath,file.getInputStream());} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}// 数据库方式保存try {ieu.saveSheetImgByDB(file.getInputStream());} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}引文来源java 读取并保存excel中的图片- LIUJIMMY的专栏- CSDN博客。
java调用接口将接口数据落到数据库的通用方法
java调用接口将接口数据落到数据库的通用方法【深入探索java调用接口将接口数据落到数据库的通用方法】导语:在当今信息化的时代,各种系统间相互通信已成为常态,而数据的处理与存储也变得尤为重要。
对于使用Java编程语言的软件开发者来说,实现将接口数据落到数据库的通用方法成为了一项非常关键的任务。
但是,如何高效、准确地处理数据,并将其持久化到数据库中,是一个复杂而繁琐的问题。
本文将深入探讨这一主题,从简单到复杂、由浅入深地探究java调用接口将接口数据落到数据库的通用方法。
一、理解接口调用与数据落地1. 接口调用在软件开发中,接口调用是不可或缺的一环。
接口调用可以使软件系统更加与外部系统进行交互,实现数据的共享和交换。
Java作为一种通用的编程语言,提供了丰富的类和接口来支持接口调用。
2. 数据落地数据落地是指将接口数据保存到数据库中,实现数据的持久化。
数据库作为数据的容器,承担着数据存储和检索的任务。
对于数据使用频繁的应用程序而言,将数据落地到数据库中可以提高数据的访问效率和数据的安全性。
二、实现数据落地的基本步骤要实现Java调用接口将接口数据落到数据库的通用方法,需要经历以下基本步骤:1. 获取接口数据要将接口数据落地到数据库,首先需要获取接口数据。
可以通过网络请求、接口调用或其他方式获取到接口返回的数据。
2. 解析接口数据获取到接口数据之后,需要对其进行解析。
根据数据的格式,可以选择使用各种解析工具,如JSON解析器、XML解析器等,将接口数据解析为统一的数据格式,以便后续的数据处理。
3. 数据处理解析接口数据之后,需要对数据进行处理。
这个过程包括数据清洗、数据转换等操作。
根据具体的业务需求和数据格式,可以使用相应的数据处理工具或自行编写代码来完成这一步骤。
4. 数据持久化数据处理完成之后,接下来就是将数据持久化到数据库中。
可以使用Java提供的数据库访问API,如JDBC、Hibernate等,通过编写相应的SQL语句或使用ORM框架来完成数据的插入、更新等操作。
java学习案例-上传文件
客户端向服务端上传文件【案例介绍】1.案例描述编写一个客户端向服务端上传文件的程序,要求使用TCP通信的的知识,将本地机器输入的路径下的文件上传到D盘中名称为upload的文件夹中。
并把客户端的IP地址加上count标识作为上传后文件的文件名,即IP(count)的形式。
其中,count随着文件的增多而增大,例如127.0.0.(1).jpg、127.0.0.(2).jpg。
2.效果显示上传文件之前上传文件之后【案例目标】●学会分析“文件上传”思路。
●根据思路独立完成“文件上传”任务的源代码编写、编译及运行。
●掌握网络通信中TCP协议的编程原理。
●掌握TCP网络通信ServerSocket和Socket的使用。
●掌握多线程的使用。
【案例分析】(1)根据任务描述中使用TCP通信的知识实现文件上传功能可知,要实现此功能,需要定义一个服务器接收文件的程序和一个客户端上传文件的程序。
(2)首先要编写服务器端程序来接收文件。
服务器端需要使用ServerSocket对象的accept()方法接收客户端的请求,由于一个服务器可能对于多个客户端,所以当客户端与服务器端简历连接后,服务器需要单独开启一个新的线程来处理与客户端的交互,这时需要在服务器端编写开启新线程的方法。
在新线程的方法中,需要获取客户端的端口号,并且使用输入输出流来传输文件到指定的目录中。
(3)编写客户端的功能代码,客户端功能的实现,因为是用户自己输入上传文件。
所以要定义键盘录入。
录入后需要使用Socket类来创建客户对象,并通过输入输出流来定义指定的文件。
(4)最后我们启动程序,先启动服务端程序,再运行客户端程序来测试上传的结果。
【案例实现】(1)首先编写服务器端的程序,用来接收文件,其代码具体如下所示。
FileServer.java1 package chapter0903;2 import java.io.File;3 import java.io.FileOutputStream;4 import java.io.InputStream;5 import java.io.OutputStream;6 import .ServerSocket;7 import .Socket;8 public class FileServer {9 public static void main(String[] args) throws Exception {10 //创建ServerSocket对象11 ServerSocket serverSocket = new ServerSocket(10001);12 while (true) {13 // 调用accept()方法接收客户端请求,得到Socket对象14 Socket s = serverSocket.accept();15 // 每当和客户端建立Socket连接后,单独开启一个线程处理和客户端的交互16 new Thread(new ServerThread(s)).start();17 }18 }19 }20 class ServerThread implements Runnable {21 // 持有一个Socket类型的属性22 private Socket socket;23 // 构造方法中把Socket对象作为实参传入24 public ServerThread(Socket socket) {25 this.socket = socket;26 }27 public void run() {28 // 获取客户端的IP地址29 String ip = socket.getInetAddress().getHostAddress();30 // 上传图片个数31 int count = 1;32 try {33 InputStream in = socket.getInputStream();34 // 创建上传图片目录的File对象35 File parentFile = new File("D:\\upload\\");36 // 如果不存在,就创建这个目录37 if (!parentFile.exists()) {38 parentFile.mkdir();39 }40 // 把客户端的IP地址作为上传文件的文件名41 File file = new File(parentFile, ip + "(" + count +42 ").jpg");43 while (file.exists()) {44 // 如果文件名存在,则把count++45 file = new File(parentFile, ip + "(" + (count++) +46 ").jpg");47 }48 // 创建FileOutputStream对象49 FileOutputStream fos = new FileOutputStream(file);50 // 定义一个字节数组51 byte[] buf = new byte[1024];52 // 定义一个int类型的变量len,初始值为053 int len = 0;54 // 循环读取数据55 while ((len = in.read(buf)) != -1) {56 fos.write(buf, 0, len);57 }58 // 获取服务端的输出流59 OutputStream out = socket.getOutputStream();60 // 上传成功后向客户端写出“上传成功”61 out.write("上传成功".getBytes());62 // 关闭输出流对象63 fos.close();64 // 关闭Socket对象65 socket.close();66 } catch (Exception e) {67 throw new RuntimeException(e);68 }69 }70 }运行结果如图所示。
java中关于json传图片的方法
java中关于json传图⽚的⽅法摘录⾃: ⼀般来说传图⽚可以以流的形式来传输,即便是⽤json传输,⼀般也都是传⼀个地址,⽽图⽚都存在服务器上,然后顺着地址发送请求下载图⽚。
但是这次公司的项⽬中,图⽚是存在oracle数据库中的blob字段的,并没有存在服务器上,也就是说我必须传图⽚本⾝过去,⽽json是⽆法传输⼆进制的⽂本格式,因此我就想将图⽚转为字符串形式传输,然后对⽅再解码然后转换回来就⾏了。
我的⽅法分三个步骤: 1.将图⽚转为字节数组 2.将字节数组转为字符串 3.压缩字符串,放⼊json传输 ⾸先是第⼀步,将图⽚转为字节数组,代码如下:1 /**2 * 将图⽚转换为字节数组3 * @return4 */5 private byte[] loadImage(File file){6 //⽤于返回的字节数组7 byte[] data=null;8 //打开⽂件输⼊流9 FileInputStream fin=null;10 //打开字节输出流11 ByteArrayOutputStream bout=null;12 try{13 //⽂件输⼊流获取对应⽂件14 fin=new FileInputStream(file);15 //输出流定义缓冲区⼤⼩16 bout=new ByteArrayOutputStream((int)file.length);17 //定义字节数组,⽤于读取⽂件流18 byte[] buffer=new byte[1024];19 //⽤于表⽰读取的位置20 int len=-1;21 //开始读取⽂件22 while((len=fin.read(buffer))!=-1){23 //从buffer的第0位置开始,读取⾄第len位置,结果写⼊bout24 bout.write(buffer,0,len);25 }26 //将输出流转为字节数组27 data=bout.toByteArray();28 //关闭输⼊输出流29 fin.close();30 bout.close();31 }catch(Exception e){32 e.printStackTrace();33 }34 return data;35 } 然后是第⼆步,将字节数组转为字符串1 /**2 * 把字节数组转化为字符串----"ISO-8859-1"3 * @param date4 * @return5 */6 private String byteToString(byte[] data){7 String dataString=null;8 try{9 //将字节数组转为字符串,编码格式为ISO-8859-110 dataString=new String(data,"ISO-8859-1");11 }catch(Exception e){12 e.printStackTrace();13 }14 return dataString;15 } 接下来就是最后⼀步,将字符串压缩后返回1 /**2 * 压缩字符串----"ISO-8859-1"3 * @param data4 * @return5 */6 private String compress(String data){7 String finalData=null;8 try{9 //打开字节输出流10 ByteArrayOutputStream bout=new ByteArrayOutputStream();11 //打开压缩⽤的输出流,压缩后的结果放在bout中12 GZIPOutpuStream gout=new GZIPOutputStream(bout);13 //写⼊待压缩的字节数组14 gout.write(data.getBytes("ISO-8859-1"));15 //完成压缩写⼊16 gout.finish();17 //关闭输出流18 gout.close();19 finalData=bout.toString("ISO-8859-1");20 }catch(Exception e){21 e.printStackTrace();22 }23 return finalData;24 } 以上就是我所⽤的⽅法,有些不熟悉的地⽅习惯于⼀句话⼀个注释算是我的习惯吧,可能会让⼈看起来⽐较乱,请不要介意,⽽且有些注释都是我⾃⼰猜测的,并不⼀定准确,如果错了还请指出来,谢谢了! 然后说下我当时写这⽅法的⼀些琐碎的事情吧,当时⼀开始我确实是想着转字符串传输,但是毕竟没写过,因此也在⽹上查阅过,百度上很多都说转Base64格式字符串传输,我试了很多遍,然⽽可能是我哪⾥写的不对,导致⼀直没有成功,我的测试⽅法是从数据库中取出那个blob字段的数据,然后经过转化压缩,然后在本地⽣成⼀个图⽚,但是最终我发现那个图⽚都是打不开的,提⽰⽂件错误或损坏,并且图⽚⼤⼩也有点怪异,估计是我哪⾥代码写的不对吧。
java中的imageio.write 用法 -回复
java中的imageio.write 用法-回复Java中的imageio.write用法是用来将图片数据写入到指定的文件中。
该方法是Java标准库提供的一个较为常用的图像处理方法,它可以将一张图片保存到本地文件系统中,或者将图片数据写入到其他容器中,比如内存中的字节数组、数据库等。
在Java中,使用imageio.write方法需要先加载相关的图像处理库,具体的操作流程如下:1. 导入相关库首先,需要导入Java标准库中的javax.imageio包和java.io包,以便使用相关的类和方法。
在代码的开头,使用import语句导入这两个包:javaimport javax.imageio.ImageIO;import java.io.*;2. 加载图片使用ImageIO类的静态方法read来加载图片文件。
read方法接受一个File对象作为参数,该对象表示待读取的图片文件。
读取成功后,read方法会返回一个BufferedImage 对象,它包含了图片的所有像素数据:javaFile inputFile = new File("input.jpg");BufferedImage bufferedImage = ImageIO.read(inputFile);3. 写入图片使用ImageIO类的静态方法write来将图片数据写入到指定的文件中。
write方法接受三个参数:一个BufferedImage 对象、一个表示输出文件的字符串和一个表示图片格式的字符串。
代码示例如下:javaFile outputFile = new File("output.jpg");ImageIO.write(bufferedImage, "jpg", outputFile);在写入图片时,需要注意输出文件的路径和文件名。
如果文件不存在,write 方法会自动创建一个新文件;如果文件已存在,write方法会覆盖原文件。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
《摘抄1》PostgreSQL7.4文档Prev Fast Backward Chapter31.JDBC接口Fast Forward Next31.7.存储二进制数据PostgreSQL提供两种不同的方法存储二进制数据。
二进制数据可以使用二进制数据类型bytea存储在表中,或者使用大对象特性,该特性以一种特殊的格式将二进制数据存储在一个独立的表中,然后通过在你的表中保存一个指向该表的类型为oid的数值来引用它。
为了判断那种方法比较合适,你必须理解每种方法的局限。
bytea数据类型并不适合存储非常大数量的二进制数据。
虽然类型为bytea的字段可以存储最多1G字节的二进制数据,但是这样它会要求数量巨大的内存来处理这样巨大的数值。
存储二进制的大对象的方法更适合存储非常大的数值,但也有自己的局限。
特别是删除一个包含大对象引用的行并未删除大对象。
删除大对象是一个需要执行的独立的操作。
大对象还有一些安全性的问题,因为任何联接到数据库的人都可以查看或者更改大对象,即使他们没有查看/更新包含大对象引用的行的权限也一样。
版本7.2是第一个支持bytea类型的JDBC驱动版本。
在7.2中引入的这个功能同时也引入了一个和以往的版本不同的行为。
自7.2以来,方法getBytes(),setBytes(),getBinaryStream()和setBinaryStream()操作bytea类型。
在7.1和更早的版本里这些方法操作和OID类型关联的大对象。
我们可以通过在Connection上设置compatible 属性为数值7.1来获取旧的7.1的行为。
要使用bytea数据类型你只需要使用getBytes(),setBytes(),getBinaryStream(),或者setBinaryStream()方法。
要使用大对象的功能,你可以使用PostgreSQL JDBC驱动提供的LargeObject类,或者使用getBLOB()和setBLOB()方法。
Important:你必须在一次SQL事务内访问大对象。
你可以通过调用setAutoCommit(false)打开一个事务。
注意:在将来的JDBC驱动中,getBLOB()和setBLOB()方法可能不再操作大对象,而是将处理bytea数据类型。
因此如果你要用大对象,我们建议你使用LargeObject API。
Example31-8包含一些有关如何用PostgreSQL JDBC驱动处理二进制数据的例子。
Example31-8.在JDBC里处理二进制数据例子比如,假设你有一个表包含一幅图像和它的文件名,并且你还想在bytea字段里存储图像∶CREATE TABLE images(imgname text,img bytea);要插入一幅图象,你可以:File file=new File("myimage.gif");FileInputStream fis=new FileInputStream(file);PreparedStatement ps=conn.prepareStatement("INSERT INTO images VALUES(?,?)"); ps.setString(1,file.getName());ps.setBinaryStream(2,fis,file.length());ps.executeUpdate();ps.close();fis.close();这里,setBinaryStream()把来自一个流的一些数目的字节转换成类型bytea的字段。
如果图像的内容已经放在byte[]里面了,那么你也可以用setBytes()方法干这件事。
检索一幅图象甚至更容易(我在这里使用PreparedStatement,当然用Statement也是一样的):PreparedStatement ps=con.prepareStatement("SELECT img FROM images WHERE imgname =?");ps.setString(1,"myimage.gif");ResultSet rs=ps.executeQuery();if(rs!=null){while(rs.next()){byte[]imgBytes=rs.getBytes(1);//从这开始使用数据}rs.close();}ps.close();这里的二进制数据是以byte[]形式检索的。
你也可以使用一个InputStream。
另外你可能会需要存储一个非常大的文件,因此希望使用LargeObject类存储该文件∶CREATE TABLE imageslo(imgname text,imgOID oid);要插入一个图像,你可以用∶//所有大对象API调用都必须在一次事务中conn.setAutoCommit(false);//获取大对象管理器以便进行操作LargeObjectManager lobj=((org.postgresql.PGConnection)conn).getLargeObjectAPI();//创建一个新的大对象int oid=lobj.create(LargeObjectManager.READ|LargeObjectManager.WRITE);//打开一个大对象进行写LargeObject obj=lobj.open(oid,LargeObjectManager.WRITE);//现在打开文件File file=new File("myimage.gif");FileInputStream fis=new FileInputStream(file);//从文件拷贝数据到大对象byte buf[]=new byte[2048];int s,tl=0;while((s=fis.read(buf,0,2048))>0){obj.write(buf,0,s);tl+=s;}//关闭大对象obj.close();//现在向imgeslo插入行PreparedStatement ps=conn.prepareStatement("INSERT INTO imageslO VALUES(?,?)"); ps.setString(1,file.getName());ps.setInt(2,oid);ps.executeUpdate();ps.close();fis.close();从大对象中检索图像∶//所有LargeObject API调用都必须在一个事务里conn.setAutoCommit(false);//获取大对象管理器以便进行操作LargeObjectManager lobj=((org.postgresql.PGConnection)conn).getLargeObjectAPI();PreparedStatement ps=con.prepareStatement("SELECT imgoid FROM imageslO WHERE imgname=?");ps.setString(1,"myimage.gif");ResultSet rs=ps.executeQuery();if(rs!=null){while(rs.next()){//打开大对象读int oid=rs.getInt(1);LargeObject obj=lobj.open(oid,LargeObjectManager.READ);//读取数据byte buf[]=new byte[obj.size()];obj.read(buf,0,obj.size());//在这里对读取的数据做些处理//关闭对象obj.close();}rs.close();}ps.close();Prev Home Next创建和更改数据库对象Up PostgreSQL对JDBC API的扩展《摘抄2》postgreSQL中怎样建个带图片字段的表啊?postgreSQL中怎样建个带图片字段的表啊?是不是这样啊:create table test(id int4not null,name varchar(10)not null,tupian BLOB,primary key(id));如不是那应该是怎么建啊?zug发表于2004-02-2508:45postgreSQL中怎样建个带图片字段的表啊?引用原帖由"marszxy"发表:postgreSQL中怎样建个带图片字段的表啊?是不是这样啊:create table test(id int4not null,name varchar(10)not null,tupian BLOB,primary key(id));如不是那应该是怎么建啊?BLOB在PG中没有。
可以用三种方式存图片1.使用大对象create table test(id int4not null,name varchar(10)not null,tupian oid,primary key(id));2.使用Text字段将二进制图片用BASE64编码存为字符串create table test(id int4not null,name varchar(10)not null,tupian text,primary key(id));3.用二进制数组byteacreate table test(id int4not null,name varchar(10)not null,tupian bytea,primary key(id));以上三种方式(第一种属过时的方法,且操作稍复杂)都可以存图片或其它任何格式的数据长度好象是2G的限制。
netkiller发表于2004-02-2515:36postgreSQL中怎样建个带图片字段的表啊?TEXT BASE64那个,不太好.BASE64后.文件会增大很多..还有编码/解码.这个过程也浪费资源..。