Java编程之如何通过JSP实现头像自定义上传

目录
  • 开发概述
  • 开发环境
  • 开发过程
    • 1、JSP前台页面
      • 样式图:
      • JS操作
    • 2、数据库的设计
      • 数据库表:
      • 实体类:UsersInfo.java
    • 3、数据库操作
      • UsersMapper
      • UsersMapper.xml
    • 4、Servlet
    • 5、工具类
      • DownloadImage:下载指定路径下的文件到本地指定目录
      • TimeRandom:生成年月日时分秒+8位随机数
    • 6、最终效果展示
  • 总结

开发概述

本次项目意在实现一种可以在本地选择图片,然后将其上传至服务器指定文件目录下,并可以通过服务器自动生成的临时链接下载到本地的指定目录进行保存,这样数据库就只需要存储对应图片的文件名即可进行正常的显示,以达到上传图片的目的。

开发环境

整体使用了Maven的开发环境   数据库操作使用的是Mybatis进行管理   前台页面的显示操作则是通过jsp+servlet   数据库采用mysql数据库

开发过程

1、JSP前台页面

首先你需要在你的jsp页面中准备好一个图片上传的<form>表单,一开始<input> 标签中的value值可以先设置为默认值,到后面连接好数据库,写好servlet之后再进行替换,这里就不在具体展示过程了,直接一步到位。另外本次举例的具体呈现的效果样式如下图所示:

 <div class="modal modal-profile" style="display: none;">
   <div class="hd"><h4 class="tt" style="margin-left: 10px;">我的资料</h4><a id="a_close" class="close">×</a></div>
    <div class="bd">

        <form class="form-horizontal" action="../usersInfo.do" method="post" enctype="multipart/form-data">
            <div class="avatar"><img id="showupimg" src="img/upload/image/<%=usersInfo.getUava()%>" alt="头像">
                <a class="upload">点击更换</a><input id="uploadimg" type="file" name="file" accept="image/png, image/jpeg, image/gif, image/jpg" class="upload-input">
                <input type="hidden" name="uname" value="<%=usersInfo.getUname()%>"/>
            </div>
            <div class="form-group"><label class="control-label">昵称</label>
                <div class="control-form"><input name="unname" type="text" placeholder="请输入昵称" class="form-control" value="<%=usersInfo.getUnname()%>"><!----></div>
            </div>
            <div class="form-group"><label class="control-label">签名</label>
                <div class="control-form">
                    <textarea name="signview" rows="5" placeholder="请输入签名,字数不超过100字" class="form-control"><%=usersInfo.getUpersonal()%></textarea>
                </div>
            </div>
            <div class="ft">
                <input type="submit" id="btn_save" class="btn btn-primary" value="保存"/>
                <button type="button" id="btn_cancel" class="btn btn-default">取消</button>
            </div>
        </form>
    </div>

样式图:

JS操作

本来这里想通过ajax来完成的,因为通过servlet重定向会页面时,页面总会闪一下,影响了用户体验,但是由于赶时间,就没有把它改成ajax,以后有时间的话可能会补一段,现在先这样吧。

    $("#uploadimg").change(function () {

        var url, imgbase64;

        //获取file对象URL
        if (navigator.userAgent.indexOf("MSIE") >= 1) { // IE
            url = document.getElementById('uploadimg').value;
        } else if (navigator.userAgent.indexOf("Firefox") > 0) { // Firefox
            url = window.URL.createObjectURL(document.getElementById('uploadimg').files.item(0));
        } else if (navigator.userAgent.indexOf("Chrome") > 0) { // Chrome
            url = window.URL.createObjectURL(document.getElementById('uploadimg').files[0]);
        }

        // 创建Image对象
        var image = new Image();
        image.src = url;
        image.onload = function () {
            imgbase64 = getBase64Image(image);
            $("#showupimg").attr("src",image.src);
        }

    });

2、数据库的设计

关于数据库表做的其实还是比较简单的,我做的其实是分了两个表,一个Users表,一个UsersInfo表。Users表用来存放用户的账号、密码和登录时间;UsersInfo表用来存储对应用户的用户信息,如昵称、头像、性别、年龄等等,这里Users表用不到,所以只展示了UsersInfo表。

数据库表:

实体类:UsersInfo.java

package com.skdsc.domain.login;

public class UsersInfo {
    private String uname;
    private String unname;
    private Sex usex;
    private String uage;
    private String uava;
    private String uqq;
    private String upersonal;

    public UsersInfo() {
    }

    public UsersInfo(String uname, String unname, Sex usex, String uage, String uava, String uqq, String upersonal) {
        this.uname = uname;
        this.unname = unname;
        this.usex = usex;
        this.uage = uage;
        this.uava = uava;
        this.uqq = uqq;
        this.upersonal = upersonal;
    }

