上传页面

上传学生信息

学号 

姓名 


密码 


性别 男 女


年龄 


身高 


学院 
计算机学院
软件学院

照片 


简历

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>上传学生信息</title>
</head>
<body>
    <form action="/lib/upload" method="post" enctype="multipart/form-data">
        学号&nbsp;<input type="text" name="xuehao" id="xuehao"/>
        <br/>
        姓名&nbsp;<input type="text" name="xingming" id="xingming">
        <br/>
        密码&nbsp;<input type="password" name="mima" id="mima">
        <br/>
        性别&nbsp;<input type="radio" name="xingbie" value="nan" checked>男 <input type="radio" name="xingbie" value="nv" >女
        <br/>
        年龄&nbsp;<input type="text" name="nianling" id="nianling">
        <br/>
        身高&nbsp;<input type="text" name="shengao" id="shengao">
        <br/>
        学院&nbsp;<select name="xueyuan">
        <option value="computer">计算机学院</option>
        <option value="software">软件学院</option>
    </select>
        <br/>
        照片&nbsp;<input type="file" name="zhaopian" id="zhaopian"/>
        <br/>
        简历&nbsp;<input type="file" name="jianli" id="jianli">
        <br/>
        <input type="submit" value="提交">
    </form>
</body>
</html>

上传需要的配置信息web.xml

<servlet>
    <description></description>
    <display-name>UploadServlet</display-name>
    <servlet-name>UploadServlet</servlet-name>
    <servlet-class>com.sangewuxie.servlet.UploadServlet</servlet-class>
    <load-on-startup>0</load-on-startup>
    <multipart-config>
      <max-file-size>52428800</max-file-size>
      <max-request-size>52428800</max-request-size>
      <file-size-threshold>0</file-size-threshold>
    </multipart-config>
  </servlet>
  <servlet-mapping>
    <servlet-name>UploadServlet</servlet-name>
    <url-pattern>/upload</url-pattern>
  </servlet-mapping>
  <servlet>

上传的servlet

package com.sangewuxie.servlet;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import javax.servlet.ServletException;
import javax.servlet.annotation.MultipartConfig;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.Part;

import com.sangewuxie.dao.StudentDao;
import com.sangewuxie.domain.Student;

public class UploadServlet extends HttpServlet {

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
        request.setCharacterEncoding("utf-8");
        String xuehao = request.getParameter("xuehao");
        String xingming = request.getParameter("xingming");
        String mima = request.getParameter("mima");
        String xingbie = request.getParameter("xingbie");
        int nianling = Integer.parseInt(request.getParameter("nianling"));
        int shengao = Integer.parseInt(request.getParameter("shengao"));
        String xueyuan = request.getParameter("xueyuan");
        String dir = request.getServletContext().getRealPath("");

        Part zhaopianPart = request.getPart("zhaopian");
        String zhaopian = upload(request, zhaopianPart, dir+"\\upload\\zhaopian");
        Part jianliPart =request.getPart("jianli");
        String jianli = upload(request, jianliPart, dir+"\\upload\\jianli");
        Student student = new Student(xuehao, xingming, mima, xingbie, nianling, shengao, xueyuan, zhaopian, jianli);
        StudentDao.InsertStudentInfo(student);
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().write("上传成功");
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }
    public String upload(HttpServletRequest request,Part part,String dir) throws IOException {
        String cd = part.getHeader("content-disposition");
        /**
         * tomcat7没有getSubmittedFileName()方法
      * String filename = part.getSubmittedFileName() */ String filename = cd.substring(cd.lastIndexOf("=")+2, cd.length()-1); String houzhui = filename.substring(filename.lastIndexOf('.')); String destfilename = System.currentTimeMillis()+""; destfilename = destfilename + houzhui; part.write(dir+"\\"+destfilename); // InputStream ist = part.getInputStream(); // FileOutputStream fos = new FileOutputStream(dir+"\\"+destfilename); // byte[] bytes = new byte[1024]; // int size = -1; // while((size = ist.read(bytes))>0){ // fos.write(bytes, 0, size); // } // ist.close(); // fos.close(); return destfilename; } }

下载  流程

package com.sangewuxie.servlet;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintStream;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.sangewuxie.dao.StudentDao;

public class DownloadServlet extends HttpServlet {

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        String xuehao = request.getParameter("xuehao");
        String jianli = StudentDao.getName(xuehao,"jianli");
//        System.out.println(jianli);

        if(jianli==null) {
            response.setContentType("text/html;charset=utf-8");
            response.getWriter().write("未找到该生或该生不存在");
        }

        else {
            String contentType = getServletContext().getMimeType(jianli);
            response.setContentType(contentType);
            response.setHeader("Content-Disposition", "attachment;filename="+jianli);
            String dir = request.getServletContext().getRealPath("")+"\\upload\\jianli\\";
            String filename = dir+jianli;
            InputStream in = new FileInputStream(filename);
            OutputStream out = response.getOutputStream();
            int len;
            while((len=in.read())!= -1)
            {
                out.write(len);
            }  

            in.close();
            out.close();
        }
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        doGet(request, response);
    }

}

保存到csv

package com.sangewuxie.servlet;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Iterator;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.sangewuxie.dao.StudentDao;
import com.sangewuxie.domain.Student;

public class SavecsvServlet extends HttpServlet {

    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        int minAge = Integer.parseInt(request.getParameter("min"));
        int maxAge = Integer.parseInt(request.getParameter("max"));
        ArrayList<Student> students= StudentDao.getInfo(minAge,maxAge);

        response.setContentType("text/html;charset=utf-8");
        if(students.isEmpty()) {
            response.getWriter().write("未找到该数据或者数据不存在");
        }

