SSH框架实现表单上传图片实例代码

SSH框架的一个上传到服务器然后显示在页面上的小实例,用的是简单的form表单形式,数据包括图片的url地址保存在数据库中,图片上传到tomcat服务器下的项目文件夹里,然后页面展示图片, 算是好好把上传功能给过了一遍了,当然还有什么H5上传,分片上传等等这里就不提了,适用于初学上传文件的例子。

使用Bootstrap fileinput.js上传控件,
GitHub源码下载:https://github.com/kartik-v/b...

页面上需要引入的CSS和JS

<link rel="stylesheet" type="text/css" href="css/fileinput.min.css" rel="external nofollow" >
<script type="text/javascript" src="js/fileinput.min.js"></script>

效果还是不错的

页面代码(参考)

  <form action="uploadAction" method="post" enctype="multipart/form-data"
    id="myform">
    <!-- 图片标题   -->
    <input class="form-control" type="text" name="img_title"
      id="img_title" size="100" value="请输入图片名称" style="color: #999999;"
      onfocus='if(this.value=="请输入图片名称"){this.value="";};'
      onblur='if(this.value==""){this.value="请输入图片名称";};'> <br />
    <!-- 下拉框 -->
    <select name="img_state">
      <option selected="selected">请选择审核状态</option>
      <c:forEach items="${stateList }" var="sl">
        <option value="${sl.s_id }">${sl.s_statename}</option>
      </c:forEach>
    </select> <br />
    <br />
    <!-- 图片上传控件 -->
    <input type="file" name="file" id="file" class="file" /> <br>
  </form>
  <center>
    <a href="executeimages" rel="external nofollow" class="btn btn-success">返回图集</a>
  </center>

uploadAction(MyEclipse的web-info下创建uploadFile文件夹)

这里没有用smartupload或者是别的上传jar包

package com.Action;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;

import org.apache.struts2.ServletActionContext;

import Enity.cms_images;
import Enity.cms_state;
import SQL_Implements.images_sql_Implem;

import com.opensymphony.xwork2.ActionSupport;

@SuppressWarnings("serial")
public class uploadAction extends ActionSupport {
  /**
   * 这里集合形式输入到流,防止上传重复文件,减少服务器压力
   */
  private String img_title;// 图片标题
  private int img_state;// 状态
  // 上传文件存放路径
  private final static String uploadAddres = "/uploadFile";

  // 上传文件集合泛型为file对象
  private List<File> file;
  // 上传文件名集合
  private List<String> fileFileName;
  // 上传文件内容类型集合
  private List<String> fileContentType;

  cms_images images = new cms_images();
  cms_state state = new cms_state();// 实例状态类
  private images_sql_Implem isi;
  cms_imagesAction cia;

  public cms_imagesAction getCia() {
    return cia;
  }

  public void setCia(cms_imagesAction cia) {
    this.cia = cia;
  }

  public int getImg_state() {
    return img_state;
  }

  public void setImg_state(int img_state) {
    this.img_state = img_state;
  }

  public cms_state getState() {
    return state;
  }

  public void setState(cms_state state) {
    this.state = state;
  }

  public images_sql_Implem getIsi() {
    return isi;
  }

  public void setIsi(images_sql_Implem isi) {
    this.isi = isi;
  }

  public static String getUploadaddres() {
    return uploadAddres;
  }

  public cms_images getImages() {
    return images;
  }

  public void setImages(cms_images images) {
    this.images = images;
  }

  public String getImg_title() {
    return img_title;
  }

  public void setImg_title(String img_title) {
    this.img_title = img_title;
  }

  public List<File> getFile() {
    return file;
  }

  public void setFile(List<File> file) {
    this.file = file;
  }

  public List<String> getFileFileName() {
    return fileFileName;
  }

  public void setFileFileName(List<String> fileFileName) {
    this.fileFileName = fileFileName;
  }

  public List<String> getFileContentType() {
    return fileContentType;
  }

  public void setFileContentType(List<String> fileContentType) {
    this.fileContentType = fileContentType;
  }

