精华内容
下载资源
问答
  • 在很多的网站都可以实现上传头像,可以选择自己喜欢的图片做头像,从本地上传,下次登录时可以直接显示出已经上传的头像,那么这个是如何实现的呢?   下面说一下我的实现过程(只是个人实现思路,实际网站怎...

    题外话:推荐一个专注于Java开发的网站,做提升学习,价值阅读:Java知音

    同时,扫码关注后端技术精选,回复“学习资料”,领取100套小程序源码+小程序开发视频和基本Java经典书籍电子版


    在很多的网站都可以实现上传头像,可以选择自己喜欢的图片做头像,从本地上传,下次登录时可以直接显示出已经上传的头像,那么这个是如何实现的呢?

     

    下面说一下我的实现过程(只是个人实现思路,实际网站怎么实现的不太清楚)

    实现的思路:

    工具:MySQL,eclipse

    首先,在MySQL中创建了两个表,一个t_user表,用来存放用户名,密码等个人信息,

    一个t_touxiang表,用来存放上传的图片在服务器中的存放路径,以及图片名字和用户ID,

    T_touxiang表中的用户ID对应了t_user中的id。

     

    t_user表SQL:

    DROP TABLE IF EXISTS `t_user`;
    CREATE TABLE `t_user` (
      `id` int(10) NOT NULL AUTO_INCREMENT,
      `username` varchar(20) NOT NULL,
      `password` varchar(255) NOT NULL,
      PRIMARY KEY (`id`),
      UNIQUE KEY `username` (`username`)
    ) ENGINE=InnoDB AUTO_INCREMENT=22 DEFAULT CHARSET=utf8;
    

     

    T_touxiang表SQL:

     

    DROP TABLE IF EXISTS `t_touxiang`;
    CREATE TABLE `t_touxiang` (
      `id` int(10) NOT NULL AUTO_INCREMENT,
      `image_path` varchar(255) DEFAULT NULL,
      `user_id` int(11) DEFAULT NULL,
      `old_name` varchar(255) DEFAULT NULL,
      PRIMARY KEY (`id`),
      KEY `img_user` (`user_id`),
      CONSTRAINT `img_user` FOREIGN KEY (`user_id`) REFERENCES `t_user` (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
    

     

    首先,写一个UploadServlet.java,用来处理图片文件的上传,并将图片路径,图片名称等信息存放到t_touxiang数据表中,代码如下:

     

    @WebServlet("/UploadServlet.do")
    public class UploadServlet extends HttpServlet {
        private static final long serialVersionUID = 1L;
    
        protected void service(HttpServletRequest request, HttpServletResponse response)
    	    throws ServletException, IOException {
    	// 判断上传表单是否为multipart/form-data类型
    	HttpSession session = request.getSession();
    	User user = (User) session.getAttribute("user"); // 在登录时将 User 对象放入了 会话
    							 // 中
    
    	if (ServletFileUpload.isMultipartContent(request)) {
    
    	    try {
    		// 1. 创建DiskFileItemFactory对象,设置缓冲区大小和临时文件目录
    		DiskFileItemFactory factory = new DiskFileItemFactory();
    		// System.out.println(System.getProperty("java.io.tmpdir"));//默认临时文件夹
    
    		// 2. 创建ServletFileUpload对象,并设置上传文件的大小限制。
    		ServletFileUpload sfu = new ServletFileUpload(factory);
    		sfu.setSizeMax(10 * 1024 * 1024);// 以byte为单位 不能超过10M 1024byte =
    						 // 1kb 1024kb=1M 1024M = 1G
    		sfu.setHeaderEncoding("utf-8");
    
    		// 3.
    		// 调用ServletFileUpload.parseRequest方法解析request对象,得到一个保存了所有上传内容的List对象。
    		@SuppressWarnings("unchecked")
    		List<FileItem> fileItemList = sfu.parseRequest(request);
    		Iterator<FileItem> fileItems = fileItemList.iterator();
    
    		// 4. 遍历list,每迭代一个FileItem对象,调用其isFormField方法判断是否是上传文件
    		while (fileItems.hasNext()) {
    		    FileItem fileItem = fileItems.next();
    		    // 普通表单元素
    		    if (fileItem.isFormField()) {
    			String name = fileItem.getFieldName();// name属性值
    			String value = fileItem.getString("utf-8");// name对应的value值
    
    			System.out.println(name + " = " + value);
    		    }
    		    // <input type="file">的上传文件的元素
    		    else {
    			String fileName = fileItem.getName();// 文件名称
    			System.out.println("原文件名:" + fileName);// Koala.jpg
    
    			String suffix = fileName.substring(fileName.lastIndexOf('.'));
    			System.out.println("扩展名:" + suffix);// .jpg
    
    			// 新文件名(唯一)
    			String newFileName = new Date().getTime() + suffix;
    			System.out.println("新文件名:" + newFileName);// image\1478509873038.jpg
    
    			// 5. 调用FileItem的write()方法,写入文件
    			File file = new File("D:/lindaProjects/mySpace/wendao/WebContent/touxiang/" + newFileName);
    			System.out.println(file.getAbsolutePath());
    			fileItem.write(file);
    
    			// 6. 调用FileItem的delete()方法,删除临时文件
    			fileItem.delete();
    
    			/*
    			 * 存储到数据库时注意 1.保存源文件名称 Koala.jpg 2.保存相对路径
    			 * image/1478509873038.jpg
    			 * 
    			 */
    			if (user != null) {
    			    int myid = user.getId();
    			    String SQL = "INSERT INTO t_touxiang(image_path,user_id,old_name)VALUES(?,?,?)";
    			    int rows = JdbcHelper.insert(SQL, false, "touxiang/" + newFileName, myid, fileName);
    			    if (rows > 0) {
    				session.setAttribute("image_name", fileName);
    				session.setAttribute("image_path", "touxiang/" + newFileName);
    				response.sendRedirect(request.getContextPath() + "/upImage.html");
    			    } else {
    
    			    }
    
    			} else {
    			    session.setAttribute("loginFail", "请登录");
    			    response.sendRedirect(request.getContextPath() + "/login.html");
    			}
    
    		    }
    		}
    
    	    } catch (FileUploadException e) {
    		e.printStackTrace();
    	    } catch (Exception e) {
    		e.printStackTrace();
    	    }
    
    	}
        }
    }
    

     

    在完成图片上传并写入数据库的同时,将图片路径通过session的方式发送到HTML界面

     

     

    <!DOCTYPE html>
    
    <html>
    
    <head>
    
    <meta charset="UTF-8">
    
    <title>更换头像</title>
    
    </head>
    
    <body>
    
             <formaction="UploadServlet.do" method="post"enctype="multipart/form-data">
    
                         本地目录:<inputtype="file" name="uploadFile">
    
               <img src="${image_path}" width="200" height="200">
    
                    <inputtype="submit" value="上传头像"/>
    
       </form>
    
    </body>
    
    </html>

     

    至此,图片上传数据库和本地服务器已经实现,那么如何在HTML界面显示出个人信息以及上传的头像呢?

     

     

    首先定义一个PersonServlet类,用来读取数据库的内容,并发送到HTML界面。

    代码如下:

    @WebServlet("/persons.do")
    public class PersonServlet extends HttpServlet {
    
        private static final long serialVersionUID = -800352785988546254L;
    
        protected void service(HttpServletRequest request, HttpServletResponse response)
    	    throws ServletException, IOException {
    	// 判断上传表单是否为multipart/form-data类型
    	Touxiang tx=null;
    	
    	HttpSession session = request.getSession();
    	User user = (User) session.getAttribute("user"); // 在登录时将 User 对象放入了 会话
    	if(user!=null){
    	    int myid=user.getId();
    	    String SQL="SELECT id,image_path,old_name FROM t_touxiang WHERE user_id=?";
    	    ResultSet rs=JdbcHelper.query(SQL,myid);
    	    String uSQL="SELECT username,password FROM t_user WHERE id=?";
    	    ResultSet urs=JdbcHelper.query(uSQL,myid);
    	    System.out.println( "我的个人id是: " + myid);
    	    final List<Touxiang> touxiang=new ArrayList<>();
    	    try {
    		if(rs.next())
    		{
    		    tx=new Touxiang();
    		    tx.setId(rs.getInt(1));
    		    tx.setImage_path(rs.getString(2));
    		    tx.setOld_name(rs.getString(3));
    		    touxiang.add(tx);
    		}
    		if(urs.next()){
    		    user.setUsername(urs.getString(1));
    		    user.setPassword(urs.getString(2));
    		    user.setTouxiang(touxiang);
    		}
    		
    	    } catch (SQLException e) {
    		// TODO Auto-generated catch block
    		e.printStackTrace();
    	    }
    	   
    		session.setAttribute("user", user);
    		System.out.println( "我的id: " + myid);
    		response.sendRedirect( request.getContextPath() + "/person.html");
    	}
        }
    }
    

     

    在HTML界面接收信息,并显示出来,代码如下:

     

    <div>
    	<form action="UploadServlet.do" method="post" enctype="multipart/form-data">
          		 <div><a href="$path/upImage.html">更换头像</a></div>
            	
            	#foreach( $ut in  $user.getTouxiang() )
            	 <img src=" $ut.getImage_path()"  width="200" height="200">
            	 #end
            	 <div>我的头像:</div>
            	 <div>我的姓名:$user.getUsername()</div>
            	 <div><a href="$path/myAnswer.do">我的解答</a></div>
    		<div><a href="$path/myQuestion.do">我的提问</a></div>
       	 </form>
    	</div>
    <div>
    	<form action="UploadServlet.do" method="post" enctype="multipart/form-data">
          		 <div><a href="$path/upImage.html">更换头像</a></div>
            	
            	#foreach( $ut in  $user.getTouxiang() )
            	 <img src=" $ut.getImage_path()"  width="200" height="200">
            	 #end
            	 <div>我的头像:</div>
            	 <div>我的姓名:$user.getUsername()</div>
            	 <div><a href="$path/myAnswer.do">我的解答</a></div>
    		<div><a href="$path/myQuestion.do">我的提问</a></div>
       	 </form>
    	</div>

     

    至此,一个基于Java的头像上传服务器,路径存储在MySQL,并在HTML界面读取出来的功能就基本实现了。头像上传之前进行处理等操作,可以选择一些插件来完成。这里只是简单的实现了基本功能。

     

     

    补充

    对于图片上传,这里只是简单的用Servlet实现了一下最基本的功能,仅提供思路。如果使用spring等框架,他都对图片上传做了很好的封装,应该更加容易。

    后台实现图片上传应该来说比较容易,但是比较头疼的是图片上传原生的按钮丑出天际,这里推荐俩实用的上传控件,应该算比较好看。

     

    1,H5实现的图片上传,可多张上传,可点击可拖拽上传,大概是这个样子:

    基本的使用介绍和下载地址:http://blog.csdn.net/weixin_36380516/article/details/70352689

     

    2,jQuery图像裁剪插件,大概长这样

     

    不仅提供上传,还有裁剪等功能,UI做的也美,

    地址:http://www.jq22.com/jquery-info318

     

    展开全文
  • Java 文件上传到服务器

    千次阅读 2019-08-05 09:49:30
    import java.io.File; import com.sun.jersey.api.client.Client; import ... /** * 文件上传帮助类 * @author yaco * @Date 2019年7月18日 下午2:16:09 */ public class UploadUtils...
    import java.io.File;
    import com.sun.jersey.api.client.Client;
    import com.sun.jersey.api.client.WebResource;
     
    /**
     * 文件上传帮助类
     * @author yaco
     * @Date 2019年7月18日 下午2:16:09
     */
    public class UploadUtils {
     
    	/**
    	 * 上传到文件服务器
    	 * @author: yaco
    	 * @Date  : 2019年7月18日 下午4:26:57  
    	 */
    	public static String uploadFile(byte[] file, String filePath, String fileName) throws Exception {
    		File targetFile = new File(filePath);
    		if (!targetFile.exists()) {
    			targetFile.mkdirs();
    		}
    		Client client = new Client();
    		WebResource resource = client.resource(filePath + fileName);
    		resource.put(String.class, file);
    		return filePath + fileName;
    	}
    }
     
    <!-- 文件传输 -->
    <dependency>
    	<groupId>com.sun.jersey</groupId>
    	<artifactId>jersey-client</artifactId>
    	<version>1.19.4</version>
    </dependency>
    <dependency>
    	<groupId>org.glassfish.jersey.core</groupId>
    	<artifactId>jersey-client</artifactId>
    </dependency>

     

    展开全文
  • 域名 空间什么的 求大神告知 想做一个论坛 不知道怎么申请域名空间 求完整的流程 谢谢谢谢
  • 网站文件夹复制您所购买的服务器,文件夹命名最好使用英文。 在对文件夹属性进行操作: 选中文件夹——》点击右键“属性”——》安全——》编辑——》添加——》高级——》立即查找——》Everyone——》选中...

    第一步:

    将网站文件夹复制到您所购买的服务器,文件夹命名最好使用英文。
    

    在对文件夹属性进行操作:
    选中文件夹——》点击右键“属性”——》安全——》编辑——》添加——》高级——》立即查找——》Everyone——》选中Everyone的所有权限。

    点击确定即可。

    第二步:

    选中IIS——》右上角的“工具”——》选择最上边的IIS管理器——》起始页下边的的那一项——》单击右键添加网站——》然后进行配置(主机名不用填,端口号不用更改,类型:http,IP地址选择服务器的公网IP,选内网IP只能在本服务器上浏览)。

    第三步:

    域名解析输入上传网站时使用的IP,解析完成即可。

    前提:这些操作的前提是在服务器上配置好了IIS。(教程:
    https://cloud.tencent.com/document/product/213/2755?!preview=true&lang=zh)
    
    展开全文
  • ssh本地的文件上传到服务器

    万次阅读 2017-10-19 09:51:07
    ssh本地的文件上传到服务器 程序代码 scp @:举例以说明:如果希望将当前目录下的a.txt文件上传到ssh服务器上test文件夹并改名为b.txt,其中ssh服务器网址为127.0.0.1,用户名root。代码如下:scp a.txt root...

    ssh把本地的文件上传到服务器

    程序代码

    scp <本地文件名> <用户名>@<ssh服务器地址>:<上传保存路径即文件名>

    举例以说明:

    如果希望将当前目录下的a.txt文件上传到ssh服务器上test文件夹并改名为b.txt,其中ssh服务器网址为127.0.0.1,用户名root。
    代码如下:
    scp a.txt root@127.0.0.1:/home/neo/test/b.txt

    下载也很简单,只需要将“本地文件名”和后面服务器的信息对调即可
    
    
    展开全文
  • (我是将文件上传到阿里云) (1)在本地的终端下,而不是在服务器上。在本地的终端上才能将本地的文件拷入服务器。 (2)scp -r localfile.txt username@192.168.0.1:/home/username/ 其中, 1)scp是命令,-...
  • 我开始是购买的虚拟服务器域名空间,用FTP上传很慢,瞎折腾了好几天时间,还是只上传一点点。人家说是我网络问题,貌似有些网络服务商对上传有限制。 二.解决方法: 后来又买了个VPS(虚拟专用服务器),个人感觉...
  • java上传文件到服务器

    热门讨论 2009-06-17 16:36:22
    java上传文件到服务器,将本地的文件上传到服务器上去
  • 使用Navicat for MySQL本地数据库上传到服务器

    万次阅读 多人点赞 2018-05-09 00:18:11
    服务器系统基本都是基于linux的,这个数据库上传的方式适用于linux的各种版本,比如Ubuntu和Centos(尽管这两个版本各种大坑小坑,但至少在数据库传输上保持了一致性) 当然本地数据库上传到服务器的前提是,服务器...
  • java文件上传到服务器

    万次阅读 2019-03-06 10:05:32
    java文件上传到服务器 最近项目中使用了文件从本地到服务器的功能。其实是为了解决目前浏览器不支持获取本地文件全路径。不得已而想到上传到服务器的固定目录,从而方便项目获取文件,进而使程序支持EXCEL批量...
  • 如题,现在有关系服务器和数据服务器,是应该给前端提供统一的接口让前端先上传到关系服务器,再从这里传数据服务器(是内网)么? 可是这样对关系服务器的带宽要求就会很高。如果直接让前端传数据服务器行不行...
  • 1、首先将文件上传到服务器, 2、将文件传数据库 3、上传完成后,删除文件
  • ASP.NET MVC 图片上传到服务器

    万次阅读 2018-05-09 21:16:26
    今天在做项目中需要做一个功能是:个人图片上传到服务器中,并路径保存数据库中!自己摸索着做了出来,但不是很完善,先记录下来,后台获取前端传过来的文件进行上传!后台代码: /// &lt;summary&...
  • jsp的file文件上传到服务器后,如果不把上传后的路径写入数据库,那么要如何取servlet里面的路径要在原页面中获取,或者转action中的某个方法中获取,如果我用这个方法来传递参数原页面![图片说明]...
  • 本地静态网页上传到服务器

    千次阅读 2020-04-23 15:29:33
    本地静态网页上传到服务器 这篇文章的目的是在服务器上建一个最基础的静态网页,在网上看了很多教程要么太高深涉及PHP或者MySQL等高级的东西,对于像我们这种只想要在服务器上运行一个静态网页的教程很少(也有...
  • php文件上传到远程服务器上例子

    千次阅读 2016-09-23 13:59:05
    在这里我们利用curl实现本地服务器的文件通过curl发送请求给远程服务器的php文件接受就实现了上传,还一个是利用ftp来上传方法也是php中的curl操作ftp服务器进行上传。 我这里写的是用curl的代码 本地代码如下...
  • 利用宝塔面板上传网站到服务器

    万次阅读 2018-08-14 18:38:29
    我用的是腾讯云服务器和域名,学生买比较便宜 详细步骤如下: 1.下载Xshell 6 2.https://www.banwagongzw.com/55.html 后面步骤参考这个,基本跟着做,不会有问题 3.https://www.banwagongzw.com/4.html 这是...
  • vue上传图片到服务器

    千次阅读 2018-06-30 12:18:09
    我们做的商家管理系统需要在添加一道菜的时候图片上传到服务器, 流程大概是这样子的: 搭建一个文件服务器(可以与你的网站后台放在同一台物理机上) 网站后台提供上传图片的API 前端接收图片后图片转成base...
  • 教新手如何本地的msSQL数据库上传到服务器 如何正确无误地本地的msSQL数据库上传到服务器 这2天帮2个客户上传MS SQL数据库到服务器,使用企业管理器导入数据,顺利地表和数据导入远程的SQL数据库。网站...
  • 上传的步骤:(本文采用git 命令界面进行操作) ( git config --global user.email "you@example.com" git config --global user.name "Your Name")实现登陆 1.进入本地的项目目录,右键“Git ...
  • 服务器的配置
  • iOS上传语音到服务器

    千次阅读 2016-01-17 22:44:35
    如果不是NSData就要想办法语音文件转化为NSData,然后才能上传服务器。首先我们拿语音文件对应的NSData对象 NSData *voiceData = [message valueForKey:@"wavAudioData"]; //kHostURL为开发者公司的APP对应的主...
  • 1.下载 可以从http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html下载pscp,并将其放入... 2、使用 (一)Windows—Linux上传文件: 1)、开始→运行→cmd进入dos模式,输入以下命令: pscp E:\java
  • JavaWeb项目上传到服务器的步骤

    千次阅读 2017-09-13 19:44:59
    之前研究怎样将项目上传到服务器上,为了今后自己看着方便记录一下- 1. 服务器创建数据库 会让你输入你的密码 密码多少自己知道create database + 库名- 2. 将本地数据库上传到服务器数据库中将本地数据库的表导出 ...
  • //第一步 保存用户上传的图片 chooseImage: function() { wx.chooseImage({ count: 1, //选择图片的数量 默认为9 success: (res) =&gt; { console.log(res) //tempFilePaths 图片的本地临时文件路径列表 ...
  • Java实现图片上传到服务器

    万次阅读 2019-03-06 09:30:15
    Java实现图片上传到服务器 #这几天研究图片上传到服务器并回显页面遇到了问题,在这里总结一下!希望对各位有用!!! 先上代码 js代码 var formData = new FormData($( &amp;quot;#myform&amp;...
  • putty上传文件到服务器

    千次阅读 2018-12-17 11:04:25
    pscp -r -P 你的端口号 你要上传的文件 用户名@服务器IP:要上传到服务器的文件夹。如果使用默认端口22可以不用写-P 端口号。 pscp -r -P 20092 C:\Users\程勇\Desktop\USA_mengwanzhou1.json hl@22...
  • ``` 现在页面上有 ;base64,..."> 我想它赋值一个文件域上然后提交到服务器 请问"赋值"这个步骤怎么弄 ```
  • 文章目录一、简介二、动态效果图三、配置服务器过程3.1、打开配置项3.2、添加SFTP服务器链接3.3、起一个服务器的名字,方便上传3.4、...上传代码到服务器,如果不知道的情况下还用传统的方式上传很麻烦,现在很多IDE...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 715,084
精华内容 286,033
关键字:

把网站上传到服务器