        else {

            String filename = "从"+minAge+"到"+maxAge+"岁的信息.csv";
            filename = URLEncoder.encode(filename,"UTF-8");
            String contentType =getServletContext().getMimeType(filename);
            response.setContentType(contentType);
            response.setHeader("Content-Disposition", "attachment;filename="+filename);

            OutputStream out = response.getOutputStream();
            PrintStream ps = new PrintStream(out);
            ps.println("学号,姓名,性别,年龄,身高,学院");
            Iterator it = students.iterator();
            while(it.hasNext()) {
                Student  student= (Student) it.next();
                ps.println(student.getXuehao()+","+student.getXingming()+","+student.getXingbie()+","+student.getNianling()+","+student.getShengao()+","+student.getXueyuan());
            }
            ps.flush();
            ps.close();
            out.close();
        }
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}

个人笔记。无需细看

servlet上传与下载的更多相关文章

  1. servlet上传下载(任何格式的都可以)

    jar不能低于此版本,JDK1.6以上,否则户报错 <dependency> <groupId>commons-fileupload</groupId> <a ...

  2. java web学习总结(二十四) -------------------Servlet文件上传和下载的实现

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能,今天来讲一下JavaWeb中的文件上传和下载功能的实现. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用 ...

  3. 使用jsp/servlet简单实现文件上传与下载

    使用JSP/Servlet简单实现文件上传与下载    通过学习黑马jsp教学视频,我学会了使用jsp与servlet简单地实现web的文件的上传与下载,首先感谢黑马.好了,下面来简单了解如何通过使用 ...

  4. Servlet 实现文件的上传与下载

    这段时间尝试写了一个小web项目,其中涉及到文件上传与下载,虽然网上有很多成熟的框架供使用,但为了学习我还是选择了自己编写相关的代码.当中遇到了很多问题,所以在此这分享完整的上传与下载代码供大家借鉴. ...

  5. springmvc和servlet在上传和下载文件(保持文件夹和存储数据库Blob两种方式)

    参与该项目的文件上传和下载.一旦struts2下完成,今天springmvc再来一遍.发现springmvc特别好包,基本上不具备的几行代码即可完成,下面的代码贴: FileUpAndDown.jsp ...

  6. 【Demo Project】AjaxSubmit+Servlet表单文件上传和下载

    一.背景 前段时间公司要求我做一个上传和下载固件的页面,以备硬件产品在线升级,现在我把这部分功能抽取出来作为一个Demo Project给大家分享. 话不多说,先看项目演示 --> 演示  源码 ...

  7. jsp+servlet实现文件的上传和下载

    实现文件的上传和下载首先需要理解几个知识,这样才可以很好的完成文件的上传和下载: (1):上传文件是上传到服务器上,而保存到数据库是文件名 (2):上传文件是以文件转换为二进制流的形式上传的 (3): ...

  8. Servlet文件上传和下载的复习

    上传 使用Servlet完成上传和下载相较于使用Struts框架有点麻烦,毕竟更偏底层了 项目中主要使用的jar包: commons-io-2.2.jar  commons-fileupload-1. ...

  9. jsp/servlet实现简单上传和下载

    使用JSP/Servlet简单实现文件上传与下载 jsp上传页面代码: <%@ page language="java" import="java.util.*&q ...

随机推荐

  1. TypeScript笔记 4--变量声明

    在上一篇:基础变量中我们在声明变量时使用了关键字let,这和JS中的var有点类似. 语法 基本语法:let 变量名:类型.当然类型不是必须的. let x:number; let y:string ...

  2. Spark算子--SortBy

    转载请标明出处http://www.cnblogs.com/haozhengfei/p/39edcbb10b5076599c0e5609b7136b88.html SortBy--Transforma ...

  3. SQL用了Union后的排序问题

    最近使用SQL语句进行UNION查询,惊奇的发现:SQL没问题,UNION查询也没问题,都可以得到想要的结果,可是在对结果进行排序的时候,却出问题了. 1.UNION查询没问题 SELECT `id` ...

  4. 使用phpMyAdmin批量修改Mysql数据表前缀的方法

    多个网站共用一个Mysql数据库时,为使数据库管理不混乱,一般采用不同的网站使用不同前缀名的方式进行区分.而如何批量修改已有数据库的前缀名呢?全部导出修改后再导入?还是一个表一个表的修改?今天我要介绍 ...

  5. redis常见使用场景下PHP实现

    基于redis字符串string类型的简单缓存实现 <?php //简单字符串缓存 $redis = new \Redis(); $redis->connect('127.0.0.1',6 ...

  6. OKMX6Q libx264交叉编译

    最开始使用的是最新版x264-snapshot-20171119-2245 配置使用: ./configure --host=arm-linux --cross-prefix=arm-linux- - ...

  7. jsp中${}

    jsp中${}----是EL表达式的常规表示方式目的是为了获取{}中指定的对象(参数.对象等)的值 如:${user.name}<====>User user = (User)reques ...

  8. 【视频编解码·学习笔记】2. H.264简介

    一.H.264视频编码标准 H.264视频编码标准是ITU-T与MPEG合作产生的又一巨大成果,自颁布之日起就在业界产生了巨大影响.严格地讲,H.264标准是属于MPEG-4家族的一部分,即MPEG- ...

  9. Apache 403 错误解决方法-让别人可以访问你的服务器

    参考网址:http://www.cnblogs.com/mrlaker/archive/2013/04/29/3050888.html http://www.jb51.net/article/6119 ...

  10. MySQL改写子查询成Join

    有时用别的方式而不是子查询可以获得更高的性能 : For example: SELECT * FROM t1 WHERE id IN (SELECT id FROM t2); 改写: SELECT D ...