热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于Java中两种jersey文件上传方式

这篇文章主要介绍了基于Java中两种jersey文件上传方式的相关资料,需要的朋友可以参考下本文将带领大家使用基于JAX-RSREST风格的实现Jersey来上传文件到服务器制定的

这篇文章主要介绍了基于Java中两种jersey文件上传方式的相关资料,需要的朋友可以参考下

本文将带领大家使用基于JAX-RS REST风格的实现Jersey来上传文件到服务器制定的文件夹,如果是图片并读取显示出该图片。

准备工作:准备一个form表单,有两个字段,一个是type=”file”和type=”text”,并且表单需要使用POST方式提交。注意改表单需要使用multipart/form-data。该项目使用netbeans8.0和glassfish4.0开发和运行。并且使用maven管理该工程;需要在您的C盘建立一个文件夹,用来存储上传的文件。如C:\Newsportal\article_images开发环境:1 创建工程 在你项目空白处右键-》点击新建项目

            

2 在创建的项目中选择maven-》点击右侧web应用程序

3 填写工程的名字和maven的组ID和包名

4 选择该项目的运行环境为服务器Glassfish server

5 最后点击完成
准备搭建jersey的运行环境:
1 配置maven需要依赖包,maven的pom文件依赖如下:
 
 
    4.0.0 
    com.vi8 
    jerseyUploadDemo 
    1.0-SNAPSHOT 
    war 
    jerseyUploadDemo 
     
    jersey上传文件DMEO 
     
     
    ${project.build.directory}/endorsed 
    UTF-8 
     
     
     
     
        org.glassfish.jersey.core 
        jersey-server 
        2.0 
        jar 
        provided 
     
     
        org.glassfish.jersey.ext 
        jersey-mvc-jsp 
        2.0 
        jar 
        provided 
     
     
        org.glassfish.jersey.media 
        jersey-media-json-jackson 
        2.0 
        jar 
        provided 
     
     
     
        org.glassfish.jersey.media 
        jersey-media-multipart 
        2.0 
        provided 
     
     
     
        commons-io 
        commons-io 
        2.4 
     
     
     
        javax 
        javaee-web-api 
        7.0 
        provided 
     
     
 
     
     
         
        org.apache.maven.plugins 
        maven-compiler-plugin 
        3.1 
         
            1.7 
            1.7 
             
            ${endorsed.dir} 
             
         
         
         
        org.apache.maven.plugins 
        maven-war-plugin 
        2.3 
         
            false 
         
         
         
        org.apache.maven.plugins 
        maven-dependency-plugin 
        2.6 
         
             
            validate 
             
                copy 
             
             
                ${endorsed.dir} 
                true 
                 
                 
                    javax 
                    javaee-endorsed-api 
                    7.0 
                    jar 
                 
                 
             
             
         
         
     
     
 
2 配置web.xml用以支持jersey,配置如下:
 
 
     
    JerseyFilter 
    org.glassfish.jersey.servlet.ServletContainer 
     
        javax.ws.rs.Application 
         
        com.vi8.upload.MyApplication 
     
     
        jersey.config.servlet.filter.staticContentRegex 
        /(img|css|js|font)/.* 
     
     
        jersey.config.servlet.filter.forwardOn404 
        true 
     
     
        jersey.config.server.mvc.templateBasePath.jsp 
        /WEB-INF/pages 
     
     
     
    JerseyFilter 
    /* 
     
     
    index.jsp 
     
 
3 编写上面web.xml用到的MyApplication.java 如下:
package com.vi8.upload; 
 
import javax.ws.rs.ApplicationPath; 
import org.glassfish.jersey.jackson.JacksonFeature; 
import org.glassfish.jersey.media.multipart.MultiPartFeature; 
import org.glassfish.jersey.server.ResourceConfig; 
import org.glassfish.jersey.server.mvc.jsp.JspMvcFeature; 
 
/**
 * qq: [email protected]
 *
 * @author Administrator
 */ 
@ApplicationPath(“/”) 
public class MyApplication extends ResourceConfig { 
 