    public String getUname() {
        return uname;
    }

    public void setUname(String uname) {
        this.uname = uname;
    }

    public String getUnname() {
        return unname;
    }

    public void setUnname(String unname) {
        this.unname = unname;
    }

    public Sex getUsex() {
        return usex;
    }

    public void setUsex(Sex usex) {
        this.usex = usex;
    }

    public String getUage() {
        return uage;
    }

    public void setUage(String uage) {
        this.uage = uage;
    }

    public String getUava() {
        return uava;
    }

    public void setUava(String uava) {
        this.uava = uava;
    }

    public String getUqq() {
        return uqq;
    }

    public void setUqq(String uqq) {
        this.uqq = uqq;
    }

    public String getUpersonal() {
        return upersonal;
    }

    public void setUpersonal(String upersonal) {
        this.upersonal = upersonal;
    }
}

3、数据库操作

这里用到的数据库操作主要是两个:findByUserInfoName()updateUsersInfo()

UsersMapper

import com.skdsc.domain.login.Users;
import com.skdsc.domain.login.UsersInfo;
import org.apache.ibatis.annotations.Param;

public interface UsersMapper {
    Users findByUserName(@Param("parUserName") String parUserName);
    UsersInfo findByUsersInfoName(@Param("parUserName") String parUserName);
    int updateUtime(@Param("uname") String uname,@Param("newUtime") String newUtime);
    int updateUsersInfo(@Param("uname") String uname,@Param("newUnname") String newUnname,@Param("newUpersonal") String newUpersonal,@Param("newUava") String newUava);
}

UsersMapper.xml

<mapper namespace="com.skdsc.mappers.login.UsersMapper">

    <sql id="selStr">uid,uname,upwd,utime</sql>
    <sql id="selStr1">uname,unname,uage,usex,uava,uqq,upersonal</sql>

    <resultMap id="newUsersInfo" type="com.skdsc.domain.login.UsersInfo">
        <result property="uname" column="uname"/>
        <result property="unname" column="unname"/>
        <result property="uage" column="uage"/>
        <result property="uava" column="uava"/>
        <result property="uqq" column="uqq"/>
        <result property="upersonal" column="upersonal"/>
        <!--嵌套对象标签-->
        <association property="usex" javaType="com.skdsc.domain.login.Sex">
            <id property="sid" column="sid"/>
            <result property="sname" column="sname"/>
        </association>
    </resultMap>

    <!-- 根据学号查询用户表 -->
    <select id="findByUserName" resultType="com.skdsc.domain.login.Users">
        SELECT <include refid="selStr" /> FROM Users where uname = #{parUserName,jdbcType=VARCHAR}
    </select>
    <!-- 根据学号查询用户信息表 -->
    <select id="findByUsersInfoName" resultType="com.skdsc.domain.login.UsersInfo">
        SELECT <include refid="selStr1" /> FROM UsersInfo where uname = #{parUserName,jdbcType=VARCHAR}
    </select>
    <!-- 更新最近一次的登录时间 -->
    <update id="updateUtime">
         UPDATE Users SET utime = #{newUtime} where uname = #{uname}
    </update>
    <!-- 更新个人资料(头像、昵称、个人签名) -->
    <update id="updateUsersInfo">
        UPDATE UsersInfo <trim prefix="set" suffixOverrides=",">
        <if test="newUnname !=null">unname = #{newUnname},</if>
        <if test="newUpersonal !=null">upersonal = #{newUpersonal},</if>
        <if test="newUava !=null">uava = #{newUava}</if>
    </trim>
        WHERE uname = #{uname}
    </update>
</mapper>

4、Servlet

这里主要是先获取<form>表单提交上来的数据,对数据进行处理,获得其路径以及文件后缀,并利用年月日时分秒+8位随机数生成一个新的文件名,最后通过DownloadImage工具类中的download方法将图片下载到本地的指定目录。

import static com.lazy.servlet.utils.DownloadImage.download;
import static com.lazy.servlet.utils.TimeRandom.createOrderCode;

@WebServlet("/usersInfo.do")
@MultipartConfig
public class UsersInfoAction extends HttpServlet {