  // 上传方法
  public String execute() throws Exception {
    // 打印文件名称
    System.out.println("文件名称:" + this.getFileFileName());
    for (int i = 0; i < file.size(); i++) {
      // 循环上传每个文件
      uploadFile(i);
    }
    /**
     * 这里有bug 想每次添加完后能在查询一遍下拉框的值
     */
    // cia.execute();
    return "uploadSuccess";
  }

  // 调用执行上传功能
  @SuppressWarnings("deprecation")
  public void uploadFile(int i) throws FileNotFoundException, IOException {
    try {
      InputStream in = new FileInputStream(file.get(i));
      // ServletActionContext对象响应获取实际文件地址,getRealPath已经废弃不推荐用了
      String dir = ServletActionContext.getRequest().getRealPath(
          uploadAddres);
      System.out.println("服务器路径:" + dir);
      // 获取文件名称
      String fileName = this.getFileFileName().get(i);
      // 路径和文件名丢进file对象里
      File uploadFile = new File(dir, fileName);
      // 输出流
      OutputStream out = new FileOutputStream(uploadFile);
      // 设置文件大小1MB
      byte[] buffer = new byte[1024 * 1024];
      int length;
      // 用循环从流中读取文件的大小
      while ((length = in.read(buffer)) > 0) {
        out.write(buffer, 0, length);
      }

      // 设置图片标题和全路径
      images.setImg_title(img_title);
      String imgURL = dir + "/" + fileName;
      // 将全路径截取为相对路径
      String strURL = imgURL.substring(32);
      images.setImg_url(strURL);

      // 设置状态的id,并将id对象传入
      state.setS_id(img_state);
      images.setImg_state(state);
      // 添加图片的信息
      int num = isi.addIMG(images);
      System.out.println("是否上传了信息:" + num);
      // 关闭输入流输出流,释放内存
      in.close();
      out.close();
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

演示效果图

图片上传到了tomcat下的项目指定的文件夹里了

页面展示(这个部分就各有各有写法了)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • SSH在登录服务器后如何显示基础信息

    前言 本文主要给大家介绍了SSH登录服务器后显示基础信息的相关内容,分享出来供大家参考学习,下面来看看详细的介绍: 方法如下: 安装landscape-common,可以在登录时候显示一些基础的信息,例如CPU内存占用等等 sudo apt-get install landscape-common 安装update-notifier-common,当有软件包更新的时候,会在SSH登录成功后提示用户 sudo apt-get install update-notifier-common 效果如下:

  • JSP 开发SSH整合异常解决办法

    SSH整合异常解决(creating bean with name 'sessionFactory' defined in class path) 整合SSH注解的方式,但是一直有异常.还是解决了,贴出来. [org.springframework.web.context.ContextLoader]: Context initialization failed org.springframework.beans.factory.BeanCreationException: Error crea

  • 使用反向ssh从外网访问内网主机的方法详解

    前言 最近遇到一个问题,就是过几天我需要离开学校,而且到时候仍然想登陆校园网里的一台服务器进行工作:但是我又没有校园网网关的操作权限,不能做端口映射,也不能搞到校园网内部主机的外网ip,而且学校自己提供的vpn又根本没法用.研究了半天,总算找到了一个比较不错的利用反向ssh(reverse ssh tunnel)进行内网登陆的解决方案. 工作原理 之所以很多转发的方法无法应用在这里,就是因为内网主机对外网其实是不可见的,也就是说外部主机不能用一般的方法访问到内部主机.那么我们就想了,能不能用内网

  • SSH 框架简介

    什么是SSH SSH是 struts+spring+hibernate的一个集成框架,是目前较流行的一种web应用程序开源框架.SSH不是一个框架,而是把多个框架(Struts.Spring以及Hibernate)紧密的结合在一起,用于构建灵活.易于扩展的多层Web应用程序. SSH框架的系统从职责上分为四层:表示层.业务逻辑层.数据持久层和域模块层(实体层). 我们通过下面这张图说明一下,三种框架的关系以及所包含的内容,内容已经很详细了,在这里就不做过多的解释了. 下面我们再详细看一下组成SS

  • SSH框架实现表单上传图片实例代码

    SSH框架的一个上传到服务器然后显示在页面上的小实例,用的是简单的form表单形式,数据包括图片的url地址保存在数据库中,图片上传到tomcat服务器下的项目文件夹里,然后页面展示图片, 算是好好把上传功能给过了一遍了,当然还有什么H5上传,分片上传等等这里就不提了,适用于初学上传文件的例子. 使用Bootstrap fileinput.js上传控件, GitHub源码下载:https://github.com/kartik-v/b... 页面上需要引入的CSS和JS <link rel=&quo

  • BootStrap表单验证实例代码

    Bootstrap,来自 Twitter,是目前最受欢迎的前端框架.Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷. 下面给大家分享bootstrap表单验证实例代码,具体代码如下所示: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@

  • AngularJs表单验证实例代码解析

    常用的表单验证指令如下详情: 1. 必填项验证 某个表单输入是否已填写,只要在输入字段元素上添加HTML5标记required即可: <input type="text" required /> 2. 最小长度 验证表单输入的文本长度是否大于某个最小值,在输入字段上使用指令ng-minleng= "{number}": <input type="text" ng-minlength="5" /> 3.

  • Python 自动化表单提交实例代码

    今天以一个表单的自动提交,来进一步学习selenium的用法 练习目标 0)运用selenium启动firefox并载入指定页面(这部分可查看本人文章 http://www.cnblogs.com/liu2008hz/p/6958126.html) 1)页面元素查找(多种查找方式:find_element_*) 2)内容填充(send_keys) 3)iframe与父页面切换(switch_to_frame是切换到iframe,switch_to_default_content是切换到主页面)

  • 第七篇Bootstrap表单布局实例代码详解(三种表单布局)

    Bootstrap提供了三种表单布局:垂直表单,内联表单和水平表单.下面逐一给大家介绍,有兴趣的朋友一起学习吧. 创建垂直或基本表单: •·向父 <form> 元素添加 role="form". •·把标签和控件放在一个带有 class .form-group 的 <div> 中.这是获取最佳间距所必需的. •·向所有的文本元素 <input>.<textarea> 和 <select> 添加 class .form-cont

  • jQuery 表单序列化实例代码

    废话不多说了,直接给大家贴代码了,具体代码如下所述: $(function(){ $('#send').click(function(){ $.ajax({ type: "GET", url: "test.json", data: {username:$("#username").val(), password:$("#password").val()}, // 参数为对象 dataType: "json"

  • 使用Vue动态生成form表单的实例代码

    具有数据收集.校验和提交功能的表单生成器,包含复选框.单选框.输入框.下拉选择框等元素以及,省市区三级联动,时间选择,日期选择,颜色选择,文件/图片上传功能,支持事件扩展. 欢迎大家star学习交流:github地址 示例 https://raw.githubusercontent.com/xaboy/form-create/dev/images/sample110.jpg 安装 npm install form-create OR git clone https://github.com/xa

  • Bootbox将后台JSON数据填充Form表单的实例代码

    序言: 刚结束公司的三个月试用期,意味着我即将正式步入社会成为广大从事IT行业的一员.作为一个编程小白,无论从技术层面还是知识层面都是比较薄弱的,想要成为一个优秀的程序员不断的学习与探索是不可避免的.我相信一切的付出与收获是成正比的!Fighting! 这几天在做公司的实际项目的时候,需要实现选中Bootstrap table中的任意一行数据点击编辑按钮弹出一个模态框以表单的形式对该行数据进行编辑.获取表格行的数据是比较方便的,具体可以查找Bootstrap table参考文档,具体地址可以直接

  • Yii框架form表单用法实例

    本文实例讲述了Yii框架form表单用法.分享给大家供大家参考.具体方法如下: 使用表单 在 Yii 中处理表单时,通常需要以下步骤: 1. 创建用于表现所要收集数据字段的模型类. 2. 创建一个控制器动作,响应表单提交. 3. 在视图脚本中创建与控制器动作相关的表单. 一.创建模型 在编写表单所需的 HTML 代码之前,我们应该先确定来自最终用户输入的数据的类型,以及这些数据应符合什么样的规则.模型类可用于记录这些信息.正如模型章节所定义的,模型是保存用户输入和验证这些输入的中心位置. 取决于

  • jQuery表单事件实例代码分享

    本文实例为大家分享了jQuery表单事件代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>表单事件</title> </head> <style type="text/css" rel="stylesheet">

随机推荐