    public MyApplication() { 
    packages(“com.vi8.upload.resources”); 
    register(JspMvcFeature.class); 
    register(JacksonFeature.class); 
    register(MultiPartFeature.class); 
    } 

以上步骤基本就是jersey运行环境准备工作,接下开始讨论文件如何上传的。
jersey文件上传:
1 文件上传的Resource类,你可以理解是spring mvc中控制器。UploadImageResource.java清单代码
package com.vi8.upload.resources; 
 
import java.io.File; 
import java.io.FileInputStream; 
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.OutputStream; 
import java.io.UnsupportedEncodingException; 
import java.util.Calendar; 
import java.util.logging.Level; 
import java.util.logging.Logger; 
import javax.servlet.http.HttpServletResponse; 
import javax.ws.rs.Consumes; 
import javax.ws.rs.GET; 
import javax.ws.rs.POST; 
import javax.ws.rs.Path; 
import javax.ws.rs.PathParam; 
import javax.ws.rs.Produces; 
import javax.ws.rs.core.Context; 
import javax.ws.rs.core.MediaType; 
import org.apache.commons.io.FileUtils; 
import org.glassfish.jersey.media.multipart.ContentDisposition; 
import org.glassfish.jersey.media.multipart.FormDataBodyPart; 
import org.glassfish.jersey.media.multipart.FormDataContentDisposition; 
import org.glassfish.jersey.media.multipart.FormDataMultiPart; 
import org.glassfish.jersey.media.multipart.FormDataParam; 

@Path(“upload”) 
public class UploadImageResource { 
 
    /**
     * Constants operating w来源gaodaimacom搞#^代%!码&网ith images
     */ 
    private static final String ARTICLE_IMAGES_PATH = “c:/Newsportal/article_images/”; 
    private static final String JPG_CONTENT_TYPE = “image/jpeg”; 
    private static final String PNG_CONTENT_TYPE = “image/png”; 
 
    /**
     * 第一种方式上传
     *
     * @param fileInputStream
     * @param disposition
     * @return
     */ 
    @POST 
    @Path(“uploadimage1 “) 
    @Consumes(MediaType.MULTIPART_FORM_DATA) 
    public String uploadimage1(@FormDataParam(“file”) InputStream fileInputStream, 
        @FormDataParam(“file”) FormDataContentDisposition disposition) { 
    String imageName = Calendar.getInstance().getTimeInMillis() 
        + disposition.getFileName(); 
 
    File file = new File(ARTICLE_IMAGES_PATH + imageName); 
    try { 
        //使用common io的文件写入操作 
        FileUtils.copyInputStreamToFile(fileInputStream, file); 
        //原来自己的文件写入操作 
        //saveFile(fileInputStream, file); 
    } catch (IOException ex) { 
        Logger.getLogger(UploadImageResource.class.getName()).log(Level.SEVERE, null, ex); 
    } 
 
    return “images/” + imageName; 
    } 
 
    /**
     * *
     * 第二种方式上传 使用FormDataMultiPart 获取表单数据
     *
     * @param form
     * @param response
     * @return
     * @throws UnsupportedEncodingException
     */ 
    @POST 
    @Path(“uploadimage2”) 
    @Consumes(MediaType.MULTIPART_FORM_DATA) 
    @Produces(MediaType.APPLICATION_JSON) 
    public String uploadimage2(FormDataMultiPart form, @Context HttpServletResponse response) throws UnsupportedEncodingException { 
    //获取文件流 
    FormDataBodyPart filePart = form.getField(“file”); 
    //获取表单的其他数据 
    FormDataBodyPart usernamePart = form.getField(“username”); 
 
    //ContentDisposition headerOfFilePart = filePart.getContentDisposition(); 
    //把表单内容转换成流 
    InputStream fileInputStream = filePart.getValueAs(InputStream.class); 
 
    FormDataContentDisposition formDataCOntentDisposition= filePart.getFormDataContentDisposition(); 
 
    String source = formDataContentDisposition.getFileName(); 
    String result = new String(source.getBytes(“ISO8859-1”), “UTF-8”); 
 
    System.out.println(“formDataContentDisposition.getFileName()result ” + result); 
 
    String filePath = ARTICLE_IMAGES_PATH + result; 
    File file = new File(filePath); 
    System.out.println(“file ” + file.getAbsolutePath()); 
    try { 
        //保存文件 
        FileUtils.copyInputStreamToFile(fileInputStream, file); 
//  saveFile(fileInputStream, file); 
    } catch (IOException ex) { 
        Logger.getLogger(UploadImageResource.class.getName()).log(Level.SEVERE, null, ex); 
    } 
    System.out.println(“” + “images/” + result); 
 
    response.setCharacterEncoding(“UTF-8”); 
    return “images/” + result; 
    } 
 