    private static final long serialVersionUID = 1L;
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("UTF-8");
        String unname = request.getParameter("unname");
        String upersonal = request.getParameter("signview");
        String uname = request.getParameter("uname");
        System.out.println(unname + upersonal + uname);
        try {
            //设置基础路径
            String basePath = "http://localhost:8080/smartcampus_web_war/center/img/upload/image/";

            //获取上传的文件
            Part part = request.getPart("file");

            //获取请求的信息
            String name=part.getHeader("content-disposition");

            //获取上传文件的目录
            String root=request.getServletContext().getRealPath("/center/img/upload/image");
            System.out.println("测试上传文件的路径:"+root);

            //获取文件的后缀
            String str=name.substring(name.lastIndexOf("."), name.length()-1);
            System.out.println("测试获取文件的后缀:"+str);

            //生成一个新的文件名,不重复,数据库存储的就是这个文件名,不重复的
            String filename=root+"\\"+createOrderCode()+str;
            System.out.println("测试产生新的文件名:"+filename);

            //获取上传到本地服务器的图片路径
            String strimg = filename.substring(filename.lastIndexOf("\\")+1);
            String imgsrc = basePath + strimg;

            System.out.println("测试获取图片名称:"+strimg);

            //上传文件到指定目录,不想上传文件就不调用这个
            part.write(filename);

            //下载到本地指定目录
            download(imgsrc, strimg,"E:\\Studyspaces\\Intellij IDEA\\IdeaProjects\\sk170403\\smartcampus_web\\src\\main\\webapp\\center\\img\\upload\\image");

            SqlSession sqlSession = MybatisUtil.getSqlSession();
            UsersMapper usersMapper = sqlSession.getMapper(UsersMapper.class);
            int updateUsersInfoflag = usersMapper.updateUsersInfo(uname,unname,upersonal,strimg);
            if (updateUsersInfoflag != 0){
                sqlSession.commit();
            }else {
                sqlSession.rollback();
            }

        } catch (Exception e) {
            e.printStackTrace();
        }

        response.sendRedirect("center/zfcenter.jsp");

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doGet(req, resp);
    }
}

5、工具类

DownloadImage:下载指定路径下的文件到本地指定目录

package com.lazy.servlet.utils;

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.URL;
import java.net.URLConnection;

public class DownloadImage {
    /**
     * @param args
     * @throws Exception
     */

    public static void download(String urlString, String filename,String savePath) throws Exception {
        // 构造URL
        URL url = new URL(urlString);
        // 打开连接
        URLConnection con = url.openConnection();
        //设置请求超时为5s
        con.setConnectTimeout(5*1000);
        // 输入流
        InputStream is = con.getInputStream();

        // 1K的数据缓冲
        byte[] bs = new byte[1024];
        // 读取到的数据长度
        int len;
        // 输出的文件流
        File sf=new File(savePath);
        if(!sf.exists()){
            sf.mkdirs();
        }
        OutputStream os = new FileOutputStream(sf.getPath()+"\\"+filename);
        // 开始读取
        while ((len = is.read(bs)) != -1) {
            os.write(bs, 0, len);
        }
        // 完毕,关闭所有链接
        os.close();
        is.close();
    }
}

TimeRandom:生成年月日时分秒+8位随机数

package com.lazy.servlet.utils;

import java.text.SimpleDateFormat;
import java.util.Date;

public class TimeRandom {
    private static String getNowDate(){
        Date date = new Date();
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
        return simpleDateFormat.format(date);
    }
    private static String getRandom(){
        String rand = "";
        for (int i = 0; i < 8; i++){
            rand = rand + (int)(Math.random()*10);
        }
        return rand;

    }
    public static String createOrderCode(){
        String OrderCode = getNowDate() + getRandom();
        return OrderCode;
    }
}

6、最终效果展示

总结

