浅谈如何实现JSP上传图片无组件化
创始人
2024-04-12 07:01:12
0

从JSP页使图片以JPEG编码后存储在指定文件夹中。这种JSP上传图片方式与组件上传相比似乎笨拙而又不能对文件属性进行操作,但的确可以轻松实现JSP上传图片的功能。

uploadimage1.jsp实现构建一个表单,提交用于为图片重命名的参数,以及图片文件。

  1. <%...@ page contentType="text/html; charset=gbk" %>   
  2. <%...@ page language="java" %>   
  3.      
  4.      
  5. </FONT></STRONG>DATABASE<STRONG><FONT color=#006699></< SPAN>TITLE></FONT></STRONG>     <LI><STRONG><FONT color=#006699><meta</FONT></STRONG> <FONT color=#ff0000>http-equiv</FONT>=<FONT color=#0000ff>"Content-Type"</FONT> <FONT color=#ff0000>content</FONT>=<FONT color=#0000ff>"text/html; charset=gb2312"</FONT><STRONG><FONT color=#006699>></FONT></STRONG>     <LI class=alt><STRONG><FONT color=#006699></< SPAN>HEAD></FONT></STRONG>     <LI><STRONG><FONT color=#006699><FORM</FONT></STRONG> <FONT color=#ff0000>METHOD</FONT>=<FONT color=#0000ff>POST</FONT> <FONT color=#ff0000>ACTION</FONT>=<FONT color=#0000ff>"uploadimage2.jsp"</FONT><STRONG><FONT color=#006699>></FONT></STRONG>     <LI class=alt>人物:<STRONG><FONT color=#006699><INPUT</FONT></STRONG> <FONT color=#ff0000>TYPE</FONT>=<FONT color=#0000ff>"text"</FONT> <FONT color=#ff0000>NAME</FONT>=<FONT color=#0000ff>"name"</FONT><STRONG><FONT color=#006699>><BR></FONT></STRONG>   <LI>图片:<STRONG><FONT color=#006699><INPUT</FONT></STRONG> <FONT color=#ff0000>TYPE</FONT>=<FONT color=#0000ff>"file"</FONT> <FONT color=#ff0000>NAME</FONT>=<FONT color=#0000ff>"image"</FONT><STRONG><FONT color=#006699>><BR></FONT></STRONG>     <LI class=alt><STRONG><FONT color=#006699><INPUT</FONT></STRONG> <FONT color=#ff0000>TYPE</FONT>=<FONT color=#0000ff>"submit"</FONT> <FONT color=#ff0000>value</FONT>=<FONT color=#0000ff>"提交"</FONT><STRONG><FONT color=#006699>></FONT></STRONG>   <LI><STRONG><FONT color=#006699></< SPAN>FORM></FONT></STRONG>   <LI class=alt><STRONG><FONT color=#006699></< SPAN>BODY></FONT></STRONG>     <LI><STRONG><FONT color=#006699></< SPAN>HTML></FONT></STRONG>    </LI></OL></PRE> <P>uploadimage1.jsp实现获取用户提交参数为要存储的图片命名,以字符的形式获取上传的图片,进一步转化为输入流,最终完成JSP上传图片的功能。</P><PRE><OL class=dp-xml><LI class=alt><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>contentType</FONT>=<FONT color=#0000ff>"text/html;charset=gb2312"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>     <LI><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"java.util.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>     <LI class=alt><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"java.text.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>     <LI><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"java.io.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>   <LI class=alt><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"com.sun.image.codec.jpeg.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>   <LI><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"java.awt.image.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>   <LI class=alt><STRONG><FONT color=#006699><</FONT></STRONG>%...@ page <FONT color=#ff0000>import</FONT>=<FONT color=#0000ff>"java.awt.*"</FONT>%<STRONG><FONT color=#006699>></FONT></STRONG>   <LI>     <LI class=alt><STRONG><FONT color=#006699><</FONT></STRONG>%...   <LI>  String <FONT color=#ff0000>name</FONT>=<FONT color=#0000ff>request</FONT>.getParameter("name");   <LI class=alt>  <FONT color=#ff0000>name</FONT>=<FONT color=#0000ff>new</FONT> String(name.getBytes("ISO-8859-1"));    <LI>  String <FONT color=#ff0000>ima</FONT>=<FONT color=#0000ff>request</FONT>.getParameter("image");    <LI class=alt> <LI>  try{   <LI class=alt>  String <FONT color=#ff0000>path</FONT>=<FONT color=#0000ff>request</FONT>.getRealPath("/");   <LI>  FileOutputStream <FONT color=#ff0000>ot</FONT> = <FONT color=#0000ff>new</FONT> FileOutputStream(path+name+".jpg");   <LI class=alt>// ServletOutputStream <FONT color=#ff0000>ot</FONT>=<FONT color=#0000ff>response</FONT>.getOutputStream(); //也可以直接输出显示   <LI>  FileInputStream <FONT color=#ff0000>in</FONT>=<FONT color=#0000ff>new</FONT> FileInputStream(ima);     <LI class=alt>  JPEGImageDecoder <FONT color=#ff0000>jpgCodec</FONT> = <FONT color=#0000ff>JPEGCodec</FONT>.createJPEGDecoder(in);   <LI>  BufferedImage <FONT color=#ff0000>image</FONT> = <FONT color=#0000ff>jpgCodec</FONT>.decodeAsBufferedImage();   <LI class=alt>  JPEGImageEncoder <FONT color=#ff0000>encoder</FONT>=<FONT color=#0000ff>JPEGCodec</FONT>.createJPEGEncoder(ot);   <LI>  encoder.encode(image);     <LI class=alt>  in.close();   <LI>  ot.close();   <LI class=alt>  out.print("JSP上传图片成功!<STRONG><FONT color=#006699><BR></FONT></STRONG>");   <LI>  //加载上传成功的图片   <LI class=alt>  out.print("<STRONG><FONT color=#006699><IMG</FONT></STRONG> <FONT color=#ff0000>width</FONT>=<FONT color=#0000ff>200</FONT> <FONT color=#ff0000>height</FONT>=<FONT color=#0000ff>200</FONT> <FONT color=#ff0000>src</FONT>=<FONT color=#0000ff>'"+name+".jpg'</FONT> <STRONG><FONT color=#006699>/></FONT></STRONG>");   <LI>}   <LI class=alt>catch(Exception e)   <LI>{   <LI class=alt>System.out.print(e.toString());   <LI>}   <LI class=alt>%<STRONG><FONT color=#006699>></FONT></STRONG>    </LI></OL></PRE> <P>实现JSP上传图片无组件化就为大家介绍到这里。</P> <P>【编辑推荐】</P> <OL> <LI>浅谈利用jspsmart实现文件上传下载</FONT></FONT></LI> <LI><FONT color=#0000ff>使用JSP页面生成PDF报表</FONT></LI> <LI><FONT color=#0000ff>JSP自定义标签定义步骤</FONT></LI> <LI><FONT color=#0000ff>详解测试JSP容器</FONT></LI> <LI><FONT color=#0000ff>介绍JSP HTTP服务器实现的以下特性</FONT></LI></OL> <!--end::Text--> </div> <!--end::Description--> <div class="mt-5"> <!--关键词搜索--> </div> <div class="mt-5"> <p class="fc-show-prev-next"> <strong>上一篇:</strong><a href="/chengxu/14143.html">Servlet API的强筋实力</a><br> </p> <p class="fc-show-prev-next"> <strong>下一篇:</strong><a href="/chengxu/14145.html">cc(ChallengeCollapsar)攻击数据小结</a> </p> </div> <!--begin::Block--> <div class="d-flex flex-stack mb-2 mt-10"> <!--begin::Title--> <h3 class="text-dark fs-5 fw-bold text-gray-800">相关内容</h3> <!--end::Title--> </div> <div class="separator separator-dashed mb-9"></div> <!--end::Block--> <div class="row g-10"> </div> </div> <!--end::Table widget 14--> </div> <!--end::Col--> <!--begin::Col--> <div class="col-xl-4 mt-0"> <!--begin::Chart Widget 35--> <div class="card card-flush h-md-100"> <!--begin::Header--> <div class="card-header pt-5 "> <!--begin::Title--> <h3 class="card-title align-items-start flex-column"> <!--begin::Statistics--> <div class="d-flex align-items-center mb-2"> <!--begin::Currency--> <span class="fs-5 fw-bold text-gray-800 ">热门资讯</span> <!--end::Currency--> </div> <!--end::Statistics--> </h3> <!--end::Title--> </div> <!--end::Header--> <!--begin::Body--> <div class="card-body pt-3"> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/241137.html" class="text-dark fw-bold text-hover-primary fs-6">如何允许远程连接到MySQL数...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">[[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/61017.html" class="text-dark fw-bold text-hover-primary fs-6">如何利用交换机和端口设置来管理...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/119031.html" class="text-dark fw-bold text-hover-primary fs-6">施耐德电气数据中心整体解决方案...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('https://files.pic99.top/shayuweb/202409/eb2e03366045d9f.jpg')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/139440.html" class="text-dark fw-bold text-hover-primary fs-6">20个非常棒的扁平设计免费资源</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/27164.html" class="text-dark fw-bold text-hover-primary fs-6">2009 IBM动态架构新动力...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7"></span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/225.html" class="text-dark fw-bold text-hover-primary fs-6">通过 XML 进行内容发布</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7"></span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/130901.html" class="text-dark fw-bold text-hover-primary fs-6">德国电信门户网站可实时显示全球...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('https://files.pic99.top/shayuweb/202503/5fe82cca6c5ff78.jpg')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/246646.html" class="text-dark fw-bold text-hover-primary fs-6">为啥国人偏爱 Mybatis,...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('https://files.pic99.top/shayuweb/202407/404021d01b8347f.jpg')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/48727.html" class="text-dark fw-bold text-hover-primary fs-6">《非诚勿扰》红人闫凤娇被曝厕所...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...</span> </div> <!--end::Title--> </div> <!--begin::Item--> <div class="d-flex flex-stack mb-7"> <!--begin::Symbol--> <div class="symbol symbol-60px symbol-2by3 me-4"> <div class="symbol-label" style="background-image: url('/static/assets/images/nopic.gif')"></div> </div> <!--end::Symbol--> <!--begin::Title--> <div class="m-0"> <a href="/chengxu/133934.html" class="text-dark fw-bold text-hover-primary fs-6">2012年第四季度互联网状况报...</a> <span class="text-gray-600 fw-semibold d-block pt-1 fs-7">[[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...</span> </div> <!--end::Title--> </div> </div> <!--end::Body--> </div> <!--end::Chart Widget 35--> </div> <!--end::Col--> </div> </div> <!--end::Content container--> </div> <!--end::Content--> </div> <!--end::Content wrapper--> <!--begin::Footer--> <div id="kt_app_footer" class="app-footer"> <!--begin::Footer container--> <div class="app-container container-xxl d-flex flex-column flex-md-row flex-center flex-md-stack py-3"> <!--begin::Copyright--> <div class="text-dark order-2 order-md-1"> <span class="text-muted fw-semibold me-1">2025 ©</span> <a href="/" target="_blank" class="text-gray-800 text-hover-primary">鲨鱼网</a> <a href="https://beian.miit.gov.cn/" target="_blank" class="text-gray-800 text-hover-primary"></a> <a href="http://spbjmm.com.shayuweb.com">上品网</a><a href="http://www.zzszq.net/">深知网</a><a href="http://www.taiyangwa.net/">太阳生活网</a><a href="http://baike.taiyangwa.net/">太阳百科网</a><a href="http://ypkjmy.com.shayuweb.com/">一品科技</a><a href="http://www.yuansudz.com/news/">元素网</a><a href="http://www.xn--i6qw12a.com/">帛典网</a><a href="http://xldmm.com.shayuweb.com/">星链岛</a> </div> <!--end::Copyright--> <!--begin::Menu--> <ul class="menu menu-gray-600 menu-hover-primary fw-semibold order-1"> <li class="menu-item"> <a href="/news/" target="_blank" class="menu-link px-2">科技资讯</a> </li> <li class="menu-item"> <a href="/chengxu/" target="_blank" class="menu-link px-2">程序开发</a> </li> <li class="menu-item"> <a href="/sitemap.xml" target="_blank" class="menu-link px-2">sitemap</a> </li> </ul> <!--end::Menu--> </div> <!--end::Footer container--> </div> <!--end::Footer--> </div> <!--end:::Main--> </div> <!--end::Wrapper--> </div> <!--end::Page--> </div> <!--end::App--> <div id="kt_scrolltop" class="scrolltop" data-kt-scrolltop="true"> <!--begin::Svg Icon | path: icons/duotune/arrows/arr066.svg--> <span class="svg-icon"> <svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"> <rect opacity="0.5" x="13" y="6" width="13" height="2" rx="1" transform="rotate(90 13 6)" fill="currentColor"></rect> <path d="M12.5657 8.56569L16.75 12.75C17.1642 13.1642 17.8358 13.1642 18.25 12.75C18.6642 12.3358 18.6642 11.6642 18.25 11.25L12.7071 5.70711C12.3166 5.31658 11.6834 5.31658 11.2929 5.70711L5.75 11.25C5.33579 11.6642 5.33579 12.3358 5.75 12.75C6.16421 13.1642 6.83579 13.1642 7.25 12.75L11.4343 8.56569C11.7467 8.25327 12.2533 8.25327 12.5657 8.56569Z" fill="currentColor"></path> </svg> </span> <!--end::Svg Icon--> </div> <!--begin::Javascript--> <script>var hostUrl = "/static/default/pc/";</script> <!--begin::Global Javascript Bundle(mandatory for all pages)--> <script src="/static/default/pc/plugins/global/plugins.bundle.js"></script> <script src="/static/default/pc/js/scripts.bundle.js"></script> <!--end::Global Javascript Bundle--> <!--end::Javascript--> </body> <!--end::Body--> </html>