    /**
     *
     * 不从web服务器去读图片,在磁盘某个目录的文件可以通过流的方式去获取 ,通过 response.getOutputStream()放回数据
     *
     * @param imageName image-name
     * @param type extension of image
     * @param response [email protected] HttpServletResponse}
     * @throws IOException
     */ 
    @GET 
    @Path(“/images/{name}.{type}”) 
    public void showImg(@PathParam(“name”) String imageName, 
        @PathParam(“type”) String type, 
        @Context HttpServletResponse response) 
        throws IOException { 
    System.out.println(“showImg”); 
    try (InputStream in = new FileInputStream(ARTICLE_IMAGES_PATH 
        + imageName + “.” + type)) { 
        FileUtils.copyFile(new File(ARTICLE_IMAGES_PATH + imageName + “.” + type), response.getOutputStream()); 
//      FileCopyUtils.copy(in, response.getOutputStream()); 
    } 
    } 
 
    // 保存文件信息到磁盘  
    private void saveFile(InputStream uploadedInputStream, File file) { 
    System.out.println(“——saveFile—–“); 
    try { 
        OutputStream outpuStream = new FileOutputStream(file); 
        int read = 0; 
        byte[] bytes = new byte[1024]; 
//      outpuStream = new FileOutputStream(new File(serverLocation)); 
        while ((read = uploadedInputStream.read(bytes)) != -1) { 
        outpuStream.write(bytes, 0, read); 
        } 
        outpuStream.flush(); 
        outpuStream.close(); 
    } catch (IOException e) { 
        e.printStackTrace(); 
    } 
    } 

2 当然要测试你也许还需要准备一个带有form表单的jsp文件
 
       

 
            文件 :
 
            用户名:
 
       

 
         
         

结果如下

以上就是本文的全部内容,希望对大家实现jersey文件上传有所帮助。

以上就是基于Java中两种jersey文件上传方式的详细内容,更多请关注gaodaima编程笔记其它相关文章!



推荐阅读
  • 图像因存在错误而无法显示 ... [详细]
  • 在tp5项目中引入ueditor编辑器并实例化后插入图片出现目录创建失败问题在查看网络上各种解决方案之后总结如下:根据官网提示主要是因为图片保存的路径无权限导致,官方文档链接:ht ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 如何在php文件中添加图片?
    本文详细解答了如何在php文件中添加图片的问题,包括插入图片的代码、使用PHPword在载入模板中插入图片的方法,以及使用gd库生成不同类型的图像文件的示例。同时还介绍了如何生成一个正方形文件的步骤。希望对大家有所帮助。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • HTML学习02 图像标签的使用和属性
    本文介绍了HTML中图像标签的使用和属性,包括定义图像、定义图像地图、使用源属性和替换文本属性。同时提供了相关实例和注意事项,帮助读者更好地理解和应用图像标签。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 本文介绍了如何使用JSONObiect和Gson相关方法实现json数据与kotlin对象的相互转换。首先解释了JSON的概念和数据格式,然后详细介绍了相关API,包括JSONObject和Gson的使用方法。接着讲解了如何将json格式的字符串转换为kotlin对象或List,以及如何将kotlin对象转换为json字符串。最后提到了使用Map封装json对象的特殊情况。文章还对JSON和XML进行了比较,指出了JSON的优势和缺点。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
  • AFNetwork框架(零)使用NSURLSession进行网络请求
    本文介绍了AFNetwork框架中使用NSURLSession进行网络请求的方法,包括NSURLSession的配置、请求的创建和执行等步骤。同时还介绍了NSURLSessionDelegate和NSURLSessionConfiguration的相关内容。通过本文可以了解到AFNetwork框架中使用NSURLSession进行网络请求的基本流程和注意事项。 ... [详细]
  • 我尝试使用Vue.js在Laravel中实现imageupload吗?但是,我不知道为什么图像 ... [详细]
author-avatar
看人生愤怒
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有