`

@Marked-common-fileUpload 上传图片到服务器端

阅读更多

今天要用到一个图片上传的,听说Struts2就是用的这个,啃了啃鹰文文档,实验了下common-fileupload实验成功了,记录下:

Servlet里doPost()方法贴出:

/** 大致步骤为:
	 * 1.准备FileItem工厂;
	 * 2.把工厂交给ServletFileUpload,让他把前端的表单条条信息解析;
	 * 3.处理解析好返回的列表中的每一个具体项 */
	@SuppressWarnings("unchecked")
	@Override
	protected void doPost(HttpServletRequest request,
			HttpServletResponse response) throws ServletException, IOException {

		/* FileItemFactory是FileItem的工厂,不过它只是个interface,
		 * 有两个实现DiskFileItemFactory和DefaultFileItemFactory;
		 * 但是api里说:"Deprecated. Use DiskFileItemFactory instead." */
		FileItemFactory itemFactory = new DiskFileItemFactory();
		/* FileUpload类是用来处理文件的上传,而ServletFileUpload是它的子类,
		 * 可以判断和解析前端的表单类型和表单项信息 */
		ServletFileUpload upload = new ServletFileUpload(itemFactory);
		List<FileItem> list = null;
		try {
			//parseRequest将前端的表单项项解析为FileItem列表
			list = upload.parseRequest(request);
			Iterator<FileItem> it = list.iterator();
			while (it.hasNext()) {
				/*
				 * 最核心的就是FileItem了,如果form的属性是enctype=multipart/form-data,
				 * 那么它会用来描述POST请求的form表单的每一个普通表单项和上传项;
				 * 可以认为每一个input对应的就是一个FileItem;看看FileItem的属性封装就知道了(加入客户端有):
				 * 用户<input type="text" name="userName"><br>//普通表单项 
				 * 图片1<input type="file" name="img1"/><br/>//上传项 
				 * 1.getContentType()	//普通表单项null;上传项要看类型如jpg,jpeg是image/jpeg;png是image/png;gif是image/gif:
				 * 2.getFieldName()		//就是前台的name="userName"和name="img1";
				 * 3.getString()		//就是用户填写的用户名,如你在表单里输入"root"提交后getString()就得到root;
				 * 3.getInputStream()	//根据输出判断:普通项是ByteArrayInputStream类型,上传项目是:FileInputStream类型
				 * 4.getName()			//普通表单项null,上传项为出去目录名后的文件名,如:"ubuntuBackground.jpg"
				 * 5.getOutputStream()	//输出流,没有深看
				 * 6.getSize()			//大小:普通为用户输入字符的字节数,上传为文件的大小字节数;
				 * 7.isFormField()		//这个就是判断是普通项[true],还是上传项[false];
				 */
				FileItem item = it.next();
				/* 过滤下,只有表单项中类型为图片的才保存 */
				if ("image/jpeg".equals(item.getContentType())
						|| "image/gif".equals(item.getContentType())
						|| "image/png".equals(item.getContentType())) {
					InputStream inStream = item.getInputStream();
					byte[] b = new byte[1024];
					int rb = inStream.read(b);
					File file=new File("/home/nie/images/", item.getName());
					OutputStream outStream = new FileOutputStream(file);
					while (rb != -1) {
						outStream.write(b);
						rb = inStream.read(b);
					}
					outStream.flush();
					inStream.close();
					outStream.close();
				}
			}
		} catch (FileUploadException e) {
			e.printStackTrace();
		}
	}

     

 总结来看,重要的就3个东西:

1.FileItemFactory【DiskFileItemFactory】;

2.FileUpload【ServletFileUpload】;

3.FileItem

然后就可以用IO了;

1
11
分享到:
评论

相关推荐

    markdown:功能齐全的markdown解析器和编译器,以TypeScript编写

    这是marked的流行库的分支(从chjj / release-0.3.7,2017年12月1日合并合并请求#961)。 郎 目录 安装 npm install @ts-stack/markdown --save 用法 最少使用量: import { Marked } from '@ts-stack/markdown' ...

    marked-toc:已弃用

    如果您将 toc 添加到README.md ,则无需添加[filename] ,只需运行toc 。 用法 var toc = require ( 'marked-toc' ) ; var file = fs . readFileSync ( 'README.md' , 'utf8' ) ; // Generate a TOC toc ( file )...

    marked-linkify-it:使用linkify-it标记网址

    const marked = require ( "marked" ) ; const linkify = require ( "marked-linkify-it" ) ; // or ES Module script // import marked from "https://cdn.jsdelivr.net/gh/markedjs/marked/lib/marked.esm.js"; //...

    marked-0.3.2-1.zip

    标题中的"marked-0.3.2-1.zip"表明这是一个软件库的压缩包,标记为"marked"的版本0.3.2的第一个修正版。Marked通常是一个文本解析库,用于将Markdown语法转换为HTML,它在开发文档、博客和网站中非常常见。Markdown...

    marked-forms:从markdown生成html表单标签和输入控件

    标记形式 Marked.js插件,用于从markdown生成HTML表单输入。 从诸如[text ?input?](name)类的markdown链接生成标签和输入控件...var marked = require ( 'marked' ) ; var markedForms = require ( 'marked-forms' )

    marked-to-md:标记渲染器将 Markdown 渲染为... Markdown

    var marked = require ( 'marked' ) ; var mdRenderer = require ( 'marked-to-md' ) ; var source = '# Markdown to md renderer\nHello world!' ; var tokens = marked . lexer ( source ) ; var mdToMd = parser...

    marked-0.2.10.zip

    totalshare2java.zip,一种提供基于常用的OAuth2的第三个网站登录功能的工具。一种提供基于常用的OAuth2的第三个网站登录功能的工具。

    marked-engine:Express兼容的Markdown渲染由标记提供支持

    marked-engine是兼容的模板引擎,用于呈现Markdown。 安装 $ npm install marked-engine 用法 将marked-engine注册marked-engine扩展名为“ .md”的文件的模板引擎。 app . engine ( 'md' , require ( 'marked-...

    hexo-renderer-marked-plus:hexo-renderer 标记了更独特的标题 ID

    《Hexo-renderer-marked-plus:打造独特标题ID的JavaScript渲染器》 Hexo-renderer-marked-plus是一款针对Hexo博客框架的插件,它的主要功能是为Markdown解析提供更加独特且可定制化的标题ID。这个插件是在hexo-...

    marked-terminal:标记项目的渲染器。 允许您渲染Markdown以打印到终端

    用于自定义渲染器,允许将Markdown打印到终端。 支持漂亮的表格,JavaScript的语法高亮显示以及覆盖所有颜色和样式。 例如,可用于打印使用情况信息。 安装 npm install marked marked-terminal 例子 var marked = ...

    marked.min.js

    开发者在网页中引入这个库之后,就可以利用它的功能将用户输入的Markdown文本渲染成富文本,同时也可以在服务器端进行Markdown到HTML的转换。这个库使用方便,功能强大,支持语法高亮,并且有着丰富的配置选项,可以...

    一款使用marked和highlightjs开发的一款markdown编辑器

    开发者可以通过安装依赖、运行构建命令,将这个项目作为一个模块引入到自己的Vue项目中,或者直接在本地运行开发和测试。 总结,这款Markdown编辑器结合了marked和highlight.js的强大功能,为Vue项目提供了便捷的...

    marked-images:简单的标记渲染器,可在markdown中包含图像属性。 还生成vimeo链接

    var marked = require ( 'marked' ) ;var markedImages = require ( 'marked-images' ) ;// opts are optionalvar opts = { xhtml : false , fqImages : { route : '/images/' , url : '...

    前端项目-marked.zip

    5. **服务器端和客户端兼容**:由于是JavaScript库,marked可以在浏览器端和Node.js服务器端使用,满足前后端共用的需求。 6. **社区与生态系统**:作为一个开源项目,marked拥有活跃的社区,用户可以通过GitHub上...

    uiw-react-md-editor-master_React_源码

    import marked from 'marked'; function MarkdownPreview({ markdownText }) { return &lt;div dangerouslySetInnerHTML={{ __html: marked(markdownText) }} /&gt;; } ``` 此外,为了实现良好的用户体验,编辑器可能还...

    marked-sanitizer-github:一个marked.js的净化器,它以与GitHub相同的方式净化markdown中HTML元素

    $ npm install --save marked-sanitizer-github 用法 它输出一类SanitizeState因为该清理是有状态的。 您可以通过调用getSanitizer()方法来为标记的解析器获取一个消毒剂。 它返回一个要清除的函数对象。 con

    marked-element:标记的库的元素接口

    描述中提到"标记元素仅与聚合物0.5及更低版本兼容,将不推荐使用",这表明marked-element最初是为 Polymer 0.5 设计的,随着Polymer框架的发展,尤其是从0.5版本升级到0.8及更高版本时,这个元素可能不再是最优选择...

Global site tag (gtag.js) - Google Analytics