到此这篇关于Java编程之如何通过JSP实现头像自定义上传的文章就介绍到这了,更多相关Java JSP头像自定义上传内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • JSP中图片的上传与显示方法实例详解

    本文实例讲述了JSP中图片的上传与显示方法.分享给大家供大家参考.具体如下: 1.引言 数据库应用程序,特别是基于WEB的数据库应用程序,常会涉及到图片信息的存储和显示.通常我们使用的方法是将所要显示的图片存在特定的目录下,在数据库中保存相应的图片的名称,在JSP中建立相应的数据源,利用数据库访问技术处理图片信息.但是,如果我们想动态的显示图片,上述方法就不能满足需要了.我们必须把图片存入数据库,然后通过编程动态地显示我们需要的图片.实际操作中,可以利用JSP的编程模式来实现图片的数据库存储和显

  • jsp中实现上传图片即时显示效果功能

    复制代码 代码如下: <script> function setImagePreview() { var docObj=document.getElementById("doc"); var imgObjPreview=document.getElementById("preview"); if(docObj.files && docObj.files[0]){ //火狐下,直接设img属性 imgObjPreview.style.dis

  • JSP上传文件到指定位置实例代码

    Servlet 代码: 复制代码 代码如下: /** 直接取上传的File */ public void doPost(HttpServletRequest request, HttpServletResponse response)   throws ServletException, IOException {  String targetPath = request.getRealPath(request.getContextPath()); // 目标存储路径,服务器部署目录下  req

  • Java编程之如何通过JSP实现头像自定义上传

    目录 开发概述 开发环境 开发过程 1.JSP前台页面 样式图: JS操作 2.数据库的设计 数据库表: 实体类:UsersInfo.java 3.数据库操作 UsersMapper UsersMapper.xml 4.Servlet 5.工具类 DownloadImage:下载指定路径下的文件到本地指定目录 TimeRandom:生成年月日时分秒+8位随机数 6.最终效果展示 总结 开发概述 本次项目意在实现一种可以在本地选择图片,然后将其上传至服务器指定文件目录下,并可以通过服务器自动生成的

  • servlet+JSP+mysql实现文件上传的方法

    本文实例讲述了servlet+JSP+mysql实现文件上传的方法.分享给大家供大家参考,具体如下: 一.文件上传的基本操作: 1. 表单属性enctype的设置 multipart/form-data和application/x-www-form-urlencoded的区别 FORM元素的enctype属性指定了表单数据向服务器提交时所采用的编码类型,默认的缺省值是"application/x-www-form-urlencoded". 然而,在向服务器发送大量的文本.包含非ASCI

  • Android编程使用HTTP协议与TCP协议实现上传文件的方法

    本文实例讲述了Android编程使用HTTP协议与TCP协议实现上传文件的方法.分享给大家供大家参考,具体如下: Android上传文件有两种方式,第一种是基于Http协议的HttpURLConnection,第二种是基于TCP协议的Socket. 这两种方式的区别是使用HttpURLConnection上传时内部有缓存机制,如果上传较大文件会导致内存溢出.如果用TCP协议Socket方式上传就会解决这种弊端. HTTP协议HttpURLConnection 1. 通过URL封装路径打开一个Ht

  • Jsp+Servlet实现文件上传下载 删除上传文件(三)

    接着上一篇讲:Jsp+Servlet实现文件上传下载(二)--文件列表展示 本章来实现一下删除已上传文件,同时优化了一下第一章中的代码. 废话少说,上代码得意 1.调整列表页面list.jsp <%@ page contentType="text/html;charset=UTF-8" language="java" %> <%@ taglib prefix="c" uri="http://java.sun.com/j

  • Jsp+Servlet实现文件上传下载 文件列表展示(二)

    接着上一篇讲: Jsp+Servlet实现文件上传下载(一)--文件上传 本章来实现一下上传文件列表展示,同时优化了一下第一章中的代码. 废话少说,上代码 mysql创建附件表 DROP TABLE tbl_accessory; CREATE TABLE tbl_accessory ( id INT AUTO_INCREMENT PRIMARY KEY, file_name VARCHAR(500), file_size DOUBLE(10,2), file_ext_name VARCHAR(1

  • jsp+servlet实现文件上传与下载功能

    本文实例为大家分享了jsp servlet实现文件上传与下载的具体代码,供大家参考,具体内容如下 上传: 需要导入两个包:commons-fileupload-1.2.1.jar,commons-io-1.4.jar import java.io.File; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.Http

  • jsp+servlet简单实现上传文件功能(保存目录改进)

    1.jsp前端 <%-- Created by IntelliJ IDEA. User: Lenovo Date: 2020/6/19 Time: 22:53 Learn from https://www.bilibili.com/video/BV18z411i7gh?t=23&p=192 To change this template use File | Settings | File Templates. --%> <%@ page contentType="te

  • Java利用Socket和IO流实现文件的上传与下载

    目录 背景概述 核心技术 Config Client Server UploadRunnableImpl DownloadRunnableImpl 背景概述 本文利用Socket编程和IO流技术实现文件的上传与下载. 核心技术 1.TCP 2.Socket 3.FileInputStream与FileOutputStream 4.DataInputStream与DataOutputStream 5.多线程 Config package com.io14; /** * 本文作者:谷哥的小弟 * 博

  • 使用canvas实现仿新浪微博头像截取上传功能

    最近看到微博头像上传功能很感兴趣,于是就使用canvas写了一个,本文写的不好还请见谅.本程序目前在谷歌浏览器和火狐浏览器测试可用,ie浏览器无法支持. 因为ie的安全机制不允许img使用本地路径,所以若想ie支持本程序,必须先将图片上传,然后给img对象上传后的图片地址. 我在这里没写,是因为暂时没写上传功能的后端代码,并且还不确定有没有更好的解决办法. 如下是新浪的 如下是我做的截取部分 代码: var canvas = document.getElementById('canvas'),

随机推荐